Django-Views模块详解

http请求中产生的两个核心对象

http请求: HttpRequest http响应: HttpResponse 所在位置 django.http

httpRequest属性:

  HttpRequest.path

    请求页面的全路径,不包含域名---完整的请求路径,不包括域 例: "/music/bands/the_beatles/"。


-  HttpRequest.method
请求中使用的HTTP方法的字符串表示。全大写表示。例如

    if request.method == 'GET':
        do_something()
    elif request.method == 'POST':
        do_something_else()

HttpRequest.GET

    GET请求对象,包含HTTP GET参数的类字典对象,详细查看 QueryDict文档

HttpRequest.POST

    POST请求对象,包含HTTP GET参数的类字典对象,详细查看 QueryDict文档,

    服务器收到空的post请求的情况也是可能发生的,也就是说,表单from通过http post
    方法提交请求,单是表单中可以没有数据。因此,不能使用御酒 if request.POST来判断
    是否使用HTTP POST方法,应该使用if request.method == "POST" (参见本表的method
    属性)。
    注意: POST不包含file-upload(文件上传)信息,请看 FILES

HttpRequest.REQUEST  django 1.8之后被废弃了

    为了方便,该属性是POST和GET属性的集合体,但是有特殊性,先
    找到POST属性,然后在查找GET属性。借鉴PHP`s$_REQUEST。

    例如,如果GET={"name":"john"}和POST={"age":'34'},册 REQUEST['name']
    的值为"jhon",REQUEST["age"]的值是'34'.

    强烈建议使用GET and POST,因为这两个属性更加显示化,写出来的代码更易于
    理解

HttpRequest.COOKIES

    包含所有cookies的标准 python字典对象,keys 和values都是字符串 参见12章 有关于
    cookies更详细的讲解

-  HttpRequest.FILES

    包含所有上传文件的类字典对象。FILES中每个KEY都是<input type="file" name=""/>
    标签中的name属性的值,FILES中每个value同事也是一个标准的python字典对象,包
    含下面三个Keys:
        1. filename 上传文件名,用python字符串表示
        2. content-type 上传文件的Content type
        3. content 上传文件的原始内容
    注意: 只有在请求方法是POST,并且请求页面中<from>有enctype="multipart/frm-data"
    属性时FILES才拥有数据。否则FILES是一个空字典

- HttpRequest.META

    包含所有可用HTTP头部信息的字典。例如:
        1. CONTENT_LENGTH
        2. CONTENT_TYPE
        3. QUERY_STRING:未解析的原始查询字符串
        4. REMOTE_ADDR:客户端主机名
        5. SERVER_NAME:服务器主机名
        6. SERVER_PORT :服务器端口
    META中写着头加上前缀HTTP_ KEY 例如:
        1. HTTP_ACCEPT_ENCODING
        2. HTTP_ACCEPT_LANGUAGE
        3. HTTP_POST 客户发送的HTTP主机头信息
        4. HTTP_REFERER:referring页面
        5. HTTP_USER_AGENT:客户端的user-agent字符串
        6. HTTP_X_BENDER:X-Bender头部信息

- HttpRequest.user

    是from django.contrib.auth.models.User对象,代表当前登录的用户,如果访问用户当前没有
    登录,user将被初始化为from django.contrib.auth.models.AnonymousUser的实例。
    你可以通过user的is_authenticated()方法来辨别用户是否登录
    if request.user.is_authenticated():
         do something for logged-in users
    else:
         do something for anonymous users
    只有激活django中的 A  uthenticationMiddleware时该属性才可用

- HttpRequest.session

    唯一可读写的属性,代表当前回话的字典对象,只有激活django中的
    session支持是该属性才可用

-raw_post_data

    原始HTTP POST数据,未解析过。改机处理时会有用。

- HtppRequest对象的方法部分
    1. get_full_path()
    返回包含查询字符串的请求路径。例如,
    "/music/bands/the_beatles/?print=true"。
    2. QueryDict对象
    get()   如果key对应多个value,get()返回最后一个value。
    在httprequest对象中,GET和POST属性时 django.http.QueryDict类的实例。

HttpResponse

对于Httprequest对象来说 django自动创建,但是 httpresponse对象必须 我们自己创建 每个View方法必须返回一个HTTPResponse对象。 HTTPResponse类在django.http.HttpResponse.render方法包装的也是一个response对象。

构造HtppResponse:

response = HttpResponse("Here's the text of the Web page.")

response = HttpResponse("Text only,please.",mimetype="text/plain")

HtppResponse的子类 部分

  • HttpResponseRedirect

    构造函数接受单个参数:重定向到URL。可以是全URL(e.g.,'http://search.yahoo.com/') 或者相对URL(e.g.,'/seach/').注意折返回HTTP状态码302

  • HttpResponsePermanentRedirect

    同HttpResponseRedirect一样,但它返回永久重定向(HTTP状态代码301)而不是“找到”重定 向(状态代码302)。

  • HttpResponseNotModified

    构造函数不接受任何参数,也不会在此响应中添加任何内容。用于指定自用户最后一次请求 (状态代码304)以来页面尚未被修改。

  • HttpResponseBadRequest

    HttpResponse使用的就是使用400状态码。

  • HttpResponseNotFound

    返回404状态码

  • JsonResponse

    返回Json字符串

详见: https://docs.djangoproject.com/en/1.11/ref/request-response/

  • httpresponse对象上扩展的常用方法

render rander_to_response redirect 跳转的方法 更多详见: https://docs.djangoproject.com/en/1.11/topics/http/shortcuts/

三. 常用的其他方法

locals() 可以直接将函数中所有变量全部传递给模板

 

转载于:https://www.cnblogs.com/richiewlq/p/7721844.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值