纯手撸web框架

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

基于wsgiref模块

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

代码封装优化

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

动静态网页

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

jinja2模块

  1. pip3 install jinja2
  2. from jinja2 import Template
  3. def get_dict_func(request):
  4. user_dict = {'name': 'jason', 'age': 18, 'person_list': ['阿珍', '阿强', '阿香', '阿红']}
  5. with open(r'templates/get_dict_page.html', 'r', encoding='utf8') as f:
  6. data = f.read()
  7. temp_obj = Template(data) # 将页面数据交给模板处理
  8. res = temp_obj.render({'d1': user_dict}) # 给页面传了一个 变量名是d1值是字典数据的数据
  9. return res
  10. <p>{{ d1 }}</p>
  11. <p>{{ d1.name }}</p>
  12. <p>{{ d1['age'] }}</p>
  13. <p>{{ d1.get('person_list') }}</p>

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

  1. 1.前端浏览器访问get_user 后端连接数据库查询use表中所有的数据 传递到某个html页面 弄好样式 再发送给浏览器展示
  2. import pymysql
  3. def get_user_func(request):
  4. # 连接数据库操作数据
  5. conn = pymysql.connect(
  6. user='root',
  7. password='222',
  8. host='127.0.0.1',
  9. port=3306,
  10. database='day51',
  11. charset='utf8',
  12. autocommit=True
  13. )
  14. cursor = conn.cursor(cursor=pymysql.cursors.DictCursor)
  15. sql1 = "select * from userinfo;"
  16. cursor.execute(sql1)
  17. user_data = cursor.fetchall() # [{},{},{},{}]
  18. # 读取页面
  19. with open(r'templates/get_user_page.html', 'r', encoding='utf8') as f:
  20. data = f.read()
  21. temp_obj = Template(data) # 将页面数据提交给模板处理
  22. res = temp_obj.render({'user_data_list': user_data})
  23. return res
  24. {% for user_dict in user_data_list %}
  25. <tr>
  26. <td>{{ user_dict.id }}</td>
  27. <td>{{ user_dict.name }}</td>
  28. <td>{{ user_dict.age }}</td>
  29. </tr>
  30. {% endfor %}

python主流web框架

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

django简介

  1. 1.版本问题
  2. django1.X:同步 1.11
  3. django2.X:同步 2.2
  4. django3.X:支持异步 3.2
  5. django4.X:支持异步 4.2
  6. ps:版本之间的差异其实不大 主要是添加了额外的功能
  7. 2.运行django注意事项
  8. 1.django项目中所有的文件名目录名不要出现中文
  9. 2.计算机名称尽量也不要出现中文
  10. 3.一个pycharm尽量就是一个完整的项目(不要嵌套 不要叠加)
  11. 4.不同版本的python解释器与不同版本的django可能会出现小问题

django基本使用

  1. 1.下载
  2. pip3 install django 默认最新版
  3. pip38 install django==版本号 指定版本
  4. pip38 install django==2.2.22
  5. pip下载模块会自动解决依赖问题(会把关联需要用到的模块一起下了)
  6. 2.验证
  7. django-admin
  8. 3.常见命令
  9. 1.创建django项目
  10. django-admin startproject 项目名
  11. 2.启动django项目
  12. cd 项目名
  13. python38 manage.py runserver ip:port
  14. 也可以用pycharmterminal进行命令创建
  15. 或者 tools ctrl+alt+R 进行直接 app名字
  16. 这个是快捷键简写
  17. 4.pycharm自动创建django项目
  18. 会自动创建templates文件夹 但是配置文件中可能会报错
  19. [os.path.join(BASE_DIR,'templates'),]

django app的概念

  1. django类似于是一所大学 app类似于大学里面的各个学院
  2. django里面的app类似于某个具体的功能模块
  3. user app 所有用户相关的都写在user app
  4. goods app 所有商品相关的都写在goods app
  5. 命令行创建应用
  6. python38 manage.py startapp 应用名
  7. pycharm创建应用
  8. 新建django项目可以默认创建一个 并且自动注册
  9. """
  10. 创建的app一定要去settings.py中注册
  11. NSTALLED_APPS = [
  12. 'app01.apps.App01Config']
  13. """

django主要目录结构

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

django小白必会三板斧

  1. from django.shortcuts import render,HttpResponse,redirect
  2. HttpResponse 返回字符串类型的数据
  3. render 返回html页面并且支持传值
  4. 支持点点点点点点点点点点点点点点点点点点
  5. redirect 重定向

