Django中的FBV和CBV用法详解


Posted in Python onSeptember 15, 2019

FBV

FBV,即 func base views,函数视图,在视图里使用函数处理请求。

以用户注册代码为例,

使用两个函数完成注册

初级注册代码

def register(request):
 """返回注册页面"""
 return render(request, "register.html")
def register_handle(request):
 """进行注册处理"""
 # 接收数据
 username = request.POST.get("user_name")
 password = request.POST.get("pwd")
 email = request.POST.get("email")
 allow = request.POST.get("allow")
 # 进行数据校验,all方法可以进行迭代,如果有内容为空的,返回false
 if not all([username, password, email]):
 # 数据不完整
 return render(request, "register.html", {"errormsg": "数据不完整"})
 # 邮箱校验
 if not re.match(r'[a-z0-9][\w.\-]*@[a-z0-9\-]+(\.[a-z]{2,5}){1,2}$', email):
 # 邮箱不合法
 return render(request, "register.html", {"errormsg": "邮箱格式不正确"})
 # 协议是否同意校验
 if allow != "on":
 # 用户不同意协议
 return render(request, "register.html", {"errormsg": "请同意协议"})
 # 校验用户名是否重复
 try:
 user = models.User.objects.get(username=username)
 except models.User.DoesNotExist:
 # 用户名不存在
 user = None
 if user:
 return render(request, "register.html", {"errormsg": "用户名已存在"})
 # 进行业务处理:进行用户注册
 # 使用Django默认的认证系统
 user = models.User.objects.create_user(username, email, password)
 # 因为默认注册后用户是激活的,得进行修改
 user.is_active = 0
 user.save()
 # 返回应答,跳转到首页
 return redirect(reverse("goods:index"))

配套url

urlpatterns = [
 url(r'^register/$', views.register, name="register"), # 注册
 url(r'^register_handle/$', views.register_handle, name="register_handle"), # 注册处理
]

这样虽然分工比较明确,但却比较麻烦,要使用到两个url和两个处理函数,众所周知,程序员是比较懒的,所以FBV的正确打开方式如下

使用一个函数完成注册

FBV注册代码

def register(request):
 """注册"""
 if request.method == 'GET':
 return render(request, "register.html")
 # 接收数据
 username = request.POST.get("user_name")
 password = request.POST.get("pwd")
 email = request.POST.get("email")
 allow = request.POST.get("allow")
 # 进行数据校验,all方法可以进行迭代,如果有内容为空的,返回false
 if not all([username, password, email]):
 # 数据不完整
 return render(request, "register.html", {"errormsg": "数据不完整"})

 # 邮箱校验
 if not re.match(r'[a-z0-9][\w.\-]*@[a-z0-9\-]+(\.[a-z]{2,5}){1,2}$', email):
 # 邮箱不合法
 return render(request, "register.html", {"errormsg": "邮箱格式不正确"})

 # 协议是否同意校验
 if allow != "on":
 # 用户不同意协议
 return render(request, "register.html", {"errormsg": "请同意协议"})
 # 校验用户名是否重复
 try:
 user = models.User.objects.get(username=username)
 except models.User.DoesNotExist:
 # 用户名不存在
 user = None
 if user:
 return render(request, "register.html", {"errormsg": "用户名已存在"})
 # 进行业务处理:进行用户注册
 # 使用Django默认的认证系统
 user = models.User.objects.create_user(username, email, password)
 # 因为默认注册后用户是激活的,得进行修改
 user.is_active = 0
 user.save()
 # 返回应答,跳转到首页
 return redirect(reverse("goods:index"))

配套url

urlpatterns = [
 url(r'^register/$', views.register, name="register"), # 注册
]

但此时问题又来了,我们知道,在http中请求的方式有get,post,head,options,put,delete,trace,connect等多种方式,从网上盗了一张图来描述这些请求,原图链接地址为:https://3water.com/article/170023.htm

Django中的FBV和CBV用法详解

而上面的只处理了get和post,虽然我们可以再定义其他的函数和url来处理,或者通过if判断来进行区别对待,但这明显会显得麻烦,此时,我们可以使用CBV来解决这个问题。

CBV

CBV,即 class base views,类视图,在视图里使用类处理请求。

CBV代码可以解决诸多请求方式的问题,具备可读性,同时也更加符合面向对象编程。

使用CBV完成注册

CBV注册代码

