Django---U福特ExplorerL、Views

作者: 网络编程  发布:2019-09-05

1、Django URL(路由系统)

     URL配置(URLconf)就像Django 所支撑网站的目录。它的本质是URL模式以及要为该URL模式调用的视图函数之间的映射表;你就是以这种方式告诉Django,对于这个URL调用这段代码,对于那个URL调用那段代码。

1 urlpatterns = [
2     url(正则表达式, views视图函数,参数,别名),
3 ]

参数说明:

  • 一个正则表达式字符串
  • 一个可调用对象,通常为一个视图函数或一个指定视图函数路径的字符串
  • 可选的要传递给视图函数的默认参数(字典形式)
  • 一个可选的name参数

示例:

 1 from django.conf.urls import url
 2 from django.contrib import admin
 3 
 4 from app01 import views
 5 
 6 urlpatterns = [
 7 
 8     url(r'^articles/2003/$', views.special_case_2003),
 9 
10     #url(r'^articles/[0-9]{4}/$', views.year_archive),
11 
12     url(r'^articles/([0-9]{4})/$', views.year_archive),  #no_named group
13 
14     url(r'^articles/([0-9]{4})/([0-9]{2})/$', views.month_archive),
15 
16     url(r'^articles/([0-9]{4})/([0-9]{2})/([0-9] )/$', views.article_detail),
17 
18 ]

 1 from django.conf.urls import url
 2   
 3 from . import views
 4   
 5 urlpatterns = [
 6     url(r'^articles/2003/$', views.special_case_2003),
 7     url(r'^articles/(?P<year>[0-9]{4})/$', views.year_archive),
 8     url(r'^articles/(?P<year>[0-9]{4})/(?P<month>[0-9]{2})/$', views.month_archive),
 9     url(r'^articles/(?P<year>[0-9]{4})/(?P<month>[0-9]{2})/(?P<day>[0-9]{2})/$', views.article_detail),
10 ]

Django URL(路由系统)

RL配置(URLconf)就像Django 所支撑网站的目录。它的本质是URL模式以及要为该URL模式调用的视图函数之间的映射表;你就是以这种方式告诉Django,对于这个URL调用这段代码,对于那个URL调用那段代码。

1 urlpatterns = [
2     url(正则表达式, views视图函数,参数,别名),
3 ]

 

参数说明:

  • 一个正则表达式字符串
  • 一个可调用对象,通常为一个视图函数或一个指定视图函数路径的字符串
  • 可选的要传递给视图函数的默认参数(字典形式)
  • 一个可选的name参数

一、url无名分组之 url参数一

1、  url路由有优先级的

2、  在正则表达式中如果加上括号就是分组了,分组就是一个对象了,就需要一个变量来接收这个对象,这里就是接收写入的url

views文件视图函数

图片 1图片 2

def special_case_2003(req):
    return HttpResponse("2003")
def month_archive(req,y,m):
    return HttpResponse(y "year" m "mouth")

View Code

 

urls路由系统无名分组

图片 3图片 4

from django.conf.urls import url
from django.contrib import admin
from app01 import  views
urlpatterns = [
    url(r'^admin/', admin.site.urls),
    url(r"^cur_time/",views.cur_time),
    url(r"^userInfo/",views.userInfo),
1、#这个用户连接http://127.0.0.1:8000/articles/2003/ 就能够显示视图函数的内容
    url(r'^articles/2003/$', views.special_case_2003),
    2、# http://127.0.0.1:8000/articles/正则匹配的/正则匹配的/  就能够显示视图函数
    url(r'^articles/([0-9]{4})/([0-9]{2})/$', views.month_archive),
]

View Code

 

1、上面用户连接1这个链接,这个是绝对匹配,就会经过视图函数返回2003

2、中的url由于分了两个组,也就相当于对象,所以要在视图函数中用变量来接收这个对象,并且在url中匹配。这里返回给用户输入的连接加上year和mouth

二、url有名分组之 url参数二

The above example used simple, non-named regular-expression groups (via parenthesis) to capture bits of the URL and pass them as positional arguments to a view. In more advanced usage, it’s possible to use named regular-expression groups to capture URL bits and pass them as keyword arguments to a view.

       In Python regular expressions, the syntax for named regular-expression groups is (?P<name>pattern), where name is the name of the group and pattern is some pattern to match.

Here’s the above example URLconf, rewritten to use named groups:

简单说明补充:

re=re.search(‘(?P<id>d{3})/(?P<name>w{3})’,’wwee32tt123/ooo’ )

