Django-01-HTTP协议、Jinja2模块、python三大主流web框架、创建django项目、django基础必备三件套(HttpResponse,render,redirect)

一、自定义web框架

1.HTTP协议
"""
网络协议
HTTP协议 	   数据传输是明文
HTTPS协议       数据传输是密文
websocket协议   数据传输是密文

四大特性
	1.基于请求响应
	2.基于TCP、IP作用于应用层之上的协议
	3.无状态
	4.短/无连接

数据格式
	请求首行
	请求头
	
	请求体

响应状态码
	1xx
	2xx		200
	3xx		
	4xx		403 404
	5xx		500
"""
# 如何做到后缀的不同返回不同的内容
	# 拿到用户输入的后缀 做判断
# 不足之处
	1.代码重复(服务端代码所有人都要重复写)
	2.手动处理http格式的数据  并且只能拿到ur1后缀  其他数据获取繁琐(数据格式一样处理的代码其实也大致一样  重复写)
	3.并发的问题
2.借助于wsgiref模块
"""
urls.py			  路由与视图函数对应关系
views.py		  视图函数(后端业务逻辑)
templates文件夹	专门用来存储html文件
"""
#按照功能的不同拆分之后  后续添加功能只需要在urls.py书写对应关系然后取views.py书写业务逻辑即可
3.动静态网页
  • 静态网页
    页面上的数据是直接写死的 万年不变

  • 动态网页
    数据是实时获取的
    eg:
    1.后端获取当前时间展示到html页面上
    2.数据是从数据库中获取的展示到html页面上

      # 动态网页制作
      import datetime
      def get_time(env):
      	current_time = datetime.datetime.now().strftime('%Y-%m-%d %X')
          # 如何将后端获取到的数据"传递”给html文件?
      	with open(r'templates/03 mytime.html','r",encoding='utf-8') as f:
          	data = f.read()
      		# data就是一堆字符串
      	data = data.replace('dwadasdsadsadasdas',current_time) # 在后端将html页面处理好之后再返回给前端
      	return data
                    
      # 将一个字典传递给html文件  并且可以在文件上方便快捷的操作字典数据
      from jinja2 import Template
      def get_dict(env):
          user_dic= {'username':'jasn','age':18,'hobby':'read'}
          with open(r'templates/04 get_dict.html','r' ,encoding='utf-8') as f:
          	data = f.read()
          tmp =  Template(data)
          res = tmp.render(user=user_dic)
      	# get_dict.htm传递了一个值  页面上通过变量名user就能够拿到user_ dict
          return res
                    
      # 后端获取数据库中数据展示到前端页面
    
4.模版语法之Jinja2模块
pip install jinja2
"""模板语法是在后端起作用的"""

# 模版语法(非常贴近python语法)
{
   
   { user }}  
{
   
   { user.get('username" )}} 
{
   
   { user.age }}
{
   
   { user['hobby'] }} 
            
{% for user_dict in user_list %}
	くtr>
		<td>{
   
   { user_dict.id}}</td>
		<td>{
   
   { user_dict.username}})</td>
  		<td>{
   
   { user_dict.password}}</td>
  		<td>{
   
   {user_dict.hobby}}</td>
	</tr>
{% endfor %}
5.自定义简易版本web框架请求流程图

在这里插入图片描述

wsgiref模块
    1.请求来的时候解析http格式的数据  封装成大字典
    2.响应走的时候给数据打包成符合http格式  再返回给浏览器

二、python三大主流web框架

django

特点:大而全,自带了很多功能模块,类似于航空母舰
不足之处:
	有时候过于笨重

flask

特点:短小精悍,自带的功能模块特别少,类似于游骑兵
第三方的模块特别特别特别的多,如果将flask第三方的模块加起来完全可以盖过django
并且也越来越像django 
不足之处:
	比较依赖于第三方的开发者

tornado

特点:异步非阻塞  支持高并发
	甚至可以开发游戏服务器
不足之处:
	暂时不会

A:socket部分
B:路由与视图函数对应关系(路由匹配)
C:模版语法
    
django
    A用的是别人的  wsgiref模块
    B用的是自己的
    C用的是自己的(没有jinja2好用  但是也很方便)
flask
    A用的是别人的  werkzeug(内部还是wsgiref模块)
    B自己写的
    C用的别人的(jinja2)
tornado
	A,B,C都是自己写的

三、注意事项

# 如何让你的计算机能够正常的启动django项目
    1.计算机的名称设置为英文
    2.一个pycharm窗口只开一个项目
    3.项目里面所有的文件也使用英文
    4.python解释器尽量使用3.4~3.6之间的版本
    (如果你的项目报错你点击最后一个报错信息,去源码中把逗号删掉)
# django版本问题
1.x 2.x 3.×(直接忽略)
# django安装
pip3 install django==1.11.11
如果已经安装了其他版本无需自己卸载
直接重新装  会自动卸载安装新的

四、django基本操作

命令行操作

# 1.创建django项目

你可以先切换到对应的D盘  然后再创建

django-admin startproject mysite
	mysite文件夹
    	manage.py
        mysite文件夹
            _init.py
            settings-py
            urls.py
            wsgi.py
# 2.启动django项目
"""
	一定要先切换到项目目录下
    cd /mysite
"""
	python3 manage.py runserver		
	# http://127.0.0.1:8000/
# 3.创建应用
"""
Next, start your first app by running python manage.py startapp[ app_label].
"""
    python manage.py startapp appo1
    应用名应该做到见名知意

创建的应用一定要去配置文件中注册

INSTALLED_APPS = [
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes,
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
    'app01.apps.App01Config',  #  全写
    'app01'  #  简写
# 创建出来的的应用第一步先去配置文件中注册

pycharm操作

# 1 new project  选择左侧第二个django即可

# 2 启动
    1.还是用命令行启动
    2.点击绿色小箭头即可
    
# 3.创建应用
    1.pycharm提供的终端直接输入完整命令
    2.pycharm
		 tools
			run manage.py task提示
# 4.修改端口号以及创建server
	edit confi....

命令行与pycharm创建的区别

# 1 命令行创建不会自动有templatew文件夹  需要你自己手动创建而pycharm会自动创建,并且还会自动在配置文件中配置对应的路径
# pycharm创建
TEMPLATES = [
    {
        'BACKEND': 'django.template.backends.django.DjangoTemplates',
        'DIRS' : [os.path.join(BASE_DIR,'templates')]
]
# 命令行创建
TEMPLATES =[
{
        'BACKEND': 'django.template.backends.django.DjangoTemplates',
        'DIRS' : [],
]
"""
也就意味着你在用命令创建django项目的时候不单单需要创建templates文件夹还需要去配置文件中配置路径
'DIRS':[os.path.join(BASE_DIR,'templates')]
"""

五、主要文件介绍

-mysite项目文件夹
	--mysite文件夹
		---settings.py		配置文件
		---urls.py		    路由与视图函数对应关系(路由层)
		--wsgi.py		    wsgiref模块(不考虑)
	--manage.py			    django的入口文件
	--db.sqlite3 			django自带的sqlite3数据库(小型数据库  功能不是很多还有bug)
	--app01文件夹
		---admin.py			django后台管理
		---apps.py			注册使用
		---migrations文件夹  数据库迁移记录
		---models.py 		数据库相关的  模型类(orm)
		---tests.py			测试文件
		---views.py			视图函数(视图层)

注意:
刚开始学习时可在配置文件中暂时禁用csrf中间件,方便表单提交测试

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',
]

六、django必会三件套

from django.shortcuts import HttpResponse, render, redirect
1.HttpResponse

返回字符串类型的数据

def index(request):
# 业务逻辑代码
return HttpResponse(“OK”)
2.render

返回html文件的

第一种:
def reg(request):
	user_dict = {‘name’:‘jason’,‘password’:‘123’}
	return render(request,‘reg.html’,{‘user_dict’:user_dict})

第二种:
def reg(request):
	user_dict = {‘name’:‘jason’,‘password’:‘123’}
	return render(request,‘reg.html’,locals())		
3.redirect

重定向

def index(request):
    # 业务逻辑代码
    return redirect("/home/")

猜你喜欢

转载自blog.csdn.net/qq_45957580/article/details/109057271