# DEBUG模式

  1. 开启debug模式后,修改项目代码时按下ctrl+s可重启项目;
  2. 项目中出现bug时,浏览器与控制台会打印错误信息;
  3. 在生产环境中禁止开启DEBUG模式,有很大的安全隐患;
  4. 将DEBUG设置为False时,必须设置ALLOWED_HOSTS。
    • ALLOWED_HOSTS :用来设置以后只能通过这个变量中的IP或域名来进行访问

视图函数

  1. 第一个参数必须是 request ; book_id 后可添加默认参数。
  2. 返回值必须是 ‘django.http.response.HttpResponse’ 的子类对象
     #(app)front中views.py
    from django.http import HttpResponse def index(request):
    return HttpResponse('网站首页') def books(requeset,book_id):
    text = '图书的ID是:%s' % book_id
    return HttpResponse(text) #项目urls.py
    from django.urls import path
    from front import views urlpatterns = [
    #http://127.0.0.1:8000/
    path('',views.index),
    #http://127.0.0.1:8000/book/1
    path('book/<book_id>/',views.books)
    ]

urls模块化

  1. 每个App的 urls 都放到自己的App进行管理,在App中新建一个 urls.py 文件来存储所有和这个App相关的 子url ,然后在项目的主 urls.py 文件下使用 include 来包含各个App的 urls.py 文件,如:

     #项目urls.py
    '''
    urlpatterns = [
    path('book/',include('book.urls'))
    ]
    '''  #book.urls为应用程序book的urls.py文件
  2. ‘App’的 urls.py 中,所有的url匹配也要放在变量 urlpatterns 中,否则找不到;
     #App的urls.py
    '''
    urlpatterns = [
    path('/detail/<book_id>/',views.book_detail)
    ]
    '''
  3. 项目的‘url’会根据 urls.py 和App中的 urls.py 进行拼接,注意不能多加斜杆。(得到的URL为:http://.../book/detail/1)

url命名

  1. 为App的‘ url ’命名,防止后期‘url’经常变动。后期反转时使用 name 定义的url名字。前面显示的 login 可变动;

      #app的urls.py
    '''
    path('login/',views.login,name='login')
    '''
  2. 存在多个App时,为防止同名的‘url’产生混淆,使用 ‘命名空间 ’app_name 来进行区分;
     #App的urls.py文件
    '''
    app_name = 'front’  #app的名称 urlpatterns = [
    path('login/',views.login,name='login')
    ]
    '''

    反转时使用 命名空间:url名称 进行反转

     app的urls.py文件
    '''
    return redirect(reverse(‘front:login’))   #反转到front应用程序的url页面(name=‘login’的值)。
    '''

# 应用(app)命名空间与实例命名空间:

  1. 一个App可使用多个URL实例进行映射,所以使用命名空间时容易发生混淆;使用 实例命名空间‘namespace’ 来解决该问题

     #项目urls.py
    '''
    path('login1/',include('front.urls',namespace='login1'))
    path('login2/',include('front.urls',namespace='login2'))
    '''
  2. 反转时使用实例命名空间指定具体的url;
     #应用程序urls.py
    '''
    def idnex(request):
    username = request.GET.get('username')
    if username:
    return HttpResponse('front首页')
    else:
    #获取当前命名空间
    current_namespace = request.resolver_match.namespace
    return redirect(reverse('%s:login' % current_namespace))
    '''

# include()函数:

  1. include(module,namespace=None)

    • module:子 url 的模块字符串;
    • namespace:指定实例命名空间时必须先指定应用命名空间app_name;
  2. include((pattern_list,app_namespace),namespace=None)
    • 函数的第一个参数可以为一个字符串或者一个元组,为元组时第一个参数为App的 url.py 模块的字符串,第二个参数为应用命名空间;

       '''
      path(('login/',include('front.urls','login'),namespace='book'))
      '''
  3. include(pattern_list) :列表中装 path 或 re_path 。
     '''
    path('movies/',include([
    path(' ',views.movie),
    path('list/',views.movie_list),
    ]))
    '''

# re_path

  1. 作用比 ‘path’ 强大,写 url 时可使用正则表达式;(无特殊情况时建议使用:path)
  2. 写正则表达式时使用原生字符串,即以 ‘r’ 开头的字符串;
  3. 正则表达式使用圆括号定义变量,参数有名字时使用 ?P<参数名字> ,然后在后面添加正则表达式的规则。
     '''
    re_path(r"^list/(?P<year>\d{4}/$",views.book_list)
    '''

# reverse函数

  1. 在反转 ur l时,如需添加参数,可传递 kwargs 参数到reverse函数中

     #应用urls.py
    '''
    return redirect(reverse('book',kwargs={'book_id':1,'page':2}))
    '''
  2. 如需添加字符串的参数,则必须手动进行拼接
     #在没输入关键参数时自动跳转到登录页面,next告诉下一步跳转的位置
    '''
    return redirect(reverse('login') + "?next=/")
    '''
    #类似于知乎的首页登录跳转
    #知乎网站:https://www.zhihu.com/signup?next=%2F (%2F = /)
    #进入时自动跳转到 signup 的url登录页面,后面告知下一步跳转到首页

URL简单梳理的更多相关文章

  1. C#正则表达式_简单梳理_Emoji表情字符处理

    A-最近一直有接触到正则表达式,现对其做简单梳理: private const RegexOptions OPTIONS = RegexOptions.IgnoreCase | RegexOption ...

  2. 机器学习&数据挖掘笔记(常见面试之机器学习算法思想简单梳理)

    机器学习&数据挖掘笔记_16(常见面试之机器学习算法思想简单梳理) 作者:tornadomeet 出处:http://www.cnblogs.com/tornadomeet 前言: 找工作时( ...

  3. [转]机器学习&数据挖掘笔记_16(常见面试之机器学习算法思想简单梳理)

    机器学习&数据挖掘笔记_16(常见面试之机器学习算法思想简单梳理) 转自http://www.cnblogs.com/tornadomeet/p/3395593.html 前言: 找工作时(I ...

  4. RocketMQ 简单梳理 及 集群部署笔记【转】

    一.RocketMQ 基础知识介绍Apache RocketMQ是阿里开源的一款高性能.高吞吐量.队列模型的消息中间件的分布式消息中间件. 上图是一个典型的消息中间件收发消息的模型,RocketMQ也 ...

  5. Memcached概念、作用、运行原理、特性、不足简单梳理(1)

    大家可能对memcached这种产品早有了解,或者已经应用在自己的网站中了,但是也有一些朋友从来都没有听说过或者使用过.这都没什么关系,本文旨在从各个角度综合的介绍这种产品,尽量深入浅出,如果能对您现 ...

  6. SpringSecurity配置,简单梳理

    生活加油:摘一句子: “我希望自己能写这样的诗.我希望自己也是一颗星星.如果我会发光,就不必害怕黑暗.如果我自己是那么美好,那么一切恐惧就可以烟消云散.于是我开始存下了一点希望—如果我能做到,那么我就 ...

  7. 简单梳理JavaScript垃圾回收机制

    JavaScript具有自动垃圾回收机制,即执行环境会负责管理代码执行过程中使用地内存. 这种垃圾回收机制的原理很简单:找出那些不再继续使用的变量,然后释放其占用的内存.为此,垃圾收集器会按照固定的时 ...

  8. 简单梳理下 Vue3 的新特性

    在 Vue3 测试版刚刚发布的时候,我就学习了下 Composition API,但没想到正式版时隔一年多才出来,看了一下发现还是增加了不少新特性的,在这里我就将它们一一梳理一遍. 本文章只详细阐述 ...

  9. 机器学习&数据挖掘笔记_16(常见面试之机器学习算法思想简单梳理)

    前言: 找工作时(IT行业),除了常见的软件开发以外,机器学习岗位也可以当作是一个选择,不少计算机方向的研究生都会接触这个,如果你的研究方向是机器学习/数据挖掘之类,且又对其非常感兴趣的话,可以考虑考 ...

随机推荐

  1. Wisdom RESTClient支持自动化测试并可以生成API文档

    Wisdom REST Client V1.2 支持自动化测试RESTful API并生成精美的测试报告,同时基于历史数据自动生成精美的RESTful API文档. 工具地址:https://gith ...

  2. PS火焰文字制作

    火焰文字制作: 最终效果 第一步: 新建图层,并输入文字(这里不做详细解说)

  3. 流媒体协议(RTMP、RTSP、UDP、HTTP、MMS)转换小工具(RTSP转成RTMP案例展示)(转)

    源: 流媒体协议(RTMP.RTSP.UDP.HTTP.MMS)转换小工具(RTSP转成RTMP案例展示)

  4. Solr创建核的方法

    Solr创建核的方法,简单粗暴 就是进入到solrhome中进行复制粘贴这个collection2 然后进入到conf中,修改一下name 然后从新启动tomcat

  5. 使用nosql实现页面静态化的一个小案列

    页面静态化,其实就是将动态生成的php页面,变成静态的HTML页面,让用户直接访问.有一下几方面好处: 1,首先就是访问速度,不需要去访问数据库,或者缓存来获取哪些数据,浏览器直接加载渲染html页即 ...

  6. c++ STL中的next_permutation

    default (1) template <class BidirectionalIterator> bool next_permutation (BidirectionalIterato ...

  7. Vue小案例 之 商品管理------修改商品数量以及增加入库日期属性

    实现修改商品的数量: 加入的代码: css: .clear-btn{ text-align: right; padding-right: 10px; } .table-warp a{ text-dec ...

  8. jQuery实现省市联动

    未实现任何功能之前: 实现功能之后: 实现该功能的jQuery核心代码: <script> var provinceArr=new Array(5); provinceArr[0]=new ...

  9. c++ kafka 客户端rdkafka报Receive failed: Disconnected问题原因以及解决方法

    %3|1538976114.812|FAIL|rdkafka#producer-1| [thrd:kafka-server:9092/bootstrap]: kafka-server:9092/0: ...

  10. TNS-12537,TNS-12560,TNS-00507 Linux Error: 29: Illegal seek解决

    下午有个测试环境测试人员反馈oracle监听起不来,一启动就报错,还生成了core文件.如下: [oracle@localhost ~]$ lsnrctl start LSNRCTL for Linu ...