zoukankan      html  css  js  c++  java
  • URL 路由系统 + views 函数

    一、URL

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

    urlpatterns = [
        url(正则表达式, views视图函数,参数,别名),
    ]
    别名
    name="reg" ,跟 标签 {% url "reg" %} 配合使用,意味着中国url 指向 别名代表的那个 url匹配。
        这个 url 标签 有好几种情况用法,在 2.1 版本,【加参数,{% url 'bieming' {{ canshu }} %}】
          【url.py 别名重名 https://docs.djangoproject.com/zh-hans/2.1/intro/tutorial03/
    
    

    参数说明:

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

    二、例子

    url(r'^index.html/(d+)/(w+)', views.index),
    
    def index(request,a,b):
        print(request.GET)
        print(a)
        print(b)
        return HttpResponse(a+"  "+b)
    
    URL里有 无名分组匹配时候,会给 views 函数 位置传参
    
    [15/Sep/2019 14:56:21] "GET /index.html/123/qwe HTTP/1.1" 200 8
    <QueryDict: {}>
    123
    qwe
    
    ===========================
    
    url(r'^index1.html/(?P<year>d{4})/(?P<month>d{2})', views.index1 ),
    
    def index1(request,month,year):
        print(request.GET)
        print("year",year)
        print("month",month)
        return HttpResponse("year:{} month:{}".format(year,month))
    
    URL里的有名分组,匹配到后给views函数 关键字传参,相当于在URL()的参数位置写上匹配到的字典。比如下面的例子
    <QueryDict: {}>
    [15/Sep/2019 14:59:01] "GET /index1.html/2020/03 HTTP/1.1" 200 18
    year 2020
    month 03
    
    ==========================
    
    url(r'^index3.html/(?P<year>d+)', views.index3 ,{"name":"qweqwe","age":12}),
    
    def index3(request,year,age,name):
        print(request.GET)
        print("year",year)
        print("name",name)
        print("age",age)
        return HttpResponse(year)
    
    当匹配到这个URL时候,会将有名分组 year +到后面的字典里,
    
    [15/Sep/2019 15:02:16] "GET /index3.html/2020 HTTP/1.1" 200 4
    year 2020
    name qweqwe
    age 12
    
    ==============================
    
    url(r'^index2.html$', views.index2),
    
    def index2(request):
        print(request.GET)
        aa = request.GET.get("aa")
        print(aa)
        return HttpResponse(aa)
    
    【http://127.0.0.1:8888/index2.html?aa=213】
    请求的URL是带有传参的,这种传参是赋值给 get方法
    
    <QueryDict: {'aa': ['213']}>
    [15/Sep/2019 15:11:53] "GET /index2.html?aa=213 HTTP/1.1" 200 3
    213

     三、路由分发

      存在将不同URL分类到不同的APP中再处理,采取路由分发

    在  项目的 urls.py 文件
    导入 include
    from django.conf.urls import url,include
    
        url(r'^app01', include("app01.urls")),
    
    在 APP01 下创建 urls.py  文件
    所有app01 的请求就转到 APP01  下的 urls.py  文件 做URL处理。
    APP01  下的 urls.py 文件
    from django.conf.urls import url,include
    from app01 import views
    urlpatterns = [
    url(r'/index.html', views.index4),
    url(r'/register', views.register),
    ]

    views.py 的函数

    def index4(request):
    
        return render(request,"index.html")
    
    def register(request):
        print("post ",request.POST)
    
        return HttpResponse("ok111")

    模板文件【HTML】的 form表单 , post 请求

    <h1>学生注册</h1>
    <form action="/app01/register" method="post">
    {% csrf_token %} {# post 请求 加这个 #}
    <p>姓名 <input type="text" name="user"></input></p>
    <p>年龄 <input type="text" name="age"></input></p>
    <p>爱好
    <input type="checkbox" name="hobby" value="1">足球</input>
    <input type="checkbox" name="hobby" value="2">篮球</input>
    <input type="checkbox" name="hobby" value="3">乒乓球</input>
    </p>
    <p><input type="submit" >提交</p>
    </form>

     最后 在 后台打印

    post  <QueryDict:
    {
      'csrfmiddlewaretoken': ['qzqavNxXMQtYzbNdUUa1mfZp6GpqU3tCCYlvJQUWLhd0mJ3gxpsTYDKR0P3biwrr'],

      'user': ['qwe'],   'age': ['2'],   'hobby': ['1']
    }
    >

    如果改成 get 请求, 那么 会在URL地址栏 看到提交后的 URL是把 提交的参数显示出来了,

    chome 开发者模式 也能看到

    Request URL: http://127.0.0.1:8888/app01/register?user=qwe&age=2222222222&hobby=3
    Request Method: GET
    Status Code: 200 OK
    Remote Address: 127.0.0.1:8888
    Referrer Policy: no-referrer-when-downgrade

    后台打印

    <QueryDict:
    {
    'user': ['qwe'],
    'age': ['2222222222'],
    'hobby': ['3']}
    >
    这个 就没有 token 了

    四、视图函数  views

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

            http请求:HttpRequest对象

            http响应:HttpResponse对象

    所在位置:django.http

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

     HttpRequest对象的属性和方法:

    # 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

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

    HttpResponse对象:

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

      HttpResponse类在django.http.HttpResponse

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

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

      

  • 相关阅读:
    mysql主从延迟判断,监控和问题处理
    oracle备份
    oracle的查询命令
    Appcan 自定义数字加减控件
    PowerDesigner16.5 有用地址
    git远程仓库关联(码云)
    leetcode27.移除元素(双指针法)
    leetcode26.删除排序数组中的重复项(双指针法,顺序表删除)
    leetcode21.合并两个有序链表(链表使用,递归算法)
    leetcode20.有效的括号(hashmap使用,键值匹配)
  • 原文地址:https://www.cnblogs.com/chenpython123/p/11522624.html
Copyright © 2011-2022 走看看