Django---view视图FBV&CBV
一:创建项目和应用:

或者用命令创建:
1:django-admin.py startproject CBV&FBV
2: cd CBV&FBV (路径切到该文件夹下)
3: python3 manage.py startapp app01
二:数据库迁移:

三:创建超级用户(做登录验证需要)

四 :分配路由 urls.py

五:登录验证视图函数 views.py----FBV(functiion Base Views)
方法一:
from django.shortcuts import render,HttpResponse,redirect
from django.contrib import auth # Create your views here. def index(request):
user = request.user
if user.is_authenticated:
return render(request,'index.html') return redirect('/login/') def log_in(request): if request.method == "POST":
user = request.POST.get('user')
password = request.POST.get('pwd') user_obj = auth.authenticate(username=user,password=password)
if user_obj: auth.login(request,user_obj)
return redirect('/index/')
return render(request,'login.html')
方法二:
或者在setting.py中加入:
LOGIN_URL=('/login/')
from django.shortcuts import render,HttpResponse,redirect
from django.contrib import auth
from django.contrib.auth.decorators import login_required # Create your views here. @login_required
def index(request):
return redirect('/login/') def log_in(request): if request.method == "POST":
user = request.POST.get('user')
password = request.POST.get('pwd') user_obj = auth.authenticate(username=user,password=password)
if user_obj: auth.login(request,user_obj)
return redirect('/index/')
return render(request,'login.html')
方法三:利用session
from django.shortcuts import render,HttpResponse,redirect
from django.contrib import auth # Create your views here. def index(request):
if request.session.get('user_info'):
return render(request,'index.html')
return redirect('/login/') def log_in(request):
if request.method == "POST":
user = request.POST.get('user')
password = request.POST.get('pwd')
user_obj = auth.authenticate(username=user,password=password)
# if user == 'root' and password=='root1234': (如果是用自己对数据库表,可以自己做判断。我这是直接用django的user表就直接用auth判断)
if user_obj:
request.session['user_info'] = user
return redirect('/index/')
return render(request,'login.html')
六:登录验证视图函数 views.py----CBV(Class Base Views)
urls.py:
from django.conf.urls import url
from django.contrib import admin
from app01 import views urlpatterns = [
url(r'^admin/', admin.site.urls),
url(r'^index', views.Index.as_view()),
url(r'login',views.Log_in.as_view()),
]
view.py
方法一:
from django.shortcuts import render,HttpResponse,redirect
from django.views import View
from django.contrib import auth class Index(View):
'''先走dispatch再走其它函数'''
def dispatch(self,request,*args,**kwargs):
print('before')
res = super(Index,self).dispatch(request,*args,**kwargs)
print('after')
return res def get(self,request,*args,**kwargs):
return render(request,'index.html') def post(self,request,*args,**kwargs):
return HttpResponse(99999) class Log_in(View):
def get(self,request,*args,**kwargs):
return render(request,'login.html') def post(self,request,*args,**kwargs):
user = request.POST.get('user')
password = request.POST.get('password')
user_obj = auth.authenticate(username=user,password=password)
if user_obj:
request.session['user_info']=user
return redirect('/index/') return render(request, 'index.html')
方法二:单独写个认证类,其余类继承该类
from django.shortcuts import render,HttpResponse,redirect
from django.views import View
from django.contrib import auth class AuthView(object):
def dispatch(self, request, *args, **kwargs):
if not request.session.get('user_info'):
return redirect('/login.html')
res = super(AuthView,self).dispatch(request, *args, **kwargs)
return res class Index(AuthView,View):
'''先走dispatch再走其它函数''' def get(self,request,*args,**kwargs):
return render(request,'index.html') def post(self,request,*args,**kwargs):
return HttpResponse(99999) class Log_in(AuthView,View):
def get(self,request,*args,**kwargs):
return render(request,'login.html') def post(self,request,*args,**kwargs):
user = request.POST.get('user')
password = request.POST.get('password')
user_obj = auth.authenticate(username=user,password=password)
if user_obj:
request.session['user_info']=user
return redirect('/index/')
return render(request, 'index.html')
方法三:装饰器:注意装饰器的写法
from django.shortcuts import render,HttpResponse,redirect
from django.views import View
from django.contrib import auth
from django.utils.decorators import method_decorator
from django.contrib.auth.decorators import login_required @method_decorator(login_required)
class Index(View):
'''先走dispatch再走其它函数'''
def get(self,request,*args,**kwargs):
return render(request,'index.html') def post(self,request,*args,**kwargs):
return HttpResponse(99999) class Log_in(View):
def get(self,request,*args,**kwargs):
return render(request,'login.html') def post(self,request,*args,**kwargs):
user = request.POST.get('user')
password = request.POST.get('password')
user_obj = auth.authenticate(username=user,password=password)
if user_obj:
request.session['user_info']=user
return redirect('/index/')
return render(request, 'index.html')
装饰器的用法:
装饰器
get, post方法上
class LoginView(View):
def dispatch(self, request, *args, **kwargs):
return super(LoginView, self).dispatch(request, *args, **kwargs) def get(self, request):
return render(request, 'login.html') @method_decorator(login_required)
def post(self, request):
# request.GET
# request.POST # 请求头中的:content-type
# request.body
user = request.POST.get('user')
pwd = request.POST.get('pwd')
if user == 'alex' and pwd == "alex3714":
# 生成随机字符串
# 写浏览器cookie: session_id: 随机字符串
# 写到服务端session:
# {
# "随机字符串": {'user_info':'alex}
# }
request.session['user_info'] = "alex"
return redirect('/index.html')
return render(request, 'login.html') dispatch方法上
class LoginView(View):
@method_decorator(login_required)
def dispatch(self, request, *args, **kwargs):
return super(LoginView, self).dispatch(request, *args, **kwargs) def get(self, request):
return render(request, 'login.html') def post(self, request):
# request.GET
# request.POST # 请求头中的:content-type
# request.body
user = request.POST.get('user')
pwd = request.POST.get('pwd')
if user == 'alex' and pwd == "alex3714":
# 生成随机字符串
# 写浏览器cookie: session_id: 随机字符串
# 写到服务端session:
# {
# "随机字符串": {'user_info':'alex}
# }
request.session['user_info'] = "alex"
return redirect('/index.html')
return render(request, 'login.html') 类上 @method_decorator(login_required, name='get')
class LoginView(View):
def dispatch(self, request, *args, **kwargs):
return super(LoginView, self).dispatch(request, *args, **kwargs) def get(self, request):
return render(request, 'login.html') def post(self, request):
# request.GET
# request.POST # 请求头中的:content-type
# request.body
user = request.POST.get('user')
pwd = request.POST.get('pwd')
if user == 'alex' and pwd == "alex3714":
# 生成随机字符串
# 写浏览器cookie: session_id: 随机字符串
# 写到服务端session:
# {
# "随机字符串": {'user_info':'alex}
# }
request.session['user_info'] = "alex"
return redirect('/index.html')
return render(request, 'login.html') 特殊:CSRF
Token只能加到dispatch
from django.views.decorators.csrf import csrf_exempt, csrf_protect
class LoginView(View):
@method_decorator(csrf_exempt)
def dispatch(self, request, *args, **kwargs):
return super(LoginView, self).dispatch(request, *args, **kwargs) def get(self, request):
return render(request, 'login.html')
def post(self, request):
# request.GET
# request.POST # 请求头中的:content-type
# request.body
user = request.POST.get('user')
pwd = request.POST.get('pwd')
if user == 'alex' and pwd == "alex3714":
# 生成随机字符串
# 写浏览器cookie: session_id: 随机字符串
# 写到服务端session:
# {
# "随机字符串": {'user_info':'alex}
# }
request.session['user_info'] = "alex"
return redirect('/index.html')
return render(request, 'login.html')
注:
form表单提交: GET,POST ***
Ajax提交数据: GET,POST
['get'获取, 'post'创建, 'put'更新, 'patch'局部更新, 'delete'删除, 'head', 'options', 'trace'] -> restful规范
Django请求的生命周期:
wsgi -> 中间件 -> 路由系统 -> 视图函数(ORM,Template,渲染)
- wsgiref
- uwsgi
Django---view视图FBV&CBV的更多相关文章
- Django 路由视图FBV/CBV
路由层 url路由层结构 from django.conf.urls import url from django.contrib import admin from app01 import vi ...
- Django view 视图
request.method 判断请求方式 8种 GET : 获取一个页面 POST: 提交数据 PUT : 上传 HEAD: 不用上传就获取数据 DELETE: 删除 Request-URL 标识的 ...
- Django View视图
视图view 一个视图函数(类),简称视图,是一个简单的Python 函数(类),它接受Web请求并且返回Web响应.响应可以是一张网页的HTML内容,一个重定向,一个404错误,一个XML文档,或者 ...
- django view 视图控制之数据返回的视图函数
八.视图 view 概述:views.py定义的python函数,它接受Web请求并且返回Web响应. 有几个页面就有几个视图view user出入url地址,发送request--->urls ...
- Django FBV/CBV、中间件、GIT使用
s5day82 内容回顾: 1. Http请求本质 Django程序:socket服务端 a. 服务端监听IP和端口 c. 接受请求 \r\n\r\n:请求头和请求体 \r\n & reque ...
- django FBV +CBV 视图处理方式总结
1.FBV(function base views) 在视图里使用函数处理请求. url: re_path('fbv', views.fbv), # url(r'^fbv' ...
- Django 学习视图之FBV与CBV
一. CBV与FBV CBV:Class Based View FBV:Function Based View 我们之前写过的都是基于函数的view,就叫FBV.还可以把view写成基于类的,那就是C ...
- python 视图 (FBV、CBV ) 、Request 和Response对象 、路由系统
一.FBV和CBV1.基于函数的view,就叫FBV(Function Based View) 示例: def add_book(request): pub_obj=models.Publisher. ...
- Django的View(视图)和路由系统
一.Django的View(视图) 1.介绍 一个视图函数(类),简称视图,是一个简单的Python 函数(类),它接受Web请求并且返回Web响应. 响应可以是一张网页的HTML内容,一个重定向,一 ...
随机推荐
- (C#)System.Security.SecureString(表示应保密的文本)
正常的String类型值,在脱离开作用域之后,其值在内存中并不会被立即销毁,这时如果有人恶意扫描你的内存,程序中所保存的机密信息就会暴露;于是就有了System.Security.SecureStri ...
- 我的第五个程序 java的JDBC连接mysql数据库 实现输入查询
import java.sql.*; import java.util.Scanner; public class JDBCTest { public static void main(String[ ...
- python 反射机制 ( 广泛应用于URL参数)
web实例 考虑有这么一个场景,根据用户输入的url的不同,调用不同的函数,实现不同的操作,也就是一个url路由器的功能,这在web框架里是核心部件之一.下面有一个精简版的示例: 首先,有一个comm ...
- Windows API之DuplicateHandle
在进程之间共享内核对象句柄的一种方法:DuplicateHandle 简单地说,该函数取得某个进程句柄表中的一个表项,然后把它拷贝到另一个进程的句柄表中. BOOL WINAPI DuplicateH ...
- iOS学习笔记(十二)——iOS国际化
开发的移动应用更希望获取更多用户,走向世界,这就需要应用国际化,国际化其实就是多语言.这篇文章介绍Xcode4.5以后的国际化,包括应用名国际化和应用内容国际化.如果是Xcode4.5之前版本请参考. ...
- 【BZOJ1823】[JSOI2010]满汉全席 2-SAT
[BZOJ1823][JSOI2010]满汉全席 Description 满汉全席是中国最丰盛的宴客菜肴,有许多种不同的材料透过满族或是汉族的料理方式,呈现在數量繁多的菜色之中.由于菜色众多而繁杂,只 ...
- EasyNVR摄像机无插件直播如何排查视频广场不在线
通道配置完成进入视频广场监控通道显示不在线 保证RTSP视频流地址是否可用,推荐用VLC先测试地址是否可用.(注意:软件本身只支持标准的RTSP视频流地址.) 如果是刚配置完需要等大概几秒左右有的网络 ...
- margin 依附与可见的内容,不能为margin而写margin
margin 依附于可见的内容,不能为margin而写margin <!DOCTYPE html><html><head><style> p{marg ...
- 是面向对象设计五个基本原则(SOLID)
单一职责原则 - 搜狗百科 https://baike.sogou.com/v51360965.htm 单一职责原则并不是一个孤立的面向对象设计原则,它是面向对象设计五个基本原则(SOLID)之一.这 ...
- JavaSctipt语句for循环的思考
一.语法 for (语句 1; 语句 2; 语句 3) { 被执行的代码块; } 语句 1: 在循环(代码块)开始前执行, 可选. 语句 2: 定义运行循环(代码块)的条件, 可选, 如果省略了语句 ...