标签:
Python的WEB框架有Django、Tornado、Flask 等多种,Django相较与其他WEB框架其优势为:大而全,框架本身集成了ORM、模型绑定、模板引擎、缓存、Session等诸多功能。Django是一个开放源代码的Web应用框架,由Python写成。采用了MVC的框架模式,即模型M,视图V和控制器C。
层次
|
职责
|
模型(Model),即数据存取层
|
处理与数据相关的所有事务: 如何存取、如何验证有效性、包含哪些行为以及数据之间的关系等。
|
视图(View),即表现层
|
处理与表现相关的决定: 如何在页面或其他类型文档中进行显示。
模型与模板的桥梁。
|
模板(Template),即业务逻辑层
|
存取模型及调取恰当模板的相关逻辑。
|
著名的MVC模式:所谓MVC就是把web应用分为模型(M),控制器(C),视图(V)三层;他们之间以一种插件似的,松耦合的方式连接在一起。
Django的MTV模式本质上与MVC模式没有什么差别,也是各组件之间为了保持松耦合关系,只是定义上有些许不同,Django的MTV分别代表:
Model(模型):负责业务对象与数据库的对象(ORM)
Template(模版):负责如何把页面展示给用户
View(视图):负责业务逻辑,并在适当的时候调用Model和Template
1、每个路由规则对应一个view中的函数
参数说明:
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}),
2、根据app对路由规则进行一次分类
Django的一个url分发器,它的作用是将一个个URL的页面请求分发给不同的view处理,view再调用相应的Model和Template
urlpatterns = [ url(r‘^admin/‘, admin.site.urls), url(r‘^buy/‘,include(‘app.urls‘)), ]
url中别名(相当于当url变化时我们不需要改 from提交的action后面url,会自动帮我们改变)
urlpatterns = [ url(r‘^admin/‘, admin.site.urls), url(r‘^index‘,views.index,name=‘bieming‘), ] ################### def index(req): if req.method==‘POST‘: username=req.POST.get(‘username‘) password=req.POST.get(‘password‘) if username==‘alex‘ and password==‘123‘: return HttpResponse("登陆成功") return render(req,‘index.html‘) ##################### <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Title</title> </head> <body> {# <form action="/index/" method="post">#} <form action="{% url ‘bieming‘ %}" method="post"> 用户名:<input type="text" name="username"> 密码:<input type="password" name="password"> <input type="submit" value="submit"> </form> </body> </html>
1、模版
TEMPLATE_DIRS = ( os.path.join(BASE_DIR,‘templates‘), )
2、静态文件
STATICFILES_DIRS = ( os.path.join(BASE_DIR,‘static‘), )
http请求中产生两个核心对象:
http请求:HttpRequest对象
http响应:HttpResponse对象
所在位置:django.http
1、HttpRequest对象的属性:
path: 请求页面的全路径,不包括域名 method: 请求中使用的HTTP方法的字符串表示。全大写表示。例如 if req.method=="GET": do_something() elseif req.method=="POST": do_something_else() GET: 包含所有HTTP GET参数的类字典对象 POST: 包含所有HTTP POST参数的类字典对象 服务器收到空的POST请求的情况也是可能发生的,也就是说,表单form通过 HTTP POST方法提交请求,但是表单中可能没有数据,因此不能使用 if req.POST来判断是否使用了HTTP POST 方法;应该使用 if req.method=="POST" COOKIES: 包含所有cookies的标准Python字典对象;keys和values都是字符串。 FILES: 包含所有上传文件的类字典对象;FILES中的每一个Key都是<input type="file" name="" />标签中 name属性的值,FILES中的每一个value同时也是一个标准的python字典对象,包含下面三个Keys: filename: 上传文件名,用字符串表示 content_type: 上传文件的Content Type content: 上传文件的原始内容 user: 是一个django.contrib.auth.models.User对象,代表当前登陆的用户。如果访问用户当前 没有登陆,user将被初始化为django.contrib.auth.models.AnonymousUser的实例。你 可以通过user的is_authenticated()方法来辨别用户是否登陆: if req.user.is_authenticated();只有激活Django中的AuthenticationMiddleware 时该属性才可用 session: 唯一可读写的属性,代表当前会话的字典对象;自己有激活Django中的session支持时该属性才可用。
HttpRequest对象的方法:get_full_path(), 比如:http://127.0.0.1:8000/index33/?name=123 ,req.get_full_path()得到的结果就是/index33/?name=123
2、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必须是我们提前生成数据库,否则报错
2、mysql驱动程序
MySQLdb(mysql python)
mysqlclient
MySQL
PyMySQL(纯python的mysql驱动程序)
3、在django的项目中会默认使用sqlite数据库,在settings里有如下设置:
如果我们想要更改数据库,需要修改如下:
DATABASES = { ‘default‘: { ‘ENGINE‘: ‘django.db.backends.mysql‘, ‘NAME‘:‘django_com‘, ‘USER‘:‘root‘, ‘PASSWORD‘:‘‘, } }
注意: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
1、在pycharm上创建mysql图形化数据库步骤:
然后 ,安装MySQL的驱动(driver),这里需要创建一个密码(我的是123)安装成功后
填入数据库的名字,mysql的用户名和密码,然后就可以进行连接了
成功后点击右下角的apply和OK。
这是你就可以看到数据库里的表和内容了:
是不是很方便呢?
如果你用的是sqlite数据库就更简单了,安装完驱动后,直接将sqlite拖动到Database就可以了:
标签:
原文地址:http://www.cnblogs.com/luxiaojun/p/5791498.html