一、装饰器要加入funtools.wrap装饰

保留函数的元数据(函数名/注释)

1.装饰器

def wrapper(f):
  def inner(*args,**kwargs):
    return f(*args,**kwargs)
  return inner

  

import functools

def wrapper(f):
@functools.wraps(f)
def inner(*args,**kwargs):
return f(*args,**kwargs)
return inner 1. 执行wrapper
2. 重新赋值
index = wrapper(index)
@wrapper
def index(a1,a2):
  """
  这是一个index函数
  """
  return a1+ a2
print(index.__name__)
print(index.__doc__)

  

二、orm字段中的verbose_name

目前当注释用. 以后:在model form和form中使用.

三、路由系统中记得加入终止符 $

url(r'^login/$', admin.site.urls,name='login'),

四、用户名和密码检测

xxxx.first() # 返回对象或None

user_object = models.UserInfo.objects.filter(username=user, password=pwd).first()

xxxx.exists() # 返回布尔值

user_object = models.UserInfo.objects.filter(username=user, password=pwd).exists()

五、模板查找顺序

1、根目录templates

2、根据app注册顺序去每个app的tempaltes中找

六、cookie

原理

基于cookie实现
保存在用户浏览器端的键值对,向服务端发请求时会自动携带。

操作

def login(request):
  # return HttpResponse('...')
  # return render('...')
  # return redirect('...')
# 设置cookie
  data = redirect('...')
  data.set_cookie()
# 读取cookie
  request.COOKIES.get('xx')
  return data
必须背会一下三个参数:
  key, value='', max_age=None 应用场景: 用户认证 投票 每页默认显示数据

七、session

原理:随机字符串的过程....

基于session实现原理

依赖cookie
是一种存储数据的方式,依赖于cookie,实现本质:
用户向服务端发送请求,服务端做两件事:生成随机字符串;为此用户开辟一个独立的空间来存放当前用户独有的值.
在空间中如何想要设置值:
request.session['x1'] = 123
request.session['x2'] = 456
在空间中取值:
request.session['x2']
request.session.get('x2')
视图函数中的业务操作处理完毕,给用户响应,在响应时会将随机字符串存储到用户浏览器的cookie中.

  

cookie和session的区别?

答: cookie是存储在客户端浏览器上的键值对,发送请求时浏览器会自动携带.
session是一种存储数据方式,基于cookie实现,将数据存储在服务端(django默认存储到数据库).其本质是:
用户向服务端发送请求,服务端做两件事:生成随机字符串;为此用户开辟一个独立的空间来存放当前用户独有的值. 在空间中如何想要设置值:
request.session['x1'] = 123
request.session['x2'] = 456
在空间中取值:
request.session['x2']
request.session.get('x2')
视图函数中的业务操作处理完毕,给用户响应,在响应时会将随机字符串存储到用户浏览器的cookie中.

  拓展:djanago和session相关的配置:


SESSION_COOKIE_NAME = "sessionid" #Session的cookie保存在浏览器上时的key,即:sessionid=随机字符串 SESSION_COOKIE_DOMAIN = None #
api.baidu.com /www.baidu.com/ xxx.baidu.com
SESSION_COOKIE_PATH = "/" # Session的cookie保存的路径 SESSION_COOKIE_HTTPONLY = True # 是否Session的cookie只支持http传输 SESSION_COOKIE_AGE = 1209600 # Session的cookie失效日期(2周) SESSION_EXPIRE_AT_BROWSER_CLOSE = False #是否关闭浏览器使得Session过期 SESSION_SAVE_EVERY_REQUEST = False # 是否每次请求都保存Session,默认修改之后才保存

  

#django中的session如何设置过期时间:

  SESSION_COOKIE_AGE = 1209600 # Session的 cookie失效日期(2周)

#django的session默认存储在数据库,可以放在其他地方吗:

