通用视图-分开处理GET、POST请求
1.编辑urls.py:
url(r'^vmmgmt-vms/$', views.vmmgmt,{'model':models.hvvms,'GET': views.vmmgmt_get_view,'POST': views.vmmgmt_post_view},name='vmmgmt-vms'), #vmmgmt view接收model,GET,POST参数
url(r'^vmmgmt-hv/$', views.vmmgmt,{'model':models.hvsrvs,'GET': views.vmmgmt_get_view,'POST': views.vmmgmt_post_view},name='vmmgmt-hv'),
url(r'^vmmgmt-vhd/$', views.vmmgmt,{'model':models.hvvhds,'GET': views.vmmgmt_get_view,'POST': views.vmmgmt_post_view},name='vmmgmt-vhd'),
2.编辑views.py:
#split get and post requests.
def vmmgmt(request,*args,**kwargs): #从url接收参数,用于区分GET、POST请求
vmmgmt_get_view = kwargs.pop('GET', None) #return None if GET not exists.
vmmgmt_post_view = kwargs.pop('POST', None)
model = kwargs.pop('model', None) #获取当前model
if request.method == 'GET' and vmmgmt_get_view is not None: #GET请求返回到vmmgmt_get_view()函数进行处理
return vmmgmt_get_view(request, model) #将model传递到get view
elif request.method == 'POST' and vmmgmt_post_view is not None:
return vmmgmt_post_view(request, model)
#return vmmgmt_post_view(request, *args, **kwargs)
raise Http404 #handle get request.
def vmmgmt_get_view(request,model):
obj_list = model.objects.all() #从url中的 model 参数接收到具体的model类。模板中要使用 obj_list 变量做for循环
counts = model.objects.count()
assert request.method == 'GET'
if 'q-hv' in request.GET:
qdata = request.GET['q-hv']
if qdata is not None:
obj_list = model.objects.filter(serverip__icontains=qdata)
counts = len(obj_list) if 'q-vms' in request.GET: #Query vm infors.
qdata = request.GET['q-vms']
if qdata is not None:
obj_list = model.objects.filter(Name__icontains=qdata)
print obj_list
counts = len(obj_list) context={'obj_list':obj_list,'counts':counts}
template_name = 'sinfors/vmmgmt_%s.html' % model.__name__.lower() # 每个Python的类都有一个 __name__ 属性返回类名。 这特性在当我们直到运行时刻才知道对象类型的这种情况下很有用。 比如, hvvms 类的 __name__ 就是字符串 'hvvms' 。
#return render_to_response(template_name,context) #无法接收csrfmiddretoken参数
return render(request,template_name,context) #handle post request.
def vmmgmt_post_view(request,model):
assert request.method == 'POST'
if request.POST['posttype'].strip() == 'hvservers_update_create': #update hv servers infors.
sdict = {}
sdict['serverip'] = request.POST['serverip'].strip()
sdict['servername'] = request.POST['servername'].strip()
model.objects.update_or_create(serverip=sdict['serverip'],defaults=sdict)
return HttpResponse(json.dumps({'sts':"修改成功"})) if request.POST['posttype'].strip() == 'vhds_update_create': #update vhd servers infors.
sdict = {}
sdict['vhdname'] = request.POST['vhdname'].strip()
sdict['vhdpath'] = request.POST['vhdpath'].strip()
model.objects.update_or_create(vhdname=sdict['vhdname'],defaults=sdict)
return HttpResponse(json.dumps({'sts':"修改成功"})) if request.POST['posttype'].strip() == 'del': #delete infors.
datas_del = request.POST.getlist('datas_del')
for i in datas_del:
item = model.objects.get(pk=i)
time.sleep(0.1)
item.delete()
return HttpResponse(json.dumps({'sts':"删除成功"})) context={'obj_list':obj_list,'counts':counts}
template_name = 'sinfors/vmmgmt_%s.html' % model.__name__.lower() # 每个Python的类都有一个 __name__ 属性返回类名。 这特性在当我们直到运行时刻才知道对象类型的这种情况下很有用。 比如, hvvms 类的 __name__ 就是字符串 'hvvms' 。
#return render_to_response(template_name,context) #无法接收csrfmiddretoken参数
return render(request,template_name,context)
参考:http://djangobook.py3k.cn/2.0/chapter08/ method_splitter(request, *args, **kwargs)
通用视图-分开处理GET、POST请求的更多相关文章
- Django创建通用视图函数
想在我们有两个视图: def thinkingview(request): user = request.user if request.method == 'GET': return render( ...
- Django 1.6 基于类的通用视图
Django 1.6 基于类的通用视图 最初 django 的视图都是用函数实现的,后来开发出一些通用视图函数,以取代某些常见的重复性代码.通用视图就像是一些封装好的处理器,使用它们的时候只须要给出特 ...
- Django通用视图执行过程
使用通用视图后,Django请求处理过程(以ListView为例):在我们自定义的视图中: class IndexView(ListView): template_name = 'blog/index ...
- 5 第一个Django第4部分(表单和通用视图)
上一节完成了视图编写,这一节为应用添加投票功能,也就是表单提交. 5.1编写一个简单的表单 5.2使用通用视图 5.3改良视图 5.1编写一个简单的表单 在网页设计中添加Form元素 polls/te ...
- Django通用视图APIView和视图集ViewSet的介绍和使用
原 Django通用视图APIView和视图集ViewSet的介绍和使用 2018年10月21日 14:42:14 不睡觉假扮古尔丹 阅读数:630 1.APIView DRF框架的视图的基类是 ...
- Python Django CBV下的通用视图函数
ListView TemplateView DetailView 之前的代码实例基本上都是基于FBV的模式来撰写的,好处么,当然就是简单粗暴..正如: def index(request): retu ...
- Django 基于类的通用视图
在早期,我们认识到在视图开发过程中有共同的用法和模式.这时我们引入基于函数的通用视图来抽象这些模式以简化常见情形的视图开发. 基于函数视图的用法有以下三种: def index(request): r ...
- django通用视图
通用视图 1. 前言 回想一下,在Django中view层起到的作用是相当于controller的角色,在view中实施的 动作,一般是取得请求参数,再从model中得到数据,再通过数据创建模板,返回 ...
- Django 1.10中文文档-第一个应用Part4-表单和通用视图
本教程接Part3开始.继续网页投票应用程序,并将重点介绍简单的表单处理和精简代码. 一个简单表单 更新一下在上一个教程中编写的投票详细页面的模板polls/detail.html,让它包含一个HTM ...
随机推荐
- 23-hadoop-hive的DDL和DML操作
跟mysql类似, hive也有 DDL, 和 DML操作 数据类型: https://cwiki.apache.org/confluence/display/Hive/LanguageManual+ ...
- tomcat关闭后线程依然运行解决办法
tomcat关闭后线程依然运行解决办法,设置线程为守护线程 守护线程与非守护线程 最近在看多线程的Timer章节,发现运用到了守护线程,感觉Java的基础知识还是需要补充. Java分为两种线程:用户 ...
- MySQL的视图view,视图创建后,会随着表的改变而自动改变数据
首先是创建视图 CREATE ALGORITHM=UNDEFINED DEFINER=`root`@`localhost` SQL SECURITY DEFINER VIEW `new_view` A ...
- 二叉树的递归,非递归遍历(java)
import java.util.Stack; import java.util.HashMap; public class BinTree { private char date; private ...
- 海量数据处理之Tire树(字典树)
参考博文:http://blog.csdn.net/v_july_v/article/details/6897097 第一部分.Trie树 1.1.什么是Trie树 Trie树,即字典树,又称单词查找 ...
- openerp7 时区问题解决--改成本地时区
由于目前openerp的时区,读取的是UTC时间,而我国本地时间比UTC快8小时 问题就导致,写入数据库的时候时间相差8小时,以及Openerp日志输出时间格式也相差8小时和前端显示问题 1.更改op ...
- C字符串
C字符串 C中的字符串是以空字符('\0')结尾的一个char数组,基本的实现字符串的方法有:字符串常量,字符串数组,char数组,char指针.字符串使用广泛,如与用户交互等处理自然语言的情况.C为 ...
- Spring基础(2):bean顺序创建
public class Person{ public Person(){ System.out.println("Person person person ..."); } } ...
- [日常] Go语言圣经-函数递归习题
练习 5.1: 修改findlinks代码中遍历n.FirstChild链表的部分,将循环调用visit,改成递归调用. 练习 5.2: 编写函数,记录在HTML树中出现的同名元素的次数. 练习 5. ...
- Java并发编程-移相器
移相器(Phaser)内有2个重要状态,分别是phase和party.phase就是阶段,初值为0,当所有的线程执行完本轮任务,同时开始下一轮任务时,意味着当前阶段已结束,进入到下一阶段,phase的 ...