标签:正则 etl alt sub 变量 als django 用户 告诉
URL配置(URLconf)就像Django 所支撑网站的目录。它的本质是URL模式以及要为该URL模式调用的视图函数之间的映射表;你就是以这种方式告诉Django,对于这个URL调用这段代码,对于那个URL调用那段代码。
1 urlpatterns = [
2 url(正则表达式, views视图函数,参数,别名),
3 ]
参数说明:
示例:
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 ]
http请求中产生两个核心对象:
http请求:HttpRequest对象
http响应:HttpResponse对象
所在位置:django.http
之前我们用到的参数request就是HttpRequest 检测方法:isinstance(request,HttpRequest)
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
对于HttpRequest对象来说,是由django自动创建的,但是,HttpResponse对象就必须我们自己创建。每个view请求处理方法必须返回一个HttpResponse对象。
HttpResponse类在django.http.HttpResponse
在HttpResponse对象上扩展的常用方法:
1 页面渲染: render()(推荐)<br> render_to_response(),
2 页面跳转: redirect("路径")
3 locals(): 可以直接将函数中所有的变量传给模板
补充:
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 # 又得重新登录.
标签:正则 etl alt sub 变量 als django 用户 告诉
原文地址:https://www.cnblogs.com/horror/p/9441011.html