(?P<id>d{3}  这里就是把这个组命名为id

?P<name>w{3} 这里就是把这个组命名为name

print(re.group())   #123/ooo

print(re.goup(id))   #123

在urls中写入:

图片 5图片 6

url(r"^articles/(?P<year>[0-9]{4})/(?P<mouth>[0-9]{2})/$",views.mouth)

View Code

 

然后在views中写入视图函数:

图片 7图片 8

def mouth(req,year,mouth):
    return HttpResponse(year "year" mouth "mouth")

View Code

 

这里的year就是匹配的urls中的路径,mouth就是前面url中的路径,这里的year和mouth必须要和urls中的对应

访问

就能在前端出现  2003year43mouth

其实就是把url参数一的对象命名了而已

三、url参数三、

一、在urls中添加第三个参数

url(r"^index",views.index,{"name":"pyrene"})

然后在views中写上视图函数

def index(req,name):
    return HttpResponse(name)

 

注意:

这里的视图函数中必须把urls中的第三个参数的key传入到这里面,并且要和urls中的key的名字一模一样

然后访问index页面就会返回给浏览器pyrene

二、如果在urls中的第三个参数前面有分组并且分组的组名和第三个参数的key相同,那么用户访问浏览器的时候就会把覆盖掉分组需要返回来的内容

图片 9图片 10

url(r"^index/(?P<name>[0-9]{4})/$",views.index,{"name":"pyrene"})

urls

views视图函数不变

用户访问

浏览器显示:pyrene 而不是2000

原因是被后面的第三个参数覆盖掉了

应用:

这里的作用可以把几个相同连接,然后加上第三个参数来返回不同的内容

四、url第四个参数

应用:防止修改跳转form路径,造成大量的复杂操作

小知识:

输入form的时候点击tab就会直接把form快捷键出来

urls文件,首先设置别名

url(r"^index/",views.index,name="pyrene")

在templates里面添加login.html文件

图片 11图片 12

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
{#<form action="/index/" method="post">#}
<form action="{% url "pyrene" %}" method="post">
    <input type="text" name="username"/>
    <input type="password" name="pwd"/>
    <input type="submit" value="submit">
</form>

</body>
</html>

View Code

 

views视图函数:

图片 13图片 14

def index(req):
    if req.method=="POST":
        username=req.POST.get("username",None)
        pwd=req.POST.get("pwd",None)
        if username=="aa"and pwd=="123":
            return HttpResponse("登录成功")
    return render(req,"login.html")

View Code

然后用户输入

输入用户名密码,提交就能登录成功

原因:

1、  首先在urls里面设置了form跳转的别名

2、  在login的前端文件中设置模板语言

3、  然后用户点击提交,前端模板语言就代表了urls的正则匹配的路径,所以能跳转找到views视图函数

参数四的应用:

由于后端测试等需要更改前端与后端的路径名字,所以这里设置别名就不用更改前端的form跳转的路径。避免了复杂操作

url关于别名补充

1、这里的别名是用户连接的时候就已经在后台替换了别名

五、url映射分发

应用背景:

由于一个大型网站有很多个页面,成千上万个,如果把这些页面路由放到全局的urls里面,那样会造成很多麻烦,所以路由映射分发就出现了

思想:

利用分级的方式,首先在全局urls分发器中分别分发给下面不同功能层级进行urls选

用include

1、  在全局urls中操作  导入include,然后分发层级

图片 15图片 16

from django.conf.urls import url,include  #这里导入include
from django.contrib import admin
from app01 import  views
urlpatterns = [
    url(r'^admin/', admin.site.urls),
    url(r"^app01/",include("app01.urls")),]   #分发层级

View Code

 

2、 在app01这个项目功能中创建urls

图片 17图片 18

#!/usr/bin/env python
# -*- coding:utf-8 -*-
from django.conf.urls import url,include
from django.contrib import admin
from app01 import  views
urlpatterns = [
    url(r"^new/story/$",views.introduce)
]

View Code

 

3、  在views视图函数中写入

图片 19图片 20

def introduce(req):
    return HttpResponse("ok")

View Code

 

用户访问

流程:首先在项目全局中设置include、urls分发,然后在下面功能中设置urls连接views视图函数。

2、Django Views(视图函数)

图片 21

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

        http请求:HttpRequest对象

        http响应:HttpResponse对象

所在位置:django.http

之前我们用到的参数request就是HttpRequest    检测方法:isinstance(request,HttpRequest)

Django views(视图函数)

图片 22

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

        http请求:HttpRequest对象

        http响应:HttpResponse对象

所在位置:django.http

之前我们用到的参数request就是HttpRequest    检测方法:isinstance(request,HttpRequest)

1 HttpRequest对象的属性和方法:

图片 23图片 24

 1 # path:       请求页面的全路径,不包括域名
 2 #
 3 # method:     请求中使用的HTTP方法的字符串表示。全大写表示。例如
 4 #
 5 #                    if  req.method=="GET":
 6 #
 7 #                              do_something()
 8 #
 9 #                    elseif req.method=="POST":
10 #
11 #                              do_something_else()
12 #
13 # GET:         包含所有HTTP GET参数的类字典对象
14 #
15 # POST:       包含所有HTTP POST参数的类字典对象
16 #
17 #              服务器收到空的POST请求的情况也是可能发生的,也就是说,表单form通过
18 #              HTTP POST方法提交请求,但是表单中可能没有数据,因此不能使用
19 #              if req.POST来判断是否使用了HTTP POST 方法;应该使用  if req.method=="POST"
20 #
21 #
22 #
23 # COOKIES:     包含所有cookies的标准Python字典对象;keys和values都是字符串。
24 #
25 # FILES:      包含所有上传文件的类字典对象;FILES中的每一个Key都是<input type="file" name="" />标签中                     name属性的值,FILES中的每一个value同时也是一个标准的python字典对象,包含下面三个Keys:
26 #
27 #             filename:      上传文件名,用字符串表示
28 #             content_type:   上传文件的Content Type
29 #             content:       上传文件的原始内容
30 #
31 #
32 # user:       是一个django.contrib.auth.models.User对象,代表当前登陆的用户。如果访问用户当前
33 #              没有登陆,user将被初始化为django.contrib.auth.models.AnonymousUser的实例。你
34 #              可以通过user的is_authenticated()方法来辨别用户是否登陆:
35 #              if req.user.is_authenticated();只有激活Django中的AuthenticationMiddleware
36 #              时该属性才可用
37 #
38 # session:    唯一可读写的属性,代表当前会话的字典对象;自己有激活Django中的session支持时该属性才可用。
39 
40 #方法
41 get_full_path(),   比如:http://127.0.0.1:8000/index33/?name=123 ,req.get_full_path()得到的结果就是/index33/?name=123
42 req.path:/index33

View Code

1 HttpRequest对象的属性和方法:

图片 25图片 26

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支持时该属性才可用。

#方法
get_full_path(),   比如:http://127.0.0.1:8000/index33/?name=123 ,req.get_full_path()得到的结果就是/index33/?name=123
req.path:/index33

View Code

注意一个常用方法:request.POST.getlist('')

注意一个常用方法:request.POST.getlist('')

2 HttpResponse对象:

  对于HttpRequest对象来说,是由django自动创建的,但是,HttpResponse对象就必须我们自己创建。每个view请求处理方法必须返回一个HttpResponse对象。

  HttpResponse类在django.http.HttpResponse

  在HttpResponse对象上扩展的常用方法:

1 页面渲染:         render()(推荐)<br>                 render_to_response(),
2 页面跳转:         redirect("路径")
3 locals():    可以直接将函数中所有的变量传给模板

补充:

图片 27图片 28

 1 -----------------------------------url.py
 2 
 3  url(r"login",   views.login),
 4  url(r"yuan_back",   views.yuan_back),
 5 
 6 -----------------------------------views.py
 7 def login(req):
 8     if req.method=="POST":
 9         if 1:
10             # return redirect("/yuan_back/")
11             name="yuanhao"
12 
13             return render(req,"my backend.html",locals())
14 
15     return render(req,"login.html",locals())
16 
17 
18 def yuan_back(req):
19 
20     name="苑昊"
21 
22     return render(req,"my backend.html",locals())
23 
24 -----------------------------------login.html
25 
26 <form action="/login/" method="post">
27     <p>姓名<input type="text" name="username"></p>
28     <p>性别<input type="text" name="sex"></p>
29     <p>邮箱<input type="text" name="email"></p>
30     <p><input type="submit" value="submit"></p>
31 </form>
32 -----------------------------------my backend.html
33 <h1>用户{{ name }}你好</h1>
34 
35 #总结: render和redirect的区别:
36 #   1 if render的页面需要模板语言渲染,需要的将数据库的数据加载到html,那么所有的这一部分
37 #     除了写在yuan_back的视图函数中,必须还要写在login中,代码重复,没有解耦.
38 
39 #   2 the most important: url没有跳转到/yuan_back/,而是还在/login/,所以当刷新后
40 #     又得重新登录.

View Code

 

2 HttpResponse对象:

  对于HttpRequest对象来说,是由django自动创建的,但是,HttpResponse对象就必须我们自己创建。每个view请求处理方法必须返回一个HttpResponse对象。

  HttpResponse类在django.http.HttpResponse

  在HttpResponse对象上扩展的常用方法:

页面渲染:         render()(推荐)<br>                 render_to_response(),
页面跳转:         redirect("路径")
locals():    可以直接将函数中所有的变量传给模板

本文由金沙澳门官网发布于网络编程,转载请注明出处:Django---U福特ExplorerL、Views

关键词: 金沙澳门官网

上一篇:一定是你的操作不够骚
下一篇:没有了