1. 注册应用的
INSTALLED_APPS =  [ 'django.contrib.admin' , 'django.contrib.auth' , 'django.contrib.contenttypes' , 'django.contrib.sessions' , 'django.contrib.messages' , 'django.contrib.staticfiles' , 'app01.apps.App01Config' , 
] 
2. 中间件
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' , 
] 
ROOT_URLCONF =  'day54_dj.urls'  3 . Django连接MySQL数据库的
DATABASES =  { 'default' :  { 'ENGINE' :  'django.db.backends.sqlite3' , 'NAME' :  os. path. join( BASE_DIR,  'db.sqlite3' ) , } 
} LANGUAGE_CODE =  'zh-hans'  
TIME_ZONE =  'Asia/Shanghai' 
"""
Django settings for day54 project.Generated by 'django-admin startproject' using Django 1.11.20.For more information on this file, see
https://docs.djangoproject.com/en/1.11/topics/settings/For the full list of settings and their values, see
https://docs.djangoproject.com/en/1.11/ref/settings/
""" import  os
BASE_DIR =  os. path. dirname( os. path. dirname( os. path. abspath( __file__) ) ) 
SECRET_KEY =  'k)_am7d@*mbelt*c*i84r$8^a%1#f7^_6cxa$esk47pa+a^tkm' 
DEBUG =  True ALLOWED_HOSTS =  [ ] 
from  django. contrib import  admin
INSTALLED_APPS =  [ 'django.contrib.admin' , 'django.contrib.auth' , 'django.contrib.contenttypes' , 'django.contrib.sessions' , 'django.contrib.messages' , 'django.contrib.staticfiles' , 'app01.apps.App01Config' ,  
] 
MIDDLEWARE =  [ 'django.middleware.security.SecurityMiddleware' , 'django.contrib.sessions.middleware.SessionMiddleware' , 'django.middleware.common.CommonMiddleware' , 'django.contrib.auth.middleware.AuthenticationMiddleware' , 'django.contrib.messages.middleware.MessageMiddleware' , 'django.middleware.clickjacking.XFrameOptionsMiddleware' , 
] 
ROOT_URLCONF =  'day54.urls' 
TEMPLATES =  [ { 'BACKEND' :  'django.template.backends.django.DjangoTemplates' , 'DIRS' :  [ os. path. join( BASE_DIR,  'templates' ) ] , 'APP_DIRS' :  True , 'OPTIONS' :  { 'context_processors' :  [ 'django.template.context_processors.debug' , 'django.template.context_processors.request' , 'django.contrib.auth.context_processors.auth' , 'django.contrib.messages.context_processors.messages' , ] , } , } , 
] 
WSGI_APPLICATION =  'day54.wsgi.application' 
DATABASES =  { 'default' :  { 'ENGINE' :  'django.db.backends.mysql' , 'NAME' :  'db17' , 'HOST' :  '127.0.0.1' , 'PORT' :  3306 , 'USER' :  'root' , 'PASSWORD' :  'root' , 'CHARSET' :  'utf8' } , 
} 
AUTH_PASSWORD_VALIDATORS =  [ { 'NAME' :  'django.contrib.auth.password_validation.UserAttributeSimilarityValidator' , } , { 'NAME' :  'django.contrib.auth.password_validation.MinimumLengthValidator' , } , { 'NAME' :  'django.contrib.auth.password_validation.CommonPasswordValidator' , } , { 'NAME' :  'django.contrib.auth.password_validation.NumericPasswordValidator' , } , 
] 
LANGUAGE_CODE =  'zh-hans' 
TIME_ZONE =  'Asia/Shanghai' USE_I18N =  True USE_L10N =  True USE_TZ =  True 
STATIC_URL =  '/static/' STATICFILES_DIRS =  [ os. path. join( BASE_DIR,  'static' ) 
] < form action= "" > action参数的三种情况:1.  什么都不写,就是朝当前地址提交数据2.  要么全写:http: // 127.0 .0 .1 : 8000 / login/ ?username= & password= 3.  只写后缀http: // 127.0 .0 .1 : 8000 / login/ 
"""我们知道静态模板文件都是放在templates文件夹中,如果没有这个文件夹就自己创建我们一般把静态文件放在static文件夹中,  但是,需要我们自己手动创建出来这个文件夹静态文件:网站使用的CSS文件网站使用的js文件网站使用图片网站使用的第三方库文件jQuery、bootstrap等""" 
1. 可以针对不同的功能对static文件夹里面的文件进行拆分
css
js
img
. . . 注意:看起来是对的,但是不能访问到
http: // 127.0 .0 .1 : 8000 / static/ bootstrap- 3.4 .1 - dist/ js/ bootstrap. min . js 之前访问的地址都可以访问到,那是因为在后端开设了可以访问的接口( 理由) 
之所以现在访问不到刚才的地址,是因为在后端没有开设这样的一个可访问的接口( 路由) 2 . Django自动的帮我们写好了这样的接口访问静态文件的令牌,以后你只要访问静态文件的路径,就要以/ static/ 开头
STATIC_URL =  '/vxcvxcvxcvxcvcx/'   STATICFILES_DIRS =  [ os. path. join( BASE_DIR,  'static' ) 
] 3. 动态解析路径
{ %  load static % } 
< script src= "{% static 'js/jquery.min.js' %}" > < / script> 
< link rel= "stylesheet"  href= "{% static 'bootstrap-3.4.1-dist/css/bootstrap.min.css' %}" > 
< script src= "{% static 'bootstrap-3.4.1-dist/js/bootstrap.min.js' %}" > < / script> 
request. method  
print ( request. POST)  
print ( request. POST. get( 'username' ) )   print ( request. GET)   
print ( request. GET. get( 'username' ) )   在 Django 中,`request` 对象是在视图函数中作为参数传递的,它包含了客户端发起的 HTTP 请求信息,包括请求的方法。在视图函数中,你可以通过 `request. method` 属性获取请求方法。常见的 HTTP 请求方法有以下几种:1.  GET:用于从服务器获取数据,通常用于请求页面或资源。
2.  POST:用于向服务器提交数据,通常用于提交表单数据或执行某些操作。
3.  PUT:用于更新服务器上的资源,通常用于更新已有数据。
4.  DELETE:用于删除服务器上的资源,通常用于删除某个数据。在 Django 中,通过检查 `request. method` 属性,你可以判断请求的方法,并根据不同的方法执行不同的操作。下面是一个示例:from  django. http import  HttpResponsedef  my_view ( request) : if  request. method ==  'GET' : return  HttpResponse( "这是一个 GET 请求" ) elif  request. method ==  'POST' : return  HttpResponse( "这是一个 POST 请求" ) elif  request. method ==  'PUT' : return  HttpResponse( "这是一个 PUT 请求" ) elif  request. method ==  'DELETE' : return  HttpResponse( "这是一个 DELETE 请求" ) else : return  HttpResponse( "未知请求方法" ) 在上面的例子中,视图函数 `my_view` 根据不同的请求方法返回不同的响应内容。根据实际需求,你可以在视图函数中根据请求方法执行相应的逻辑和操作。需要注意的是,要使用 `request` 对象,你需要在视图函数的参数列表中将它传递进来,例如:`def  my_view( request) : `。在 Django 中,视图函数的第一个参数通常是 `request` 对象,它包含了客户端发起的请求信息。在 Django 中,`request` 对象是一个包含了客户端发起的 HTTP 请求信息的对象。它是在 Django 视图函数中作为参数传递的,用于处理来自用户浏览器或其他客户端的请求。`request` 对象包含了许多属性和方法,其中包括:1.  `request. method`:  获取请求的 HTTP 方法,例如 GET、POST、PUT、DELETE 等。
2.  `request. GET`:  包含了 GET 请求参数的字典。可以通过 `request. GET. get( 'param_name' ) ` 来获取具体的参数值。
3.  `request. POST`:  包含了 POST 请求参数的字典。可以通过 `request. POST. get( 'param_name' ) ` 来获取具体的参数值。
4.  `request. FILES`:  包含了上传文件的信息,通常用于处理文件上传表单。
5.  `request. path`:  获取请求的路径,例如 "/myapp/myview/" 。
6.  `request. path_info`:  获取请求的路径信息,例如 "/myapp/myview/" ,不包含查询参数。
7.  `request. get_full_path( ) `:  获取请求的完整路径,包括路径和查询参数。
8.  `request. is_secure( ) `:  判断请求是否使用了 HTTPS 安全协议。除了上述属性和方法,`request` 对象还包含其他有关请求的信息,例如请求头信息、用户 IP 地址、会话信息等。你可以通过 `request` 对象来获取客户端发起的请求数据,从而根据请求数据做出相应的处理和响应。在 Django 中,视图函数的第一个参数通常是 `request` 对象,例如:from  django. http import  HttpResponsedef  my_view ( request) : return  HttpResponse( "Hello, World!" ) 通过使用 `request` 对象,你可以在视图函数中访问并处理客户端发起的请求数据,从而实现不同的业务逻辑和功能。
1. 默认情况sqlite3
DATABASES =  { 'default' :  { 'ENGINE' :  'django.db.backends.sqlite3' , 'NAME' :  os. path. join( BASE_DIR,  'db.sqlite3' ) , } 
} 2. 连接MySQL
DATABASES =  { 'default' :  { 'ENGINE' :  'django.db.backends.sqlite3' , 'NAME' :  os. path. join( BASE_DIR,  'db.sqlite3' ) , } 
} 3. 解决bug的思路:1.  就是print ( ) 2.  看是否有日志3.  看报错的信息去百度中搜索4.  问问别人4. 连接MySQL数据的时候可能报错的解决办法:
1.  如果解释器版本导致的问题,直接改源码base. pydef  get_new_connection ( self,  conn_params) : conn =  Database. connect( ** conn_params) conn. encoders[ SafeText]  =  conn. encoders[ six. text_type] 先判断bytes 是否存在于编码器中,如果在才执行操作if  bytes  in  conn. encoders:  conn. encoders[ SafeBytes]  =  conn. encoders[ bytes ] return  conn2.  解释器版本改为3.6 的时候也会报错Django的底层默认使用的是mysqldb模块,这个模块兼容性很差我们还使用pymysql连接mysql,你要提前安装pymysql模块Did you install mysqlclient or  MySQL- python?3. 怎么解决这个问题:在项目的任意的__init__. py中加入下面两行代码** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** * import  pymysqlpymysql. install_as_MySQLdb( )   以上这两行代码的意思就是把底层的mysqldb模块换成pymysql** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** * 4.  除了使用mysqldb、pymysql之外还可以使用mysqlclient这个模块用了mysqlclient这个模块,就不用加上面那两句话了mysqlclient安装的时候可能会报各种错误DATABASES =  { 'default' :  { 'ENGINE' :  'django.db.backends.mysql' , 'NAME' :  'db9' , 'HOST' :  '127.0.0.1' , 'PORT' :  3306 , 'USER' :  'root' , 'PASSWORD' :  'root' , 'CHARSET' :  'utf8' } 
} 
什么是ORM:对象映射模型以后在django中写根数据库相关的代码时候,就不用再写原生的SQL语句了,直接通过python代码来操作数据的增删改查. 1 . orm的书写位置:在models. py中书写
概念表				>> >> >      类名记录				>> >> >     对象字段				>> >> >     属性2. 创建出来一张表来所有的类必须继承models. Modelclass  User ( models. Model) :   id  =  models. AutoField( primary_key= True ) username =  models. CharField( max_length= 64 ) password =  models. CharField( max_length= 64 ) 3. 类写完之后,一定要做数据库迁移,真正的在数据库中生成表
** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** python36 manage. py makemigrations  它的作用是把数据库的迁移记录保存下来python36 manage. py migrate		   才是真正的把数据表创建出来
** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** 
class  Author ( models. Model) : '''如果创建的表中有主键字段,并且,主键字段的名字也叫id,那么,以后就可以直接省略id字段''' name =  models. CharField( max_length= 64 ) 如何做查询  select *  from  author where username =  jack and  password =  123 objects: 小组件,里面封装了很多的方法res= models. Author. objects. create( name= username, password= password)