# 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. elsearch

    1. ElasticSearch是性能优化的分布式全文搜索引擎,存储数据的载体是文档(Document),它的优势在于搜索速度快和支持聚合操作,在更新文档时,基本上能够达到实时搜索.ElasticSe ...

  2. RocketMQ最佳实战

    RocketMQ 客户端最佳实践 1. Producer最佳实践 发送消息注意事项 1). 一个应用尽可能用一个Topic,消息子类型用tags来标识,tags可以由应用自由设置. 2). 消息发送成 ...

  3. Linux基础命令---IP路由操作

    ip ip指令可以显示或操作路由.网路设备,设置路由策略和通道. 此命令的适用范围:RedHat.RHEL.Ubuntu.CentOS.SUSE.openSUSE.Fedora.   1.语法     ...

  4. 区块链3.0 ada Cardano卡尔达诺如何获得一致好评?

    区块链3.0 ada Cardano卡尔达诺如何获得一致好评? EOS 的直接竞争对手是以太坊.文章介绍的卡尔达诺(Cardano)的目标就更加远大了,他要同时锁定比特币和以太坊.但大家去网上搜索卡尔 ...

  5. Lucene 个人领悟 (二)

    想了想,还是继续写吧,因为,太无聊了,媳妇儿也还有半个小时才下班. 前面拖拖拉拉用了三篇文章来做铺垫,这一篇开始正经搞了啊. 首先,我要加几个链接 http://www.cnblogs.com/xin ...

  6. Django ORM 操作 必知必会13条 单表查询

    ORM 操作 必知必会13条 import os # if __name__ == '__main__': # 当前文件下执行 os.environ.setdefault('DJANGO_SETTIN ...

  7. 浏览收藏夹 看到了hadoop3.0 的改动

    大数据非常前卫的it网站   https://www.iteblog.com/archives/tag/hadoop/ 1.多个服务的默认端口被改变 在此之前,多个Hadoop服务的默认端口都属于Li ...

  8. The Little Prince-summary

    The Little Prince-summary 这些年 ”寂寞”这个词使用频率越来越高 这些年 不管有钱没钱 有对象没对象的人 入夜时分总是心里空空 不知生活的意义是什么 我们不喜欢一座城市 对一 ...

  9. jsoi2018 R1R2

    Jsoi2018 R1: D1:T1:签到题,状压dp,(思考:讲题人说可以卡一卡空间,怎么做?) T2:50pts:贪心,因为无重复 100pts:线段树合并? T3:25pts 树形dp D1:T ...

  10. python类的组合

    类的组合,即在类实例化时,将另一个类的实例作为参数传入,这样可以将两个实例关联起来. 当类之间有显著不同,并且较小的类是较大的类所需要的组件时,用组合比较好. 例如,描述一个机器人类,这个大类是由很多 ...