from django.shortcuts import render, redirect, HttpResponse
from django.views.generic import View
from django.core.urlresolvers import reverse
from django.core.mail import send_mail
from django.contrib.auth import authenticate, login
from itsdangerous import TimedJSONWebSignatureSerializer as Serializer
from itsdangerous import SignatureExpired
import re
from django.conf import settings
import user.models as models
class RegisterView(View):
 """注册视图"""
 def get(self, request):
 """返回注册页面"""
 return render(request, "register.html")
 def post(self, request):
 """进行注册处理"""
 # 接收数据
 username = request.POST.get("user_name")
 password = request.POST.get("pwd")
 email = request.POST.get("email")
 allow = request.POST.get("allow")
 # 进行数据校验,all方法可以进行迭代,如果有内容为空的,返回false
 if not all([username, password, email]):
  # 数据不完整
  return render(request, "register.html", {"errormsg": "数据不完整"})
 # 邮箱校验
 if not re.match(r'[a-z0-9][\w.\-]*@[a-z0-9\-]+(\.[a-z]{2,5}){1,2}$', email):
  # 邮箱不合法
  return render(request, "register.html", {"errormsg": "邮箱格式不正确"})
 # 协议是否同意校验
 if allow != "on":
  # 用户不同意协议
  return render(request, "register.html", {"errormsg": "请同意协议"})
 # 校验用户名是否重复
 try:
  user = models.User.objects.get(username=username)
 except models.User.DoesNotExist:
  # 用户名不存在
  user = None
 if user:
  return render(request, "register.html", {"errormsg": "用户名已存在"})
 # 进行业务处理:进行用户注册
 # 使用Django默认的认证系统
 user = models.User.objects.create_user(username, email, password)
 # 因为默认注册后用户是激活的,得进行修改
 user.is_active = 0
 user.save()
 # 发送激活邮件,包括激活链接:http://127.0.0.1:8000/user/active/3
 # 激活链接中需要包含用户的身份信息,并且要把身份信息进行加密
 # 加密用户的身份信息,生成激活token
 serializer = Serializer(settings.SECRET_KEY, 1800)
 info = {'confirm': user.id}
 token = serializer.dumps(info)
 token = token.decode()
 # 发邮件
 subject = "绿色果园欢迎信息"
 message = ""
 sender = settings.EMAIL_FROM
 receiver = [email]
 html_message = "<h2>%s, 欢迎你成为绿色果园注册会员</h2></br>请点击以下链接激活账号<a href='http:127.0.0.1:8000/" \
   "user/active/%s'>http:127.0.0.1:8000/user/active/%s</a>" % (username, token, token)
 send_mail(subject, message, sender, receiver, html_message=html_message)
 # 返回应答,跳转到首页
 return redirect(reverse("goods:index"))

配套url

from user.views import RegisterView
urlpatterns = [
 url(r'^register/$', RegisterView.as_view(), name="register"), # 注册
]

总结

以上所述是小编给大家介绍的Django中的FBV和CBV用法详解,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的!

Python 相关文章推荐
Python2.x版本中maketrans()方法的使用介绍
May 19 Python
Python 专题二 条件语句和循环语句的基础知识
Mar 19 Python
python爬取w3shcool的JQuery课程并且保存到本地
Apr 06 Python
Python基于列表list实现的CRUD操作功能示例
Jan 05 Python
Python多项式回归的实现方法
Mar 11 Python
python设计微型小说网站(基于Django+Bootstrap框架)
Jul 08 Python
Python3 requests文件下载 期间显示文件信息和下载进度代码实例
Aug 16 Python
python实现文件的分割与合并
Aug 29 Python
Python 输出详细的异常信息(traceback)方式
Apr 08 Python
django使用JWT保存用户登录信息
Apr 22 Python
pymysql之cur.fetchall() 和cur.fetchone()用法详解
May 15 Python
详解Django的MVT设计模式
Apr 29 Python
Python爬虫实现使用beautifulSoup4爬取名言网功能案例
Sep 15 #Python
Python爬虫实现的根据分类爬取豆瓣电影信息功能示例
Sep 15 #Python
Python实现的爬取豆瓣电影信息功能案例
Sep 15 #Python
Python数据库小程序源代码
Sep 15 #Python
python中树与树的表示知识点总结
Sep 14 #Python
python树的同构学习笔记
Sep 14 #Python
python图形绘制奥运五环实例讲解
Sep 14 #Python
You might like
使用php判断网页是否gzip压缩
2013/06/25 PHP
php数组使用规则分析
2015/02/27 PHP
PHP的swoole扩展安装方法详细教程
2016/05/18 PHP
Yii数据读取与跳转参数传递用法实例分析
2016/07/12 PHP
PHP实现下载远程图片保存到本地的方法
2017/06/19 PHP
浅谈PHP中如何实现Hook机制
2017/11/14 PHP
Laravel框架路由管理简单示例
2019/05/07 PHP
PHP的new static和new self的区别与使用
2019/11/27 PHP
让你的PHP,APACHE,NGINX支持大文件上传
2021/03/09 PHP
解javascript 混淆加密收藏
2009/01/16 Javascript
jWiard 基于JQuery的强大的向导控件介绍
2011/10/28 Javascript
jQuery建立一个按字母顺序排列的友好页面索引(兼容IE6/7/8)
2013/02/26 Javascript
jquery struts 验证唯一标识(公用方法)
2013/03/27 Javascript
编写高效jQuery代码的4个原则和5个技巧
2014/04/24 Javascript
js浏览器本地存储store.js介绍及应用
2014/05/13 Javascript
jQuery根据ID获取input、checkbox、radio、select的示例
2014/08/11 Javascript
jQuery 跨域访问解决原理案例详解
2016/07/09 Javascript
详解如何使用vue-cli脚手架搭建Vue.js项目
2017/05/19 Javascript
jQuery中.attr()和.data()的区别分析
2017/09/03 jQuery
vue3.0 CLI - 3.2 路由的初级使用教程
2018/09/20 Javascript
一步步教你利用Docker设置Node.js
2018/11/20 Javascript
微信小程序实现简单文字跑马灯
2020/05/26 Javascript
在Python的循环体中使用else语句的方法
2015/03/30 Python
教你学会使用Python正则表达式
2017/09/07 Python
Python 忽略warning的输出方法
2018/10/18 Python
Python Django的安装配置教程图文详解
2019/07/17 Python
python写一个随机点名软件的实例
2019/11/28 Python
Python selenium爬虫实现定时任务过程解析
2020/06/08 Python
Python持续监听文件变化代码实例
2020/07/22 Python
PHP如何删除一个Cookie值
2012/11/15 面试题
校园十大歌手策划书
2014/02/01 职场文书
公立医院改革实施方案
2014/03/14 职场文书
心理健康日活动总结
2014/05/08 职场文书
军事理论课感想
2015/08/11 职场文书
导游词之河姆渡遗址博物馆
2019/10/10 职场文书
MySQL系列之九 mysql查询缓存及索引
2021/07/02 MySQL