1.纯手撸web框架

1.web框架的本质
理解1:连接前端与数据库的中间介质
理解2:socket服务端
2.手写web框架
1.编写socket服务端代码
2.浏览器访问响应无效>>>:HTTP协议
3.根据网址后缀的不同获取不同的页面内容
4.想办法获取到用户输入的后缀>>>:请求数据
5.请求首行
GET /login HTTP/1.1
GET请求
朝别人索要数据
POST请求
朝别人提交数据
6.处理请求数据获取网址后缀
"""
1.socket代码过于重复
2.针对请求数据处理繁琐
3.后缀匹配逻辑过于LowB
"""
import socket server = socket.socket() # TCP UDP
server.bind(('127.0.0.1', 8080)) # IP PORT
server.listen(5) # 半连接池 while True:
sock, address = server.accept() # 等待连接
data = sock.recv(1024) # 字节(bytes)
# print(data.decode('utf8')) # 解码打印
sock.send(b'HTTP/1.1 200 OK\r\n\r\n')
data_str = data.decode('utf8') # 先转换成字符串
target_url = data_str.split(' ')[1] # 按照空格切割字符串并取索引1对应的数据
# print(target_url) # /index /login /reg
if target_url == '/index':
# sock.send(b'index page')
with open(r'myhtml01.html','rb') as f:
sock.send(f.read())
elif target_url == '/login':
sock.send(b'login page')
else:
sock.send(b'home page!')

2.基于wsgiref模块

内置模块 很多web框架底层使用的模块
功能1:封装了socket代码
功能2:处理了请求数据
1.固定代码启动服务端
2.查看处理之后的request大字典
3.根据不同的网址后缀返回不同的内容>>>:研究大字典键值对
4.立刻解决上述纯手撸的两个问题
5.针对最后一个问题代码如何优化 from wsgiref.simple_server import make_server def run(request, response):
"""
:param request: 请求相关数据
:param response: 响应相关数据
:return: 返回给客户端的真实数据
"""
response('200 OK', []) # 固定格式 不用管它
# print(request) 是一个处理之后的大字典
path_info = request.get('PATH_INFO')
if path_info == '/index':
return [b'index']
elif path_info == '/login':
return [b'login']
return [b'hello wsgiref module'] if __name__ == '__main__':
server = make_server('127.0.0.1', 8080, run) # 实时监听127.0.0.1:8080 一旦有请求过来自动给第三个参数加括号并传参数调用
server.serve_forever() # 启动服务端

3.代码封装优化

1.网址后缀的匹配问题
2.每个后缀匹配成功后执行的代码有多有少
面条版 函数版 模块版
3.将分支的代码封装成一个个函数
4.将网址后缀与函数名做对应关系
5.获取网址后缀循环匹配
6.如果想新增功能只需要先写函数再添加一个对应关系即可
7.根据不同的功能拆分成不同的py文件
views.py 存储核心业务逻辑(功能函数)
urls.py 存储网址后缀与函数名对应关系
templates目录 存储html页面文件
8.为了使函数体代码中业务逻辑有更多的数据可用
将request大字典转手传给这个函数(可用不用但是不能没有)

4.动静态网页

动态网页
页面数据来源于后端
静态网页
页面数据直接写死 1.访问某个网址后缀 后端代码获取当前时间 并将该时间传到html文件上再返回给浏览器展示给用户看
读取html内容(字符串类型) 然后利用字符串替换 最后再返回给浏览器 2.将字典传递给页面内容 并且在页面上还可以通过类似于后端的操作方式操作该数据
模板语法>>>:jinja2模块

5.jinja2模块

pip3 install 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>

6.前端、后端、数据库三者联动

1.前端浏览器访问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 %}

7.python主流web框架

"""
作为小白的你 初学阶段不要混着学 很容易走火入魔
"""
1.django:大而全,自身自带的功能组件非常的多,类似于航空母舰。
2.flask
小而精 自身自带的功能组件非常的少 类似于游骑兵
几乎所有的功能都需要依赖于第三方模块
3.tornado
异步非阻塞 速度极快效率极高甚至可以充当游戏服务端
ps:sanic、fastapi...

8.django简介

1.版本问题
django1.X:(17年以前)(同步) 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可能会出现小问题

9.django基本使用

1.下载
pip3 install django 默认最新版
pip3 install django==版本号 指定版本
pip3 install django==2.2.22
pip下载模块会自动解决依赖问题(会把关联需要用到的模块一起下了)
1.1 下载方式1:在pycharm中下载:

1.2在cmd窗口中下载(以2.2.22版本为例):
pip install Django==2.2.22

如果出现上出错误,需要临时换元来解决:
pip install Django==2.2.22 -i https://mirrors.aliyun.com/pypi/simple/ 2.验证:在终端中输入:django-admin,如果提示一下信息说明已经下好。

3.常见命令
1.创建django项目
1.1首先切换到一个文件夹:
1.2在终端输入django-admin startproject 项目名,创建一个django项目,其实就是一个文件夹。此时我们在终端目录下用dir命令查看目录下的文件夹,发现已经有这个目录。

 	2.启动django项目:
