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

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

前提是后端提前开设该资源的访问,在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
然后数据库中的对应字段类型,才会从整形修改为字符串类型

Django 之day02,必会知识点的更多相关文章

  1. [新手必备]Python 基础入门必学知识点笔记

    Python 作为近几年越来越流行的语言,吸引了大量的学员开始学习,为了方便新手小白在学习过程中,更加快捷方便的查漏补缺.根据网上各种乱七八糟的资料以及实验楼的 Python 基础内容整理了一份极度适 ...

  2. java数据库学习路线和必学知识点!

    java数据库必学知识点! 分享一下数据库的学习路线和必学的知识点! 掌握mysql,Oracle在各个平台上的安装及使用 Mysql数据库基础 mysql概述.优点.运行原理及内存结构 mysql数 ...

  3. Django学习day02随堂笔记

    每日测验 """ 今日考题 1.谈谈你对web框架的认识,简述web框架请求流程 2.python三大主流web框架的区别 3.安装django需要注意的事项有哪些(最少 ...

  4. MySQL面试必考知识点:揭秘亿级高并发数据库调优与最佳实践法则

    做业务,要懂基本的SQL语句: 做性能优化,要懂索引,懂引擎: 做分库分表,要懂主从,懂读写分离... 数据库的使用,是开发人员的基本功,对它掌握越清晰越深入,你能做的事情就越多. 今天我们用10分钟 ...

  5. Django ORM 操作 必知必会13条 单表查询

    ORM 操作 必知必会13条 import os # if __name__ == '__main__': # 当前文件下执行 os.environ.setdefault('DJANGO_SETTIN ...

  6. linux驱动工程面试必问知识点

    linux内核原理面试必问(由易到难) 简单型 1:linux中内核空间及用户空间的区别?用户空间与内核通信方式有哪些? 2:linux中内存划分及如何使用?虚拟地址及物理地址的概念及彼此之间的转化, ...

  7. 精选Spring Boot三十五道必知必会知识点

    Spring Boot 是微服务中最好的 Java 框架. 我们建议你能够成为一名 Spring Boot 的专家.本文精选了三十五个常见的Spring Boot知识点,祝你一臂之力! 问题一 Spr ...

  8. django面试题必知

    Django的Model的继承有几种形式,分别是什么?(私信小编001 .002 .003 .007任何一个即可获取Python学习资料) 一.抽象继承: 这种继承的定义方法如下: 上例中,我们的Hu ...

  9. django面试题必问

    1.谈谈你对http协议的认识. HTTP协议(HyperText Transfer Protocol,超文本传输协议)是用于从WWW服务器传输超文本到本地浏览器的传送协议.它可以使浏览器更加高效,使 ...

随机推荐

  1. linux计算机网络基础

    OSI7层协议和TCP/IP4层网络协议 第一层:物理层,定义各种物理设备的规范,如通信距离,接口大小等. 第二层:数据链路层,基于mac地址通信是,数据报文封装和相应方式. 第三层:网络层,基于IP ...

  2. 利用堆来处理Top K问题

    目录 一.什么是Top K问题 二.Top K的实际应用场景 三.Top K问题的代码实现及其效率对比 1.用堆来实现Top K 2.用快排来实现Top K 3.用堆或用快排来实现 TopK 的效率对 ...

  3. es6 every的使用

    let arr2 =[1,3,5,7,9,10]; //arr2.every() 数组里面所有的元素都有符合条件,才返回true var b =arr2.every(function (val,ind ...

  4. [UWP]UIElement.Clip虽然残废,但它还可以这样玩

    1. 复习一下WPF的UIElement.Clip 用了很久很久的WPF,但几乎没有主动用过它的Clip属性,我只记得它很灵活,可以裁剪出多种形状.在官方文档复习了一下,大致用法和效果如下: < ...

  5. .Net Core使用分布式缓存Redis:基础

    一.前言 Redis的介绍网上很多不再赘述.本次环境为net core 2.2,使用的StackExchange.Redis来操作Redis. 二.引用Microsoft.Extensions.Cac ...

  6. 实战webpack系列03

    03.Webpack的强大功能 一.生成Source Maps(使调试更容易) 通过简单的配置,webpack就可以在打包时为我们生成的source maps,这为我们提供了一种对应编译文件和源文件的 ...

  7. linux命令之less命令

    一.我查看日志特别喜欢用less命令来查看,下面给大家讲解下使用. less(选项)(参数) 选项如下: -e:文件内容显示完毕后,自动退出: -f:强制显示文件: -g:不加亮显示搜索到的所有关键词 ...

  8. linux搭建ftp出错汇总

    重启vsftpd出现”500 OOPS: vsftpd: cannot open config file:restart” 2008-05-09 21:33 进到/etc/init.d/目录 输入: ...

  9. c# 窗体开发1 基本控件的使用

      namespace firstly #当前命名空间控件 { public partial class Form1 : Form { public Form1() #第一个窗体 { Initiali ...

  10. 从入门到入土:Lambda完整学习指南,包教包会!

    什么是Lambda表达式 Lambda表达式是Java SE 8中一个重要的新特性.lambda表达式允许你通过表达式来代替功能接口.lambda表达式就和方法一样,它提供了一个正常的参数列表和一个使 ...