这篇主要介绍了Django中urls.py与views.py的配置,HttpRequest对象和HttpResponse对象属性和方法。
路由系统
URL配置(URLconf)就像Django 所支撑网站的目录。它的本质是URL模式以及要为该URL模式调用的视图函数之间的映射表;你就是以这种方式告诉Django,对于不同URL分别调用的代码是什么。
urlpatterns = [ |
参数:
- 一个正则表达式字符串
- 一个可调用对象,通常为一个视图函数或一个指定视图函数路径的字符串
- 可选的要传递给视图函数的默认参数(字典形式)
- 一个可选的name参数
视图函数
views.py中的函数是用来编写与路由系统绑定函数,用于处理hhtp请求。在http请求中两个核心对象:
http请求:HttpRequest对象
http响应:HttpResponse对象
def userinfo(request): |
我们这里用到的参数request就是HttpRequest
检测方法:isinstance(request,HttpRequest)
HttpRequest对象的属性和方法
属性
属性 | 描述 |
---|---|
path | 请求页面的全路径,不包括域名 |
method | 请求中使用的HTTP方法的字符串表示。全大写表示。 |
例子:if req.method == "GET":
do_something()
elseif req.method == "POST":
do_something_else()
服务器收到空的POST请求的情况也是可能发生的,也就是说,表单form通过HTTP POST方法提交请求,但是表单中可能没有数据,因此不能使用if req.POST来判断是否使用了HTTP POST 方法;应该使用 if req.method==”POST”
属性 | 描述 |
---|---|
GET | 包含所有HTTP GET参数的类字典对象 |
POST | 包含所有HTTP 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支持时该属性才可用。 |
方法
方法 | 描述 |
---|---|
get_full_path() | 得到完整路径 |
比如:http://127.0.0.1:8000/index33/?name=123
- req.get_full_path()得到的结果: /index33/?name=123
- req.path得到的结果: /index33
HttpResponse对象
对于HttpRequest对象来说,是由django自动创建的,但是HttpResponse
对象就必须我们自己创建。每个view请求处理方法必须返回一个HttpResponse对象。
HttpResponse类在django.http.HttpResponse
在HttpResponse对象上扩展的常用方法:
方法 | 描述 |
---|---|
页面渲染 | render()(推荐); render_to_response() |
页面跳转 | redirect(“路径”) |
locals() | 可以直接将函数中所有的变量传给模板 |