2.1首先用cd 项目名 进入到项目目录内(相当于用鼠标双击项目名文件。)
2.2启动Django项目:python manage.py runserver IP:端口号(如果有多个解释器版本需要在python后面添加版本号,python37)。出现以下界面说明项目启动成功。启动成功的同时可以发现在项目名目录中还会自动创建一个db开头的数据库。cmd中能启动Django项目的基础是目录中能找到manage.py文件,如图2。# 8 17 4.pycharm自动创建django项目:
可以发现pycharm会自动创建一个templates,这个文件夹用来保存html文件。

	如果报以下错误说明是配置文件中的问题,需要将settings.py中的'DIRS'改为:[s.path.join(BASE_DIR,'templates'),]

然后当我们运行并且点击pycharm终端提供的地址,可以进入界面: # 14
默认的端口号为8080,如果我们想改可以按照如下操作:

10.django app的概念

"""
Django只是一个空壳,想要添砖加瓦就需要用到app
"""
1.django类似于是一所大学,app类似于大学里面的各个学院(我们之前创建的项目目前只是类似于大学,真正执行任务的还是各个学院)。 2.django里面的app类似于某个具体的功能模块:
user:app 所有用户相关的都写在user app下
goods:app 所有商品相关的都写在goods app下 3.创建应用:、
命令行创建应用:
python38 manage.py startapp 应用名(首先要切换到manage.py文件所在的目录)
pycharm创建应用
方法1:在pycharm中的终端窗口(terminal)中输入python38 manage.py startapp 应用名,创建成功之后应用会在左侧列表中显示:

	方法2:在创建Django文件的时候在创建窗口的More Settings中的Application name中填写应用名,不过该方法只能创建1个应用:

"""
在pycharm中通过终端手动创建的app一定要去settings.py中注册:
INSTALLED_APPS = [
'app01.apps.App01Config', # 全称
'app02' # 只写app名也可以(pycharm会自动提示)
]
"""

11.django主要目录结构

1.django项目同名目录
settings.py:配置文件
urls.py:存储网址后缀与函数名对应关系(不严谨)
wsgi.py:wsgiref网关文件 db.sqlite3文件:django自带的小型数据库(项目启动之后才会出现)
manage.py 入口文件(命令提供)
2.应用目录
migrations目录:存储数据库相关记录
admin.py:django内置的admin后台管理功能
apps.py:注册app相关
models.py:与数据库打交道的(非常重要)
tests.py:测试文件
views.py:存储功能函数(不严谨)
templates目录:存储html文件(命令行不会自动创建 pycharm会)
配置文件中还需要配置路径
[os.path.join(BASE_DIR,'templates'),] """
网址后缀 路由
函数 视图函数
类 视图类
重要名词讲解
urls.py:路由层
views.py:视图层
models.py:模型层
templates:模板层
"""

12.django小白必会三板斧



from django.shortcuts import render,HttpResponse,redirect

1.HttpResponse:返回字符串给网页。
步骤:
1.首先在应用文件中的views中写功能函数(功能函数中的print只能在后端执行打印,打印的内容需要用返回值返回到前端)。 2.在Django文件夹中urlpatterns列表中加入一行path('路由',函数名(需要导模块))
应用目录views中代码:
from django.shortcuts import render,HttpResponse,redirect def index_func(requet):
print('111')
return HttpResponse('index_function') Django目录中urls中代码:
urlpatterns = [
path('admin/', admin.site.urls),
path('index/', views.index_func)
]

2.render:返回html页面并且支持传值。
1.首先在应用文件中的views中写功能函数,功能函数返回值写成return(request,'html文件')。
2.在Django文件夹中urlpatterns列表中加入一行path('路由',函数名(需要导模块))。
应用目录views中代码:
from django.shortcuts import render,HttpResponse,redirect
def login_func(request):
return render(request,'login.html') Django目录中urls中代码:
urlpatterns = [
path('admin/', admin.site.urls),
path('index/', views.index_func),
path('login/', views.login_func)
]

"""
render还有个功能:可以在urls中函数体代码内写入字典,写返回值的时候在render内传入三个参数:render(request,'html文件名','{d1:字典变量名}')。然后再html文件中可以直接用字典变量名点的方式直接拿到字典的值。
views代码:
def login_func(request):
userdict = {'name':'max','age':25,'hobby':'soccer'}
return render(request,'login.html', {'d1':userdict}) html文件:
<body>
<h1>哈哈哈 学Django的第一天 </h1>
<p>{{ d1.name }}</p>
<p>{{ d1.age }}</p>
</body> urls文件:
urlpatterns = [
path('admin/', admin.site.urls),
path('index/', views.index_func),
path('login/', views.login_func)
]
"""