python之路45 初识django框架的更多相关文章

  1. 初识Django框架——环境搭建前你需要了解的几点

    Django是一个开放源代码的Web应用框架,由Python写成. 采用了MVC的框架模式,即模型M,视图V和控制器C. 它最初是被开发来用于管理劳伦斯出版集团旗下的一些以新闻内容为主的网站的,即是C ...

  2. 初识django框架

    django框架 1.框架介绍 根据第一部分内容介绍,我们可以总结出一个web框架应该包含如下三部分:a.sockect服务.b.根据不同的url调用不同函数(包含逻辑).c.返回内容(模板渲染).常 ...

  3. 【python之路42】web框架们的具体用法

    Python的WEB框架 (一).Bottle Bottle是一个快速.简洁.轻量级的基于WSIG的微型Web框架,此框架只由一个 .py 文件,除了Python的标准库外,其不依赖任何其他模块. p ...

  4. 【python之路41】web框架

    一.web框架介绍 一共有两种web框架 1.既包含socket又能逻辑处理 tornado框架 2.只能处理逻辑 Django bottle flask  二.web框架的本质 众所周知,对于所有的 ...

  5. 【python接口自动化】初识unittest框架

    本文将介绍单元测试的基础版及使用unittest框架的单元测试. 完成以下需求的代码编写,并实现单元测试 账号正确,密码正确,返回{"msg":"账号密码正确,登录成功& ...

  6. 【python之路45】tornado的用法 (三)

    参考:https://www.cnblogs.com/sunshuhai/articles/6253815.html 一.cookie用法补充 1.cookie的应用场景 浏览器端保存的键值对,每次访 ...

  7. Python之路 day2 初识字典

    #Author:ersa ''' key-value 键值对 字典是无序的,不需要下标,有key 字典的查找.修改.添加.判断.删除 ''' info = { 'stu1101': "Ten ...

  8. python之路-模块初识

    # sys模块 import sys #print (sys.path) #打印环境变量 print (sys.arge) print (sys.arge[2]) # os模块 import os # ...

  9. web框架之初识Django

    目录 一.web框架 1.1什么是web框架 1.2自制的简易web框架 1.3三大主流web框架简介 Django Flask Tornado 1.4动态网页与静态网页 二.初识Django框架 2 ...

  10. 如何用Python做Web开发?——Django环境配置

    用Python做Web开发,Django框架是个非常好的起点.如何从零开始,配置好Django开发环境呢?本文带你一步步无痛上手.     概念 最近有个词儿很流行,叫做“全栈”(full stack ...

随机推荐

  1. uoj349【WC2018】即时战略

    题目链接 WC出了点意外滚粗了,来补补题. \(O(n^2)\)的时间复杂度,\(O(nlogn)\)的询问次数应该还是比较好想的,每次要打通到x的路径,对当前已知的树不断的找重心并询问在重心的哪颗子 ...

  2. Vue学习之--------el与data的两种写法、MVVM模型、数据代理(2022/7/5)

    文章目录 1.el与data的两种写法 1.1.基础知识 1.2.代码实例 1.3.页面效果 2.MVVM模型 2.1. 基础知识 2.2 .代码实例 2.3.页面效果 3.数据代理 3.1. 基础知 ...

  3. GitLab CI/CD 自动化部署入门

    前言:因为找了B站内推,测试开发,正好知道内部使用GitLab做自动化测试,所以简单学了一下,有错误的地方请指正. 入门 初始化 cp: 无法获取'/root/node-v12.9.0-linux-x ...

  4. Redis 01: 非关系型数据库 + 配置Redis

    数据库应用的发展历程 单机数据库时代:一个应用,一个数据库实例 缓存时代:对某些表中的数据访问频繁,则对这些数据设置缓存(此时数据库中总的数据量不是很大) 水平切分时代:将数据库中的表存放到不同数据库 ...

  5. 机器学习实战-AdaBoost

    1.概念 从若学习算法出发,反复学恶习得到一系列弱分类器(又称基本分类器),然后组合这些弱分类器构成一个强分类器.简单说就是假如有一堆数据data,不管是采用逻辑回归还是SVM算法对当前数据集通过分类 ...

  6. Sublime Text怎样自定义配色和主题

    一.自定义配色方案 1 基础知识 配色方案[Color Scheme]文件保存在以下路径[ST安装目录]: "D:\Program Files\Sublime Text\Packages\C ...

  7. ubuntu下Mysql安装与root密码重置

    一.安装 1.首先更新本地存储库索引,执行sudo apt update 2.从APT存储库安装MySQL,执行sudo apt install MySQL-server,在安装过程中,可能会出现[Y ...

  8. SpringBoot 解决跨域问题代码

    package com.example.demo.gs; import org.springframework.context.annotation.Configuration; import jav ...

  9. scrapy传递 item时的 数据不匹配 和一些注意事项

    item 在传递数据时需要拷贝内存地址 yield scrapy.Request( url=title_url, callback=self.parse_detail, # 用深拷贝的方式 复制子对象 ...

  10. BlockingQueue家族成员一览

    最近在复习多线程的知识,必然少不了要扫描一遍JUC包下的各个类或接口,今天就先来聊一聊阻塞队列BlockingQueue: BlockingQueue是jdk1.5发布的JUC包下的一个工具类,他提供 ...