小系统:默认放在数据库即可.
大系统:缓存(redis) 文件:
SESSION_ENGINE = 'django.contrib.sessions.backends.file'
SESSION_FILE_PATH = '/sssss/' 缓存(内存):
SESSION_ENGINE = 'django.contrib.sessions.backends.cache' SESSION_CACHE_ALIAS = 'default'
CACHES = {
  'default': {
    'BACKEND':
      'django.core.cache.backends.locmem.LocMem Cache',
      'LOCATION': 'unique-snowflake',
  }
} 缓存(redis):
SESSION_ENGINE = 'django.contrib.sessions.backends.cache' SESSION_CACHE_ALIAS = 'default'
CACHES = {
  "default": {
    "BACKEND":
      "django_redis.cache.RedisCache",
      "LOCATION": "redis://127.0.0.1:6379",
    "OPTIONS": {
      "CLIENT_CLASS":
        "django_redis.client.DefaultClient",
        "CONNECTION_POOL_KWARGS": {"max_connections": 100} # "PASSWORD": "密码",
    }
  }
}

  

操作session

#读取
request.session['x']
request.session.get('xx') #设置(添加&修改)
request.session['x'] = 123 #删除
del request.session['x']

  

配置
  数据存储位置
    数据库(django默认)
    文件
    缓存(内存/redis)
cookie相关操作
应用场景
  用户认证
  短信验证过期
  权限管理
强调
session中的数据是根据用户相互隔离.
# 示例
def login(request):
  # 获取用户提交的用户名和密码
  user = request.POST.get('user')
  request.session['user_name'] = user
def index(request):
print(request.session['user_name'])

  

八、Http协议

什么是HTTP协议

