Python的WEB框架有Django、Tornado、Flask 等多种,Django相较与其余WEB框架其优点为:大而全,框架自己集成了ORM、模型绑定、模板引擎、缓存、Session等诸多功能。Django是一个开放源代码的Web应用框架,由Python写成。采用了MVC的框架模式,即模型M,视图V和控制器C。html
层次 | 职责 |
模型(Model),即数据存取层 | 处理与数据相关的全部事务: 如何存取、如何验证有效性、包含哪些行为以及数据之间的关系等。 |
视图(View),即表现层 |
处理与表现相关的决定: 如何在页面或其余类型文档中进行显示。
模型与模板的桥梁。
|
模板(Template),即业务逻辑层 |
存取模型及调取恰当模板的相关逻辑。
|
著名的MVC模式:所谓MVC就是把web应用分为模型(M),控制器(C),视图(V)三层;他们之间以一种插件似的,松耦合的方式链接在一块儿。python
Django的MTV模式本质上与MVC模式没有什么差异,也是各组件之间为了保持松耦合关系,只是定义上有些许不一样,Django的MTV分别表明:mysql
Model(模型):负责业务对象与数据库的对象(ORM)web
Template(模版):负责如何把页面展现给用户正则表达式
View(视图):负责业务逻辑,并在适当的时候调用Model和Templatesql
一、每一个路由规则对应一个view中的函数数据库
参数说明:django
url(r'^index/(\d*)', views.index), url(r'^articles/([0-9]{4})/$', views.year_archive), url(r'^manage/(?P<name>\w*)/(?P<id>\d*)', views.manage), url(r'^manage/(?P<name>\w*)', views.manage,{'id':333}),
二、根据app对路由规则进行一次分类缓存
Django的一个url分发器,它的做用是将一个个URL的页面请求分发给不一样的view处理,view再调用相应的Model和Templateoracle
urlpatterns = [ url(r'^admin/', admin.site.urls), url(r'^buy/',include('app.urls')), ]
url中别名(至关于当url变化时咱们不须要改 from提交的action后面url,会自动帮咱们改变)
1、建立django程序
其余经常使用命令:
python manage.py runserver 0.0.0.0 python manage.py startapp appname python manage.py syncdb python manage.py makemigrations python manage.py migrate python manage.py createsuperuser
2、模版
TEMPLATE_DIRS = ( os.path.join(BASE_DIR,'templates'), )
3、静态文件
STATICFILES_DIRS = ( os.path.join(BASE_DIR,'static'), )
http请求中产生两个核心对象:
http请求:HttpRequest对象
http响应:HttpResponse对象
所在位置:django.http
一、HttpRequest对象的属性:
HttpRequest对象的方法:get_full_path(), 好比:http://127.0.0.1:8000/index33/?name=123 ,req.get_full_path()获得的结果就是/index33/?name=123
二、HttpResponse对象:
在HttpResponse对象上扩展的经常使用方法:页面渲染:render,render_to_response,
页面跳转:redirect
locals: 能够直接将函数中全部的变量传给模板
return HttpResponse('ASD') return render_to_response('admin.html') return render(request,'admin.html') return redirect('/choutiadmin/login')
1、 数据库配置
一、django默认支持sqlite,mysql, oracle,postgresql数据库。
<1> sqlite
django默认使用sqlite的数据库,默认自带sqlite的数据库驱动
引擎名称:django.db.backends.sqlite3
<2>mysql
引擎名称:django.db.backends.mysql
sqlite和mysql的区别是,建立表时sqlite无需提早建立表,而mysql必须是咱们提早生成数据库,不然报错
二、mysql驱动程序
MySQLdb(mysql python)
mysqlclient
MySQL
PyMySQL(纯python的mysql驱动程序)
三、在django的项目中会默认使用sqlite数据库,在settings里有以下设置:
若是咱们想要更改数据库,须要修改以下:
注意:NAME即数据库的名字,在mysql链接前该数据库必须已经建立,而上面的sqlite数据库下的db.sqlite3则是项目自动建立
USER和PASSWORD分别是数据库的用户名和密码。
设置完后,再启动咱们的Django项目前,咱们须要激活咱们的mysql。
而后,启动项目,会报错:no module named MySQLdb
这是由于django默认你导入的驱动是MySQLdb,但是MySQLdb对于py3有很大问题,因此咱们须要的驱动是PyMySQL
因此,咱们只须要找到项目名文件下的__init__,在里面写入:
import pymysql
pymysql.install_as_MySQLdb()
下图的执行步骤会建立数据库,具体建立那种数据库仍是要看你的设置
为了更好的查询修改数据库,咱们能够不使用Navicate,而是利用pycharm的Database
一、在pycharm上建立mysql图形化数据库步骤:
而后 ,安装MySQL的驱动(driver),这里须要建立一个密码(个人是123)安装成功后
填入数据库的名字,mysql的用户名和密码,而后就能够进行链接了
成功后点击右下角的apply和OK。
这是你就能够看到数据库里的表和内容了:
是否是很方便呢?
若是你用的是sqlite数据库就更简单了,安装完驱动后,直接将sqlite拖动到Database就能够了: