Django(一)
目录纯手撸web框架
1.web框架的本质
连接前端与数据库的中间介质,socket服务端。
2.手写web框架
2.1 编写socket服务端代码
2.2浏览器访问响应无效,记得添加HTTP协议
2.3根据网址后缀的不同获取不同的页面内容
2.4想办法获取到用户输入的后缀,请求数据
2.5请求首行
GET/login HTTP/1.1
GET请求:朝别人索要数据
POST请求:朝别人提交数据
2.6处理请求数据获取网址后缀
# target_url = data.decode('utf8').split(' ')[1]
# 代码实现
import socket
server = socket.socket()
server.bind(('127.0.0.1', 8080))
server.listen(5)
while True:
sock , address = server.accept()
data = sock.recv(1024)
# print(data.decode('utf8'))
sock.send(b'HTTP/1.1 200 ok\r\n\r\n')
target_url = data.decode('utf8').split(' ')[1]
# 按照空格切割,索引取值得到第二个数据,拿到的就是我们输入后台网站的后缀
if target_url == '/index':
sock.send(b'index view')
elif target_url == '/login':
sock.send(b'login view')
elif target_url == '/reg':
sock.send(b'reg view')
else:
sock.send(b'404 error')
代码缺陷:
1.socket代码重复
2.针对请求数据处理繁琐
3.针对不同网址后缀的匹配逻辑low
基于wsgiref模块
wsgiref模块是一个内置模块,是很多web框架底层使用的模块
功能:
1.封装socket代码
2.处理请求数据
from wsgiref.simple_server import make_server
def register(request):
return 'register'
def login(request):
return 'login'
def error(request):
return '404 Not Found'
urls = (
('/login', login),
('/register', register)
)
def run(request, response):
response('200 OK', [])
func_name = None
current_path = request.get('PATH_INFO')
for url_tuple in urls:
if current_path == url_tuple[0]:
func_name = url_tuple[1]
break
if func_name:
res = func_name(request)
else:
res = error(request)
return [res.encode('utf8')]
if __name__ == '__main__':
server = make_server('127.0.0.1', 8080, run)
server.serve_forever()
代码封装优化
# 根据不同的功能拆分成不同的py文件
views.py 存储核心业务逻辑(功能函数)
urls.py 存储网址后缀与函数名对应关系
templates目录 存储html页面文件
# 为了使函数体代码中业务逻辑有更多的数据可用
将request大字典转手传给这个函数(可用不用但是不能没有)
服务端代码
from wsgiref import simple_server
from urls import urls
from views import error
def run(request,response):
response('200 OK',[])
current_path=request.get('PATH_INFO')
func_name=None
for url_tuple in urls:
if current_path==url_tuple[0]:
func_name=url_tuple[1]
break
if func_name:
res=func_name(request)
else:
res=error(request)
return [res.encode('utf8')]
if __name__ == '__main__':
server=simple_server.make_server('127.0.0.1',8080,run)
server.serve_forever()
urls代码
from views import *
urls={
('/register',register),
('/login',login),
('/index',index),
}
view代码
def register(request):
return 'register'
def login(request):
return 'login'
def index(request):
return 'index'
def error(request):
with open(r'template/error.html','r',encoding='utf8')as f:
return f.read()
动静态网页
动态网页
页面数据来源于后端
静态网页
页面数据直接写死
1.访问某个网址后缀,后端代码获取当前时间,并将该时间传到html文件上再返回给浏览器展示给用户看
读取html内容(字符串类型),然后利用字符串替换。最后再返回给浏览器
2.将字典传递给页面内容,并且在页面上还可以通过类似于后端的操作方式操作该数据
模板语法:jinja2模块
jinja2模块
jinja2模块能够让我们在html文件内使用类似于后端的语法来操作各种数据类型
pip3 install jinja2
jinja2模板语法:
{{···}}
{%···%}
# 代码实现:
from jinja2 import Template
def get_dict_func(request):
user_dict = {'name': 'jason', 'age': 18, 'person_list': ['阿珍', '阿强', '阿香', '阿红']}
with open(r'templates/get_dict_page.html', 'r', encoding='utf8') as f:
data = f.read()
temp_obj = Template(data) # 将页面数据交给模板处理
res = temp_obj.render({'d1': user_dict}) # 给页面传了一个 变量名是d1值是字典数据的数据
return res
<p>{{ d1 }}</p>
<p>{{ d1.name }}</p>
<p>{{ d1['age'] }}</p>
<p>{{ d1.get('person_list') }}</p>
前端、后端、数据库三者联动
前端浏览器访问get_user,后端连接数据库查询use表中所有的数据,然后传递到某个HTML页面弄好样式后再发送给浏览器展示。
{% for user_dict in user_data_list %}
<tr>
<td>{{ user_dict.id }}</td>
<td>{{ user_dict.name }}</td>
<td>{{ user_dict.age }}</td>
</tr>
{% endfor %}
python主流web框架
'''
1.django
大而全 自身自带的功能组件非常的多 类似于航空母舰
2.flask
小而精 自身自带的功能组件非常的少 类似于游骑兵
几乎所有的功能都需要依赖于第三方模块
3.tornado
异步非阻塞 速度极快效率极高甚至可以充当游戏服务端
ps:sanic、fastapi...
'''
django简介
1.版本问题
django1.X:同步 1.11
django2.X:同步 2.2
django3.X:支持异步 3.2
django4.X:支持异步 4.2
ps:版本之间的差异其实不大 主要是添加了额外的功能
2.运行django注意事项
1.django项目中所有的文件名目录名不要出现中文
2.计算机名称尽量也不要出现中文
3.一个pycharm尽量就是一个完整的项目(不要嵌套 不要叠加)
4.不同版本的python解释器与不同版本的django可能会出现小问题
django基本使用
1.下载
pip3 install django (默认最新版)
pip install django==版本号 (指定版本)
pip下载模块会自动解决依赖问题(会把关联需要用到的模块一起下了)
2. 验证是否安装成功
django-admin
3. 常见命令
3.1 创建django项目
django-admin startproject 项目名
3.2 启动django项目
cd 项目名
python3.10 manage.py runserver ip:port
4.pycharm自动创建django项目
会自动创建templates文件夹 但是配置文件中可能会报错
os.path.join(BASE_DIR,'templates')
django app
django里面的app 就是某个具体功能的模块
eg:
user app 所有用户相关的都写在user app下
goods app 所有商品相关的都写在goods app下
# 命令行创建应用
python3.10 manage.py startapp 应用名
# pycharm创建应用
新建的django项目可以默认创建一个,并自动注册
# 创建的app一定要去settings.py中注册
INSTALLED_APPS = [
'app01.apps.App01Config',
'app02'
]
django主要目录结构
django项目目录名
# django项目同名目录
settings.py 配置文件
urls.py 存储路由于函数名对应关系(不严谨)
wsgi.py wsgiref网关文件
db.sqlite3文件 django自带的小型数据库(项目启动之后才会出现)
manage.py 入口文件(命令提供)
# 应用目录
migrations目录 存储数据库相关记录
admin.py django内置的admin后台管理功能
apps.py 注册app相关
models.py 与数据库打交道(very import)
test.py 测试文件
view.py 存储功能函数(不严谨)
templates目录 存储html文件(命令行不会自动创建、pycharm可以)
ps:
配置文件中需要配置路径
[os.path.join(BASE_DIR,'templates'),]
网址后缀 路由
函数 视图函数
类 视图类
# 重要名词讲解
urls.py 路由层
views.py 视图层
models.py 模型层
templates 模板层
django小白必会三板斧
from django.shortcuts import render,HttpResponse,redirect
HttpResponse # 返回字符串类型的数据
render # 返回html页面并且支持传值
redirect # 重定向
标签:name,url,Django,py,request,django,server
From: https://www.cnblogs.com/zhiliaowang/p/16967572.html