静态文件配置*******

为什么用户在浏览器中输入的网址能够访问到对应的资源,

前提是后端提前开设该资源的访问,在urls.py文件中进行配置该路由,

如果我的后端没有开设相关的资源,用户是无法访问到的。

1.默认情况下所有的html文件都是放在templates文件夹内

2.什么是静态文件
网站所使用到的提前写好的css js 第三方模块 图片都叫做静态资源 3.默认情况下网站所用到的静态文件资源全部放在static文件夹下。
通常情况下,在static文件夹内部还会再建其他文件夹
css 文件夹
js 文件夹
font 文件夹
img 文件夹
为了更加方便的管理文件
django中,需要手动创建static文件夹 4.静态文件动态绑定----重点!!!
{%load static%}
<link rel="stylesheet" href="{%static 'bootstrap-3.3.7-dist/css/bootstrap.min.css' %}">
<script src="{%static 'bootstrap-3.3.7-dist/js/bootstrap.min.js' %}"></script> 5. #访问静态资源文件接口前缀,通常情况下接口前缀的名字是static
STATIC_URL = '/xxx/'
#例如通过 http://127.0.0.1:8000/xxx/a.txt查找a.txt文件
#手动配置静态文件访问资源
STATICFILES_DIRS=[
os.path.join(BASE_DIR,'static')
os.path.join(BASE_DIR,'static1')
os.path.join(BASE_DIR,'static2')
#多个配置文件,查找顺序,自上向下依次查找,找到就结束 ] 6.
form表单默认是get请求
get请求也能够携带参数
http://127.0.0.1:8000/login/?username=jjjjksk & password=123
特点:url?xxx=xxxx & yyyy=yyyy
1.携带的数据不够安全
2.携带的数据大小有限制 ,最大好像应该差不多是4kb左右
3.通常只会携带一些不是很重要的数据 7.post请求会出现403,需要注释settings中下面的中间件
MIDDLEWARE = [
'django.middleware.security.SecurityMiddleware',
'django.contrib.sessions.middleware.SessionMiddleware',
'django.middleware.common.CommonMiddleware',
# 'django.middleware.csrf.CsrfViewMiddleware',
'django.contrib.auth.middleware.AuthenticationMiddleware',
'django.contrib.messages.middleware.MessageMiddleware',
'django.middleware.clickjacking.XFrameOptionsMiddleware',

]

8.
<form action="" method="">默认处理的是get请求,
get请求指向拿到login页面
post请求向后端提交数据,然后后端做校验 9.如何判断当前请求方式???
request.method获取请求的方式
拿到的是字符串大写的请求方式 GET POST
print(request.method,type(request.method))
打印:GET <class 'str'> def login(request): # print('来了,小老弟')
# print(request.method,type(request.method)) if request.method=='post':
print(request.method)
return HttpResponse('昂首挺胸') print(request.method)
return render(request,'login.html') '''
视图函数都必须有返回值,
并且返回值都是HttpResponse对象 ''' 10.request方法初始
request.method 获取请求方式,并且纯大写的字符串 print(request.POST) 获取用户提交的post请求数据
如何获取用户数据*********
request.POST.get() #默认只会获取列表最后一个元素
request.POST.getlist() #如果你想获取列表,用getlist()方法 print(request.GET) 获取用户提交的GET请求数据
如何获取用户数据*********
request.GET.get() #默认只会获取列 表最后一个元素
request.GET.getlist() #如果你想获取列表,用getlist()方法 11.pycharm连接数据库,如果最右侧没有显示database的话,可以在settings中配置
settings --> Plugins --> Database Tools and SQL(推荐右侧的全部勾选上) 12.django连接MySQL***********
必须要有两步操作
1.在settings中找到DATABASES,然后把default中的配置修改为对应mysql的信息
需要注意的是default中的key值都需要是全大写。 原始的 DATABASES = {
'default': {
'ENGINE': 'django.db.backends.sqlite3',
'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
}
} 改后的 DATABASES = {
'default': {
'ENGINE': 'django.db.backends.mysql',
'NAME': 'day49',
'USER':'root',
'PASSWORD':'root',
'HOST':'127.0.0.1',
'PORT':3306,
'CHARSET':'utf8' }
} 2.主动告诉django 不要用默认的mysqldb连接,而是用pymysql
你可以在项目名下的__init__.py中书写
也可以在应用名下的__init__.py中书写
书写内容是:
import pymysql
pymysql.install_as_MySQLdb() 13.django orm简介
orm 对象关系映射
类 --- 表
对象 --- 数据
对象.属性 --- 字段对应的值 为什么使用orm?
能够让不会数据库操作的人也能够简单方便去操作数据库
orm的缺点:
封装程度太高,有时候会出现查询效率偏低的问题
所以工作中:
简单的用orm
复杂的追求速度的,需要你手动书写sql语句 14.django中如何操作orm?
书写模型类
去应用下的models.py中书写模型类 注意事项:
之后在写django项目的时候,一个django项目对应一个数据库,
不要出现多个项目使用同一个数据库的情况************* 15.*****************数据库迁移(同步)命令********************************
1.python manage.py makemigrations 将数据库的修改,记录到migrations文件中 2.python manage.py migrate 将修改操作真正的同步记录到数据库中 注意事项:
1.这两条命令是同步进行的,成双成对,缺一不可
2.只要修改了models里面和数据库相关的代码,你就必须重新执行上面的两条命令 个人建议:
只要你离开了你的电脑,你就顺手锁屏,锁屏快捷键是 Windows+L 锁屏 ************************************************************************* 16.模型表字段的增删改查
class User(models.Model):
username = models.CharField(max_length=255)
password = models.IntegerField()
email = models.EmailField() 注意事项:
字段:email = models.EmailField()
该字段需要设置默认值,或者该字段允许为空,两种方式需要选择一个
方式1 设置默认值
email = models.EmailField(default='123@qq.com')
方式2 设置为空
email = models.EmailField(null=True)
注意:email虽然之前设置了默认值 default='123@qq.com' 后面又修改为 null=True,
但是仍然对之前设置过的email字段没有任何影响的
phone = models.BigIntegerField(null=True)
方式3 直接根据他的提示设置默认值
gender
'''
E:\Python jieshiqi\11月份练习考试\day50>python manage.py makemigrations 1) Provide a one-off default now (will be set on all existing ro
ws with a null value for this column)
2) Quit, and let me add a default in models.py
Select an option: 1 #######此处做出自己的选择,1设置默认值,2退出设置默认值
Please enter the default value now, as valid Python
The datetime and django.utils.timezone modules are available, so
you can do e.g. timezone.now
Type 'exit' to exit this prompt
>>> 'male' #######此处设置默认值,注意要有引号
Migrations for 'app01':
app01\migrations\0005_auto_20191123_2054.py
- Add field gender to user
- Alter field email on user E:\Python jieshiqi\11月份练习考试\day50>python manage.py migrate ###不要忘记提交数据到数据库 ''' 注意事项,字段的删除谨慎使用,因为对应字段都已经有了数据,删除后不可恢复(如同删库跑路)
删除字段email、phone、gender:
# email = models.EmailField(default='123@qq.com')
# phone = models.BigIntegerField(null=True)
# gender = models.CharField(max_length=64)
删除字段的方法:
直接注释对应字段的代码 +python manage.py makemigrations + python manage.py migrate 17.模型表数据的增删改查****************
查:
data = models.User.objects.filter(username=username)
print(data) #<QuerySet [<User: User object>]> '''
filter 返回的结果是一个列表,里面才是真正的数据对象
filter 括号内可以放多个关键字参数,这多个关键字参数在查询的时候是and的关系不是or的关系
'''
user_list=models.User.objects.all() #查询出所有
print(user_list) #列表里面有4个对象<QuerySet [<User: User object>, <User: User object>, <User: User object>, <User: User object>]>
#对象被打印会执行__str__方法
增:
user_obj=models.User.objects.create(username=username,password=password)
print(user_obj,user_obj.username,user_obj.password)
#create方法会有一个返回值,返回值就是当前被创建的对象本身(如上面的user_obj) 改: #修改数据库中的数据
#sql语句:update User set username='jsdnn',password='123' where id=1;
models.User.objects.filter(id=edit_id).update(username=username,password=password) #修改完毕
'''
上面的更新语句属于批量操作,会将filter查询出来的列表中所有的对象全部更新
更新之后,重定向到用户列表页面 由于更新重要,所以我拷贝了一份完整的代码,以供查阅
def edit_user(request):
'''
返回编辑页面,编辑页面要含有用户的原来数据,提交后,保存数据到数据库
问题:
1.如何获取用户想要编辑的对应ID数据呢?
利用get请求携带参数的方式,获取用户想要编辑的数据id值
edit_id=request.GET.get('edit_id')
2.如何查询出来要编辑的数据
将用户想要编辑的数据查询出来,展示到编辑页面上,供用户修改
edit_obj=models.User.objects.filter(id=edit_id)[0] #支持索引取值,也支持切片操作,但是不支持负数
edit_obj=models.User.objects.filter(id=edit_id).first()
上面两行代码是同一个意思,查询出对应id的数据
return render(request,'edit_user.html',{'edit_obj':edit_obj}) :param request:
:return:
'''
edit_id = request.GET.get('edit_id')
if request.method == 'POST':
username=request.POST.get('username')
password=request.POST.get('password')
#修改数据库中的数据
#sql语句:update User set username='jsdnn',password='123' where id=1;
models.User.objects.filter(id=edit_id).update(username=username,password=password) #修改完毕
'''
上面的更新语句属于批量操作,会将filter查询出来的列表中所有的对象全部更新
更新之后,重定向到用户列表页面 ''' return redirect('/userlist/') edit_obj = models.User.objects.filter(id=edit_id).first()
return render(request,'edit_user.html',{'edit_obj':edit_obj}) 删:
#直接删除
models.User.objects.filter(id=delete_id).delete()
'''
批量操作,会将filter查询出来的列表中所有的对象全部删除 ''' 注意事项:
password = models.CharField(max_length=64)
修改字段类型以后,必须下面的password由整形修改为varchar类型,也是需要提交这两句命令的
python manage.py makemigrations
python manage.py migrate
然后数据库中的对应字段类型,才会从整形修改为字符串类型

最新文章

  1. NC57,NC63-NC二开经验总结
  2. Atitit 表达式原理 语法分析&#160;原理与实践 解析java的dsl &#160;递归下降是现阶段主流的语法分析方法
  3. Sql Server 2008 无法启动T-Sql调试问题的解决方案
  4. Java JSON、XML文件/字符串与Bean对象互转解析
  5. Java基础(1):Switch语句注意的5个地方
  6. 基于visual Studio2013解决面试题之0701寻找丑数
  7. jquery 判断当前上传文件大小限制上传格式 搭配thinkphp实现上传即预览(模拟异步上传)
  8. ReentrantLock获取、释放锁的过程
  9. IP地址和硬件地址 ARP协议
  10. Codeforces Round #483 (Div. 2) C. Finite or not?
  11. 图解TCP/IP
  12. Mybatis学习笔记之二(动态mapper开发和spring-mybatis整合)
  13. js倒计时一分钟
  14. 13树莓派手动安装Home Assistant
  15. 第 9 章 数据管理 - 074 - 如何安装和配置 Rex-Ray?
  16. java中String创建对象分析(转)
  17. Scrapy结构
  18. opengl 无法定位程序输入点_glutInitWithExit于动态链接库glut32.dll上
  19. We Need More Bosses CodeForces - 1000E(缩点 建图 求桥 求直径)
  20. http1.0 和 http1.1 主要区别

热门文章

  1. 在ensp上利用三层交换机实现VLAN间路由
  2. Hook原理--逆向开发
  3. firefox浏览器中使用vux的x-input报错TypeError: _this3.$refs.input.scrollIntoViewIfNeeded is not a function
  4. Fragment的生命周期(与Activity的对比)
  5. 2019-11-19:xxe漏洞利用,笔记
  6. C#连接SAP【生产系统与ERP对接】
  7. 【记录】洛谷P1739-表达式括号匹配AC记
  8. Erlang/Elixir精选-第1期
  9. 程序员的算法课(6)-最长公共子序列(LCS)
  10. 线程池&amp;进程池