3.redirect:重定向(跳转到指定的页面)。
views代码:
def addr_func(request):
return redirect('https://i.cnblogs.com/posts') urls代码:
urlpatterns = [
path('admin/', admin.site.urls),
path('index/', views.index_func),
path('login/', views.login_func),
path('addr/', views.addr_func)
]

Django-Django基本使用、app、三板斧的更多相关文章

  1. [django]django xlrd处理xls中日期转换问题

    xlrd会把xls文件中比如20160--03-01类型的时间转换成整数,那么我们如何保证xlrd读取进来的时间为2016-03-01格式呢? 使用xlrd中的xldate_as_tuple函数 代码 ...

  2. [django]Django model中数据批量导入bulk_create()

    参考: https://www.cnblogs.com/ccorz/p/Django-model-zhong-shu-ju-pi-liang-dao-rubulkcreat.html import o ...

  3. [Django] Pinax 项目下APP的 安装与使用

    Pinax下有数十个APP,怎么将这些APP集成到已有的Django 工程(http://www.cnblogs.com/xiaoqu/p/3196081.html)文件中去呢?现在用django-u ...

  4. Django --- Django下载和APP创建 ORM (大概步骤)

    1,下载: 命令行: pip install django == 1.11.15 pip install -i或 源 django == 1.11.15 pycharm settings 解释器 点 ...

  5. pyCharm django 中新加app

    1.在manage.py@djangotest中输入命令: 1.startapp   realnameauth   ---新建一个app,名字为realnameauth 2.在 django 项目中的 ...

  6. django 创建视图和APP

    .创建视图views 1.在项目目录下创建views.py文件 2.from django.http import HttpResponse 3.在urls 导入模板: from django.con ...

  7. 学以致用三十-----pycharm创建django项目忘记添加app

    记忆力有时候真的不是很好.因此有些操作步骤还是记录下来好了. pycharm版本-----2018.2.4 创建django项目 file-----newproject----- 创建的时候,appl ...

  8. Django创建项目及app

    主要环境为python3.5,编译环境为pycharm 首先已经安装好Django相关的组件 1.首先创建Django程序: windows系统下pycharm创建步骤: File->New P ...

  9. 02 Django框架基础(APP的创建访问)

    一.创建项目 1.命令:django-admin startproject sitename 2.IDLE环境:本质上都是执行上述命令 常用命令: python manage.py runserver ...

  10. Django学习day5——创建app

    app应用与project项目的区别 一个app实现某个功能,比如博客.公共档案数据库或者简单的投票系统 一个project是配置文件和多个app的集合,这些app组合成整个站点 一个project可 ...

随机推荐

  1. echarts标题(title)配置

    var option = {         //标题         title : {             show:true,//显示策略,默认值true,可选为:true(显示) | fa ...

  2. 2022春每日一题:Day 28

    题目:最大上升子序列和 就是最长上升子序列的改版,贡献由1改为a[i]其他全部不变 代码: #include <cstdio> #include <cstdlib> #incl ...

  3. Go语言核心36讲13

    我们已经讨论过了通道的基本操作以及背后的规则.今天,我再来讲讲通道的高级玩法. 首先来说说单向通道.我们在说"通道"的时候指的都是双向通道,即:既可以发也可以收的通道. 所谓单向通 ...

  4. 7、将字符串数组s2中全部字符复制到字符数组s1中,不用strcpy函数

    /* 将字符串数组s2中全部字符复制到字符数组s1中,不用strcpy函数 */ #include <stdio.h> #include <stdlib.h> void str ...

  5. 带你从入门到精通学习WireShark

    个人名片: 因为云计算成为了监控工程师‍ 个人博客:念舒_C.ying CSDN主页️:念舒_C.ying 带你从入门到精通学习WireShark 一.什么是WireShark? 二.WireShar ...

  6. 【Java并发010】使用层面:发令枪CountDownLatch全解析

    一.前言 CountDownLatch是在java1.5被引入,存在于java.util.cucurrent包中,跟它一起被引入的工具类还有CyclicBarrier.Semaphore.concur ...

  7. CmakeLists简单使用总结

    单文件工程和多级目录工程CmakeLists.txt编写分享 你若发现该帖中有待商榷的地方,还请指正赐教,先行拜谢了! 1 main.c单文件工程CmakeLists.txt 1.1 目录结构 1.2 ...

  8. day33 过滤器filter & 监听器listener & 利用反射创建BaseServlet实现调用自定义业务方法

    Filter过滤器 Fileter可以实现: 1)客户端的请求访问servlet之前拦截这些请求,对用户请求进行预处理 2)对HttpServletResponse进行后处理: 注意 多个Filter ...

  9. 【大数据】kafka-02:Kafka Connect内容、原理及使用

    〇.概述 1.常见资料 (1)confluent https://docs.confluent.io/5.4.0/connect/kafka-connect-jdbc/sink-connector/s ...

  10. 4.11:Storm之WordCount

    〇.概述 1.拓扑结构 2.目标 使用storm进行计数实验. 一.启动服务   在网页中输入:http://localhost:8081可以查看storm的相关信息. 二.kafka操作 终端中输入 ...