form组件+cookie+session总结
1、forms 组件
-数据校验功能
1、定义
-新建一个py文件
-导入from django import forms
-写一个类继承 forms.Form
-把你需要校验的(字段的条件)属性写到类里面
-比如:name = forms.CharField(max_length=8,min_length=3,label="用户名",
error_messages={"max_length":"超出范围",
"min_length":"太短了","required":"该项不能为空"},)
-局部钩子函数
-def clean_name(self):
-name=self.cleaned_data.get("name")
if name.startswith("sb")
-raise ValidationError("不能以sb开头")
else:
#切记,如果正确,一定要返回name
return name
-全局钩子函数
-使用ValidationError需导入
-from django.core.exceptions import ValidationError
-def clean(self):
-pwd = self.cleaned_data.get("pwd")
-re_pwd = self.cleaned_data.get("re_pwd")
-if pwd ==re_pwd:
-# 正确,返回cleaned_data
-return None
-else:
#校验不通过:raise ValidationError('两次密码不一致'),错误放到__all__
-return ValidationError("两次密码不一致")
2 views中使用:
def test(request):
if request.method=='GET':
regform=RegForm()
else:
regform=RegForm(request.POST)
if regform.is_valid():
#一般情况需要存数据库了
pass
else:
error_all=regform.errors.get('__all__')
# error_all=regform.errors['__all__']
return render(request,'register.html',locals())
3 模板中使用
<form action="">
{% for foo in regform %}
{{ foo.label }}:{{ foo }} <span>{{ foo.errors.0 }}</span>
{% endfor %}
<input type="submit"> <span>{{ error_all }}</span>
</form>
2、cookie和session
-1、cookie:由服务器产生,存放在客户端浏览器上的键值对
-2、django中使用:
-设置值:
obj = HttpResponse(“ok”)
obj.set.cookie("key","value")
return obj
-取值:
request.COOKIES.get("key")
request.COOKIES["key"]
-删除值:
obj = HttpResponse(“ok”)
obj.datele_cookie("key")
-3、session:保存在服务器上的键值对
-设置值:
-request.session["key"]="value"
干了的事:
1、生成一个随机字符串:dasfjdfks
2、在django——session表中存入dasfjdfks {"key":"value"} 超市时间
3、把sessionid:dasfjdfks写入到cookie
-取值:
-request.session.get("key")
-删除值:
-request.session.flush():全删除
-request.session.detele():只删除数据库
-其他配置参数:
-了解
3、Auth模块
1、Django自带的用户认证模块,可以快速实现都登录,注销,修改密码....
#from django.contrib.auth.models import AbstractUser
2、扩展auth表,需要继AbstractUser
3、一定不要忘记在setting中配置:AUTH_USER_MODEL = "app01.UserInfo"
-# 指定以后再作用户认证,都用这个表
4、它提供的功能:
-from django.contrib.auth import authenticate,login,logout
-用户认证:authenticate(username=lqz,password=123)
-用户一旦认证通过,调用login(request,user),以后从reuqest.user 中就能取出当前登录人对象
-退出:logout(request),request.user就是匿名用户
-校验是否通过认证(是否登录):request.user.is_authenticated()
-创建普通用户
-models.UserInfo.objects.create_user(username=lqz)
-创建超级用户
-models.UserInfo.objects.create_superuser(username=lqz)
-修改密码
-用user对象.set_password(新密码)
-一定要记住sava
-校验密码
-check_password(password)
-登录认证装饰器
# @login_required(login_url='/login/')
-login_required(login_uel="/login/")
is_staff: 用户是否拥有网站管理权限:create_superuser: is_staff 是 1
id_active: 是否允许用户登录,设置为False,可以在不删除用户的前提下禁止用户登录。
form组件+cookie+session总结的更多相关文章
- day09 Django: 组件cookie session
day09 Django: 组件cookie session 一.cookie和session都是会话跟踪技术 1.什么是会话 可以理解为客户端和服务端之间的一次会 ...
- Form组件 cookie和session
django form组件 1.渲染标签 2.校验数据 3.展示信息 第一步需要一个form类 from django import forms class MyForm(forms.Form): n ...
- python 全栈开发,Day76(Django组件-cookie,session)
昨日内容回顾 1 json 轻量级的数据交换格式 在python 序列化方法:json.dumps() 反序列化方法:json.loads() 在JS中: 序列化方法:JSON.stringfy() ...
- Django组件-cookie,session
昨日内容回顾: json 轻量级的数据交换格式 在python 序列化方法:json.dumps() 反序列化方法:json.loads() 在JS中: 序列化方法:JSON.stringfy() 反 ...
- django form组件 cookies,session
django form组件 渲染标签 就是组件里面的字段在前端展示叫做渲染标签 校验数据 用户输入的数据提交给后端组件叫做校验数据 forms组件中定义的字段都是必须传值的(required=Tr ...
- Django--form组件cookie/session
Field required=True, 是否允许为空 widget=None, HTML插件 label=None, 用于生成Label标签或显示内容 initial=None, 初始值 help_ ...
- django之forms组件,cookie&session
forms组件 先自己实现注册功能,并且对用户输入的信息加限制条件如果用户输入的信息不符合条件,前端展示报错信息 from django.shortcuts import render,HttpRes ...
- Web框架之Django_08 重要组件(form组件、cookie和session组件)
摘要: form组件 cookie组件 session组件 一.form组件 form介绍我们之前在html页面中利用form表单向后端提交数据时候,都需要对用户的输入进行校验,比如校验用户是否输入正 ...
- Ajax cookie session form组件
. Cookie是什么 保存在浏览器端的键值对 为什么要有Cookie? 因为HTTP请求是无状态的 Cookie的原理? 服务端可以在返回响应的时候 做手脚 在浏览器上写入键值对(Cookie) 浏 ...
随机推荐
- python类属性用法总结
属性的定义:python中的属性其实是普通方法的衍生. 操作类属性有三种方法: 1.使用@property装饰器操作类属性. 2.使用类或实例直接操作类属性(例如:obj.name,obj.age=1 ...
- WIN10安装不上IIS,使用IISExpress作为发布服务
[背景] 本人开发Win程序,需要调用网站资源作为Win程序的辅助功能,为此需要本地开发环境支持IIS.最近重装系统,VS安装完后,接着再安装IIS,可以在添加删除程序中反复尝试,均告安装失败提示.最 ...
- 安卓投屏助手(B1358)之辅助调试
Android远程桌面助手的中文版——安卓投屏助手正式上线.安卓投屏和远程控制的软件其实已经非常多了,如Vysor.Total Control.Mobizen.ApowerMirror.TeamVie ...
- Linux网络基本网络配置方法介绍
网络信息查看 设置网络地址: cat /etc/sysconfig/network-scripts/ifcfg-eth0 你将会看到: DEVICE=eth0BOOTPROTO=staticsHWAD ...
- 报错TypeError: $(...).live is not a function解决方法
报错的原因是这个方法在jquery1.7以后就被废除了, 1.7以后的版本改用.on()方法 之前的用法: .live(events, function) 新方法: .on(eventType, se ...
- SQL Server数据库————增删改查
--增删改查--增 insert into 表名(列名) value(值列表) --删 delect from 表名 where 条件 --改 update 表名 set 列名=值1,列名2=值2 w ...
- iOS多线程GCD的使用
1. GCD 简介 Grand Central Dispatch(GCD)是异步执行任务的技术之一.一般将应用程序中记述的线程管理用的代码在系统级中实现.开发者只需要定义想执行的任务并追加到适当的Di ...
- win10怎么进入和退出安全模式?
在Win10系统里同时按下”Win+R“组合按键,在打开的运行对话框里输入命令:msconfig,然后点击确定,如下图所示. 点击打开系统配置窗口,选择引导选项卡,如下图所示. 在引导选项卡窗口下,将 ...
- java中的重写与重载
重写(Override) 重写是子类对父类的允许访问的方法的实现过程进行重新编写, 返回值和形参都不能改变.即外壳不变,核心重写! 重写的好处在于子类可以根据需要,定义特定于自己的行为. 也就是说子类 ...
- jQuery中$.each()方法的使用
$.each()是对数组,json和dom结构等的遍历,说一下他的使用方法吧. 1.遍历一维数组 var arr1=['aa','bb','cc','dd']; $.each(arr1,functio ...