超文本传输协议
关于连接:一次请求一次响应之后断开连接(无状态、短连接)
关于格式:
请求:请求头+请求体
  (http:www.baidu.com/index/?a=123)
  send("GET /index/?a=123
  http1.1\r\nhost:www.baidu.com\r\nuseragent:Chrome\r\n\r\n")
  send("POST /index/
  http1.1\r\nhost:www.baidu.com\r\nuseragent:Chrome\r\n\r\nusername=alex&pwd=123")
响应:响应头+响应体
  Content-Encoding: gzip\r\nCache-Control:
  private\r\n\r\n网页看到的HTML内容
扩展:常见的请求头都有哪些?
- user-agent:用什么浏览器访问的网站。
- content-type: 请求体的数据格式是什么?(服务端按照格式要求进行解析)
扩展:常见的请求方式?
- GET
- POST

九、django请求生命周期

django请求生命周期 / 浏览器上输入http://www.xxx.com 请求到 达django后发生了什么?

补充:

1、通过js设置cookie

document.cookie = 'k1=wy222;path=/'

$.cookie('k1','wy222',{path:'/'})

注意:path不同会导致设置不同.

2、path的作用

/ , 当前网站中所有的URL都能读取到此值.

"", 只能在当前页面访问的到此数据.

/index/ , 只能在/index/xxx 的网页中查看.

cooke和session的更多相关文章

  1. python Django cookie和session

    在一个会话的多个请求中共享数据,这就是会话跟踪技术.例如在一个会话中的请求如下:  请求银行主页: 请求登录(请求参数是用户名和密码): 请求转账(请求参数与转账相关的数据): 请求信誉卡还款(请求参 ...

  2. python 全栈开发,Day76(Django组件-cookie,session)

    昨日内容回顾 1 json 轻量级的数据交换格式 在python 序列化方法:json.dumps() 反序列化方法:json.loads() 在JS中: 序列化方法:JSON.stringfy() ...

  3. Django组件-cookie,session

    昨日内容回顾: json 轻量级的数据交换格式 在python 序列化方法:json.dumps() 反序列化方法:json.loads() 在JS中: 序列化方法:JSON.stringfy() 反 ...

  4. python Django session/cookie

    一, Cookie #cookie # def cook1(request): # print(request.COOKIES) # 查看cooke # # print(request.get_sig ...

  5. asp.net web.config 设置Session过期时间

    在Asp.net中,可以有四处设置Session的过期时间:(原文作者:望月狼地址:http://www.cnblogs.com/wangyuelang0526/) 一.全局网站(即服务器)级 IIS ...

  6. Asp.NET设置Session过期时间的四种方式

    在Asp.net中,可以有四处设置Session的过期时间: 一.全局网站(即服务器)级 IIS-网站-属性-Asp.net-编辑配置-状态管理-会话超时(分钟)-设置为120,即为2小时,即120分 ...

  7. 转:设置session过期时间

    在Asp.net应用中,很多人会遇到Session过期设置有冲突.其中,可以有四处设置Session的过期时间: 一.全局网站(即服务器)级 IIS-网站-属性-Asp.net-编辑配置-状态管理-会 ...

  8. JavaWeb之Servlet:Cookie 和 Session

    会话 现实生活中我们会用手机跟对方对话,拿起手机,拨号,然后对面接听,跟着互相通话,最后会话结束. 这个过程也可以用我们的B/S模式来描述: 打开浏览器—>输入地址->发出请求->服 ...

  9. Cookie与Session详解

    来源:<PHP核心技术与最佳实践> 列旭松 陈文 著 Cookie与Session详解读书笔记,从概念.操作.应用.注意事项以及区别等几方面详细阐述两者的基础知识,它们都是针对HTTP协议 ...

随机推荐

  1. VB.Net制作-历朝通俗演义

    原先的回数,全是汉语数字,为此我先转换成了阿拉伯数字,遗憾的是阿拉伯数字100居然排在1和2之前!所以必须设置为3位数字才行!否则顺序是乱的. 以下是用VBA批量重命名的代码: Dim FSO As ...

  2. Archives: 2018/11

    There are 35 posts in total till now. 11月 11, 2018 HTTP 11月 11, 2018 TCP与UDP 11月 10, 2018 Python测试 1 ...

  3. Oracle 10G 服务端的安装

    安装依赖包yum -y install binutils compat-libstdc++-33 compat-libstdc++-33.i686 elfutils-libelf elfutils-l ...

  4. python--mysql的CURD操作

    from pymysql import * def main(): # 创建Connextion连接 conn = connect(host='localhost', port=3306, user= ...

  5. signals function|KNN|SVM|average linkage|Complete linkage|single linkage

    生物医疗大数据 存在系统误差使得估计量有偏,如下图红色和蓝色图形,存在随机误差使得估计量并不是同一个值,如图中除去期望之外的曲线值,为了控制随机抽样造成的误差,可以使用p-value决定是否服从假设检 ...

  6. 使用apktool反编译apk文件

    Apktool https://ibotpeaches.github.io/Apktool/install/ 下载地址:Apktool https://bitbucket.org/iBotPeache ...

  7. [洛谷P4299] 首都

    题目传送门 还是维护子树信息. 但是这里多了一个找重心的操作. 这里有一个关于树重心的结论,据说可以用反证法证明.反正我不会证 就是:新的重心一定在原来两个重心之间的那条树链上. 这样我们逐步缩小搜索 ...

  8. 查漏补缺:QT入门

    1.什么世QT Qt是一个跨平台的C++图形用户界面应用程序框架,为应用程序开发者提供建立艺术级图形界面所需的所有功能.它是完全面向对象的,容易扩展,并且允许真正的组建编程. 2.支持平台 Windo ...

  9. JMeter接口测试-计数器

    前言 在测试注册接口的时候,需要批量注册账号时,每注册一个并且需要随时去修改数据,比较繁琐,除了使用随机函数生成账号,我们还可以使用计数器来进行批量注册. 一:添加配置元件-计数器 二:注册10个账号 ...

  10. Python——9函数式编程②

    */ * Copyright (c) 2016,烟台大学计算机与控制工程学院 * All rights reserved. * 文件名:text.cpp * 作者:常轩 * 微信公众号:Worldhe ...