目录
我们可以这样理解:所有的Web应用本质上就是一个socket服务端,而用户的浏览器就是一个socket客户端。 这样我们就可以自己实现Web框架了。
对于真实开发中的python web程序来说,一般会分为两部分:服务器程序和应用程序。
服务器程序负责对socket服务器进行封装,并在请求到来时,对请求的各种数据进行整理。
应用程序则负责具体的逻辑处理。为了方便应用程序的开发,就出现了众多的Web框架,例如:Django、Flask、web.py 等。不同的框架有不同的开发方式,但是无论如何,开发出的应用程序都要和服务器程序配合,才能为用户提供服务。
这样,服务器程序就需要为不同的框架提供不同的支持。这样混乱的局面无论对于服务器还是框架,都是不好的。对服务器来说,需要支持各种不同框架,对框架来说,只有支持它的服务器才能被开发出的应用使用。
这时候,标准化就变得尤为重要。我们可以设立一个标准,只要服务器程序支持这个标准,框架也支持这个标准,那么他们就可以配合使用。一旦标准确定,双方各自实现。这样,服务器可以支持更多支持标准的框架,框架也可以使用更多支持标准的服务器。
WSGI(Web Server Gateway Interface)就是一种规范,它定义了使用Python编写的web应用程序与web服务器程序之间的接口格式,实现web应用程序与web服务器程序间的解耦。
常用的WSGI服务器有uwsgi、Gunicorn。而Python标准库提供的独立WSGI服务器叫wsgiref,Django开发环境用的就是这个模块来做服务器。
大型框架,自带的组件和功能非常多;不足之处就是写小项目时,可能会很笨重
小而精 短小精悍 自带的组件和功能特别特别少 ,基本全部依赖于第三方组件
不足之处: 受限于第三方模块的影响比较大
如果将flask所有第三方模块加起来 能够直接盖过django
特点:异步非阻塞 这个框架甚至可以用来开发游戏服务器
socket、路由匹配、模板语法都是自己写的
pip install django==1.11.11
django-admin
,有返回结果说明安装成功django-admin startproject 项目名(如mysite)
python manager.py runserver
,或者指定ip和端口:python manager.py runserver 127.0.0.1:8000
,默认启动在本地8000端口python manager.py startapp app01
django是一个以开发app为只要功能的web框架,app就是application应用的意思
一个django项目就相当于一所大学,而一个个app相当于大学里的学院。
而 一个空的django项目本身没有任何作用,仅仅为app提供前期的环境配置,app才是一个个具体的功能,每个app都有自己独立的功能。
注意:创建好的app需要在django配置文件中注册方可生效:
# 在配置文件settings.py中配置
INSTALLED_APPS = [
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
'app01', # 简易写法
'app01.apps.App01Config' # 完整写法
]
命令行传创建项目注意:
‘DIRS‘: [os.path.join(BASE_DIR, ‘templates‘)]
Tools >>> run manage.py task
这样就会生成一个专门敲django命令的窗口
注意:
‘DIRS‘: [os.path.join(BASE_DIR, ‘templates‘)]
mysite/
├── manage.py # django的入口文件
├── templates # 模板文件夹,存放html文件
├── db.splite3 # django自带的数据库文件
└── mysite # 项目目录
├── __init__.py
├── settings.py # 暴露给用户可以配置的配置文件
├── urls.py # 路由 --> URL和函数的对应关系
└── wsgi.py # runserver命令就使用wsgiref模块做简单的web server
├── app01 # 应用文件夹名
├── migrations文件夹 # 所有数据库相关的操作记录
├── __init__.py
├── admin.py # django admin后台管理
├── apps.py # 注册qpp使用
├── models.py # 放数据库相关的模型类
├── tests.py # 测试文件
├── views.py # 处理业务逻辑的视图函数
主要操作views.py和urls.py
内部传入一个字符串参数,返回给浏览器
from django.shortcuts import render, HttpResponse, redirect
def index(request):
return HttpResponse('有点意思')
render可以返回html文件,可以给html页面传值
def login(request):
user_dic = {'username': 'neo', 'password': '123'}
return render(request, 'login.html', {'user_dic':user_dic})
重定向,接受一个URL参数,表示跳转指定的URL。
可以是后缀名,也可以是全路径
def home(request):
return redirect('/index')
# return redirect('https://coding.net/')
原文:https://www.cnblogs.com/setcreed/p/11908575.html