广州市住房和建设局网站,wordpress修改密码后还是登陆不了,室内环保网站模板代码,wordpress 站长主题一、视图函数 一个视图函数#xff0c;简称视图#xff0c;是一个简单的python函数#xff0c;它接受Web请求并且返回Web响应。响应可以是一张网页的HTML内容#xff0c;一个重定向#xff0c;一个404错误#xff0c;一个XML文档#xff0c;或者一张图片...是任何东西都…一、视图函数 一个视图函数简称视图是一个简单的python函数它接受Web请求并且返回Web响应。响应可以是一张网页的HTML内容一个重定向一个404错误一个XML文档或者一张图片...是任何东西都可以。无论视图本身包含什么逻辑都要返回响应。代码写在哪里也无所谓只要它在你的python目录下面。除此之外没有更多的要求了--可以说“没有什么神奇的地方”。为了将代码放在某处约定是将视图放置在项目或应用程序目录中的名为views.py的文件中。 下面是一个返回当前日期和时间作为HTML文档的视图 from django.shortcuts import render, HttpResponse, HttpResponseRedirect, redirect
import datetime# Create your views here.def current_datetime(request):now datetime.datetime.now()html htmlbodyIt is now %s./body/html % nowreturn HttpResponse(html) 让我们逐行阅读上面的代码 首先我们从django.shortcuts模块导入了HttpResponse类以及python的datetime库。接着我们定义了current_datetime函数。它就是视图函数。每个视图函数都使用HttRequest对象作为第一个参数并且通常称之为request。 注意视图函数的名称并不重要不需要用一个统一的命名方式来命名以便让Django识别它。我们将其命名为current_datetime是因为这个名称能够精确地反映出它的功能。 这个视图会返回一个HttpResponse对象其中包含生成的响应。每个视图函数都负责返回一个HttpResponse对象。 视图层熟练掌握两个对象即可请求对象(request)和响应对象(HttpResponse) 二、HttpRequest对象 2.1 request属性 django将请求报文中的请求行、首部信息、内容主体封装成HttpRequest类中的属性。除了特殊说明的之外其他均为只读的。 /*1.HttpRequest.GET一个类似于字典的对象包含 HTTP GET 的所有参数。详情请参考 QueryDict 对象。2.HttpRequest.POST一个类似于字典的对象如果请求中包含表单数据则将这些数据封装成 QueryDict 对象。POST 请求可以带有空的 POST 字典 —— 如果通过 HTTP POST 方法发送一个表单但是表单中没有任何的数据QueryDict 对象依然会被创建。因此不应该使用 if request.POST 来检查使用的是否是POST 方法应该使用 if request.method POST另外如果使用 POST 上传文件的话文件信息将包含在 FILES 属性中。注意键值对的值是多个的时候,比如checkbox类型的input标签select标签需要用request.POST.getlist(hobby)3.HttpRequest.body一个字符串代表请求报文的主体。在处理非 HTTP 形式的报文时非常有用例如二进制图片、XML,Json等。但是如果要处理表单数据的时候推荐还是使用 HttpRequest.POST 。4.HttpRequest.path一个字符串表示请求的路径组件不含域名。例如/music/bands/the_beatles/5.HttpRequest.method一个字符串表示请求使用的HTTP 方法。必须使用大写。例如GET、POST6.HttpRequest.encoding一个字符串表示提交的数据的编码方式如果为 None 则表示使用 DEFAULT_CHARSET 的设置默认为 utf-8。这个属性是可写的你可以修改它来修改访问表单数据使用的编码。接下来对属性的任何访问例如从 GET 或 POST 中读取数据将使用新的 encoding 值。如果你知道表单数据的编码不是 DEFAULT_CHARSET 则使用它。7.HttpRequest.META一个标准的Python 字典包含所有的HTTP 首部。具体的头部信息取决于客户端和服务器下面是一些示例CONTENT_LENGTH —— 请求的正文的长度是一个字符串。CONTENT_TYPE —— 请求的正文的MIME 类型。HTTP_ACCEPT —— 响应可接收的Content-Type。HTTP_ACCEPT_ENCODING —— 响应可接收的编码。HTTP_ACCEPT_LANGUAGE —— 响应可接收的语言。HTTP_HOST —— 客服端发送的HTTP Host 头部。HTTP_REFERER —— Referring 页面。HTTP_USER_AGENT —— 客户端的user-agent 字符串。QUERY_STRING —— 单个字符串形式的查询字符串未解析过的形式。REMOTE_ADDR —— 客户端的IP 地址。REMOTE_HOST —— 客户端的主机名。REMOTE_USER —— 服务器认证后的用户。REQUEST_METHOD —— 一个字符串例如GET 或POST。SERVER_NAME —— 服务器的主机名。SERVER_PORT —— 服务器的端口是一个字符串。从上面可以看到除 CONTENT_LENGTH 和 CONTENT_TYPE 之外请求中的任何 HTTP 首部转换为 META 的键时都会将所有字母大写并将连接符替换为下划线最后加上 HTTP_ 前缀。所以一个叫做 X-Bender 的头部将转换成 META 中的 HTTP_X_BENDER 键。8.HttpRequest.FILES一个类似于字典的对象包含所有的上传文件信息。FILES 中的每个键为input typefile name / 中的name值则为对应的数据。注意FILES 只有在请求的方法为POST 且提交的form 带有enctypemultipart/form-data 的情况下才会包含数据。否则FILES 将为一个空的类似于字典的对象。9.HttpRequest.COOKIES一个标准的Python 字典包含所有的cookie。键和值都为字符串。10.HttpRequest.session一个既可读又可写的类似于字典的对象表示当前的会话。只有当Django 启用会话的支持时才可用。完整的细节参见会话的文档。11.HttpRequest.user(用户认证组件下使用)一个 AUTH_USER_MODEL 类型的对象表示当前登录的用户。如果用户当前没有登录user 将设置为 django.contrib.auth.models.AnonymousUser 的一个实例。你可以通过 is_authenticated() 区分它们。例如if request.user.is_authenticated():# Do something for logged-in users.else:# Do something for anonymous users.user 只有当Django 启用 AuthenticationMiddleware 中间件时才可用。-------------------------------------------------------------------------------------匿名用户class models.AnonymousUserdjango.contrib.auth.models.AnonymousUser 类实现了django.contrib.auth.models.User 接口但具有下面几个不同点id 永远为None。username 永远为空字符串。get_username() 永远返回空字符串。is_staff 和 is_superuser 永远为False。is_active 永远为 False。groups 和 user_permissions 永远为空。is_anonymous() 返回True 而不是False。is_authenticated() 返回False 而不是True。set_password()、check_password()、save() 和delete() 引发 NotImplementedError。New in Django 1.8:新增 AnonymousUser.get_username() 以更好地模拟 django.contrib.auth.models.User。*/2.2 request常用方法 /*1.HttpRequest.get_full_path()返回 path如果可以将加上查询字符串。例如/music/bands/the_beatles/?printtrue2.HttpRequest.is_ajax()如果请求是通过XMLHttpRequest 发起的则返回True方法是检查 HTTP_X_REQUESTED_WITH 相应的首部是否是字符串XMLHttpRequest。大部分现代的 JavaScript 库都会发送这个头部。如果你编写自己的 XMLHttpRequest 调用在浏览器端你必须手工设置这个值来让 is_ajax() 可以工作。如果一个响应需要根据请求是否是通过AJAX 发起的并且你正在使用某种形式的缓存例如Django 的 cache middleware你应该使用 vary_on_headers(HTTP_X_REQUESTED_WITH) 装饰你的视图以让响应能够正确地缓存。*/ 三、HttpResponse对象 响应对象主要有三种形式 HttpResponse()render()redirect()HttpResponse()括号内直接跟一个具体的字符串作为响应体比较直接很简单所以这里主要介绍后面两种心事。 3.1 render() render(request,template_name,context)结合一个给定的模板和一个给定的上下文字典并返回一个渲染后的HttpResponse对象。 参数 request用于生成响应的请求对象。 template_name要使用的模板的完整名称可选的参数 context添加到模板上下文的一个字典。默认是一个空字典。如果字典中的某个值是可调用的视图将在渲染模板之前调用它。 render方法就是将一个模板页面中的模板语法进行渲染最终渲染成一个html页面作为响应体。 3.2 redirect() 传递要重定向的一个硬编码的URL def my_view(request):...return redirect(/some/url/) 也可以是一个完整的URL: def my_view(request):...return redirect(http://example.com) key两次请求 1301和302的区别。301和302状态码都表示重定向就是说浏览器在拿到服务器返回的这个状态码后会自动跳转到一个新的URL地址这个地址可以从响应的Location首部中获取用户看到的效果就是他输入的地址A瞬间变成了另一个地址B——这是它们的共同点。他们的不同在于。301表示旧地址A的资源已经被永久地移除了这个资源不可访问了搜索引擎在抓取新内容的同时也将旧的网址交换为重定向之后的网址302表示旧地址A的资源还在仍然可以访问这个重定向只是临时地从旧地址A跳转到地址B搜索引擎会抓取新的内容而保存旧的网址。 SEO302好于3012重定向原因
1网站调整如改变网页目录结构
2网页被移到一个新地址
3网页扩展名改变(如应用需要把.php改成.Html或.shtml)。这种情况下如果不做重定向则用户收藏夹或搜索引擎数据库中旧地址只能让访问客户得到一个404页面错误信息访问流量白白丧失再者某些注册了多个域名的网站也需要通过重定向让访问这些域名的用户自动跳转到主站点等。用redirect可以解释APPEND_SLASH的用法 转载于:https://www.cnblogs.com/Black-rainbow/p/9224310.html