首页 > 其他分享 >web框架、django基本使用

web框架、django基本使用

时间:2022-12-08 19:36:15浏览次数:36  
标签:web 框架 后缀 py django user 模块

今日内容总结

web框架

web框架的本质

	理解1:连接前端与数据库的中间介质
	理解2:socket服务端

手写web框架

	1.编写socket服务端代码
	2.浏览器访问响应无效>>>:HTTP协议
 	3.根据网址后缀的不同获取不同的页面内容
 	4.针对用户输入不同的路由而进行不同的操作>>>:请求数据
 	5.请求首行
    	GET请求	朝别人索要请求
     	POST请求	朝别人提交数据
    6.处理请求数据获取网络后缀

wsgiref模块

在写web框架以及客服端等之类的编写时 需要反复写socket模块的那几行代码 便有了wsgiref模块
# wsgiref模块是一个内置模块 是大多数web框架底层使用的代码
	功能1:封装了socket代码
 	功能2:处理了请求数据
        
#使用
1.固定代码启动服务端
2.查看处理之后的request大字典
3.根据不同的网址后缀返回不同的内容>>>:研究大字典的键值对
4.处理了手写web中socket代码太过于重复 以及数据的处理问题
5.针对最后一个问题代码如何优化

代码封装优化

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

动静态网页

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

jinja2模块

jinja2是外部模块
#代码实操:
pip3 install jinja2    #  下载模块


from jinja2 import Template 


def get_dict_func(request):
    user_dict = {'name': 'xiaochen', 'age': 19, '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>
#可以通过字典的内置方法来操作字典的数据 jinja2是最贴近python的

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

前端浏览器范文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
	异步非阻塞 速度极快 效率也极高 甚至可以充当游戏的服务端
    

django简介

1.版本问题
		django1.X:同步		1.11
		django2.X:同步		2.2
 		django3.X:支持异步    3.2
 		django4.X:支持异步	   4.2
	ps:版本之间的差异其实不大 主要是添加了额外的功能
#不同python解释器针对不同版本的django是需要注意的
Django版本 python版本
2.2 3.5、3.6、3.7、3.8(在2.2.8中添加)、3.9(2.2.17)中添加
3.1 3.6、3.7、3.8、3.9(在3.1.3中添加)
3.2 3.6、3.7、3.7、3.9、3.10(在3.2.9中添加)
4.0、4.1 3.8、3.9、3.10
2.运行django注意事项
	django的项目命名中不要出现中文式命名
	计算机的名称也尽量别输入中文

django基本使用

1.下载
	pip install django		  # 下载最新版
 	pip	install	django==版本号	# 下载指定版
  pip下载模块会自动解决依赖问题(会把关联需要用到的模块一起下了)
2.验证
	django-admin
3.常见命令
	创建django项目
    	django-admin startproject 项目名
     启动django项目
    	cd 项目名
     	python mange.py runserver ip:port
4.pycharm自动创建django项目
	会自动创建templates文件夹 但是配置文件中可能会报错
    	#[os.path.join(BACE_DIR,'templates'),]

django app的概念

django里面的app类似于某个具体的功能模块

django里面的app类似于某个具体的功能模块
	user	app 所有用户相关的都写在user app下
 	goods	app 所有商品相关的都写在goods app下
  
命名行创建应用
	python manage.py startapp 应用名
pycharm创建应用
	新建django项目可以默认创建一个 并且自动注册
'''
创建的app以及手动写入的templates都需要去注册 不然无法识别使用
INSTALLED_APPS = [
    	'app01.apps.App01Config',
		'app02'
	]
'''

django主要目录结构

#django项目目录名
	1.djangpo项目同名目录
    	settings.py		配置文件
    	urls.py		    存储网址后缀与函数名对应关系(不严谨)
        wsgi.py			wsgiref网关文件
    2.db.sqlite3文件	   django自带的数据库(项目启动才有)
  	3.manage.py		文件入口(命名提供)
    4.应用目录
    	migrations目录	存储数据库相关记录
     	admin.py		 django内置的admin后台管理功能
     	apps.py			 注册app相关
     	models.py		 与数据库打交道的
    	tests.py		 测试文件
      	views.py		 存储功能函数
    5.templates目录		存储html文件(命名行不会自动创建)
    	#记得先配置路径

  	一些相关名词
        '''
       	网络后缀			路由
       	函数			视图函数
       	类			视图类
       	
       	urls.py				路由层
       	views.py			视图层
       	models.py			模型层
       	templates			模板层
        '''

django的三板斧

from django.shortcuts import render,HttpResponse,redirect

HttpResponse		返回字符串类型的数据

render				返回html页面并且支持传数值

redirect			重定向

标签:web,框架,后缀,py,django,user,模块
From: https://www.cnblogs.com/xiaochenxiangchangpang/p/16967057.html

相关文章

  • django框架之基础学习
    目录纯手撸web框架基于wsgiref模块代码封装优化动静态网页jinja模板前端、后端、数据库三者联动python主流web框架Django简介Django基本使用djangoapp的概念django的主要......
  • (26)C#WebService
     一、创建webservice vs2008创建 vs2019创建选择  添加项目选择    二、发布webservice1.正式发布(1)配置IIS自己在局域网用的话,只需1,2,3三步1:网站的名称,将来IIS里......
  • 手撸web框架
    手撸web框架web框架是前端与数据库的中介。在我们所常见的web中,一般情况下,一个应用不会只有一个首页界面,当顶级域名后有其他后缀时,会有其他的web界面,也就是将我们的网页......
  • Web前端面试真题(算法篇):001篇
    OverridetheentrypointofanimageIntroducedinGitLabandGitLabRunner9.4.Readmoreaboutthe extendedconfigurationoptions.Beforeexplainingtheav......
  • webapi CORS origin
    dotnetcore6.0reference:https://learn.microsoft.com/zh-cn/aspnet/core/security/cors?view=aspnetcore-6.0test: https://learn.microsoft.com/zh-cn/aspnet/core......
  • 解一个webpack打包后加密的JS代码
    源码过长,只贴部分加密的源代码如下0x1fc9:function(_0x2715a2,_0x5a118b,_0x344094){const_0x23ae3e=_0x344094(`611c`);class_0x2e9b72{......
  • 基于Qt的桌面客户端组件化框架DT 开源啦
    这个是本人在工作中基于QT开发的组件化桌面开发框架,目前打算开源出来提供给大家,节省大家的开发时间和效率,希望对大家的开发有所帮助,也欢迎提出意见和改进建议1.为什么开源D......
  • django三板斧
    今日内容概要纯手撸web框架基于wsgiref模块代码封装优化动静态网页jinja2模板语法python主流web框架django框架简介django基本操作命令django小白必会三板斧今......
  • Java web区分两个按钮
    在.jsp文件中有时候会出现两个按钮的情况在最开始的时候是打算通过两个hidden对两个按钮进行区分于是我写了这样的语句  然而事实却是,这样的语句无法分辨提交的......
  • Vue项目打包后css中的-webkit-line-clamp这个属性失效
    .htcon{margin-top:5px;font-size:13px;word-break:break-all;text-overflow:ellipsis;display:-webkit-box;-webkit-b......