最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

pythonDjango框架实现自定义表单提交

来源:动视网 责编:小采 时间:2020-11-27 14:35:41
文档

pythonDjango框架实现自定义表单提交

pythonDjango框架实现自定义表单提交:除了使用Django内置表单,有时往往我们需要自定义表单。对于自定义表单Post方式提交往往会带来由CSRF(跨站请求伪造)产生的错误CSRF verification failed. Request aborted. 本篇文章主要针对表单提交和Ajax提交两种方式来解决CSRF带来的错
推荐度:
导读pythonDjango框架实现自定义表单提交:除了使用Django内置表单,有时往往我们需要自定义表单。对于自定义表单Post方式提交往往会带来由CSRF(跨站请求伪造)产生的错误CSRF verification failed. Request aborted. 本篇文章主要针对表单提交和Ajax提交两种方式来解决CSRF带来的错


除了使用Django内置表单,有时往往我们需要自定义表单。对于自定义表单Post方式提交往往会带来由CSRF(跨站请求伪造)产生的错误"CSRF verification failed. Request aborted."

本篇文章主要针对"表单提交"和"Ajax提交"两种方式来解决CSRF带来的错误

一、表单提交
Template:




 
 计算数字和


 


Views.py:

def Calculate(request):
 if request.POST:
 a=request.POST["ValueA"]
 b=request.POST["ValueB"]
 c=str(int(a)+int(b))
 return render_to_response('Result.html',{'result':c})
 else:
 return render_to_response('Calculation.html',context_instance=RequestContext(request))

需要注意:

(1)在

标签内添加{% csrf_token %},这样在表单提交的过程中,会产生"csrfmiddlewaretoken"标识去防止CSRF

(2)在Get请求页面时,需要添加context_instance=RequestContext(request) ,它和{% csrf_token %}配合使用,缺少一个都会出现上述错误,RequestContext 需要在 django.shortcuts 导入

(3)只有当表单以Post方式提交时,才需要验证CSRF,Get方式是不需要的

二、Ajax提交
同比与表单提交,Ajax提交需要进行额外的操作,Ajax提交时需要自己提供"csrfmiddlewaretoken"标识参数。我们除了需要引入JQuery外还需要引入一段JS代码

Template:




 
 Ajax 提交
 
 
 jQuery(document).ajaxSend(function(event, xhr, settings) {
 function getCookie(name) {
 var cookieValue = null;
 if (document.cookie && document.cookie != '') {
 var cookies = document.cookie.split(';');
 for (var i = 0; i < cookies.length; i++) {
 var cookie = jQuery.trim(cookies[i]);
 // Does this cookie string begin with the name we want?
 if (cookie.substring(0, name.length + 1) == (name + '=')) {
 cookieValue = decodeURIComponent(cookie.substring(name.length + 1));
 break;
 }
 }
 }
 return cookieValue;
 }
 function sameOrigin(url) {
 // url could be relative or scheme relative or absolute
 var host = document.location.host; // host + port
 var protocol = document.location.protocol;
 var sr_origin = '//' + host;
 var origin = protocol + sr_origin;
 // Allow absolute or scheme relative URLs to same origin
 return (url == origin || url.slice(0, origin.length + 1) == origin + '/') ||
 (url == sr_origin || url.slice(0, sr_origin.length + 1) == sr_origin + '/') ||
 // or any other URL that isn't scheme relative or absolute i.e relative.
 !(/^(//|http:|https:).*/.test(url));
 }
 function safeMethod(method) {
 return (/^(GET|HEAD|OPTIONS|TRACE)$/.test(method));
 }
 
 if (!safeMethod(settings.type) && sameOrigin(settings.url)) {
 xhr.setRequestHeader("X-CSRFToken", getCookie('csrftoken'));
 }
});
 
 
结果为:

View.py:

def AjaxRequest(request):
 if request.POST:
 a =request.POST["a"]
 b=request.POST["b"]
 c=int(a)+int(b)
 return JsonResponse(c,safe=False)
 else:
 return render_to_response('AjaxDemo.html',context_instance=RequestContext(request))

需要注意:

(1)在使用引入的JS代码后,需要添加如下代码,这样JS就可以自动帮我们生成"csrfmiddlewaretoken"标识,接下来你就可以使用$.post()了

$.ajaxSetup({
 data:{csrfmiddlewaretoken: '{{ csrf_token }}'}
 });

(2)context_instance=RequestContext(request) 并不是必须的

(3)Get请求不需要以上操作,直接使用$.get()即可
注:本文使用的Django1.8.3版本进行测试。

文档

pythonDjango框架实现自定义表单提交

pythonDjango框架实现自定义表单提交:除了使用Django内置表单,有时往往我们需要自定义表单。对于自定义表单Post方式提交往往会带来由CSRF(跨站请求伪造)产生的错误CSRF verification failed. Request aborted. 本篇文章主要针对表单提交和Ajax提交两种方式来解决CSRF带来的错
推荐度:
标签: 开发 提交 表单
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top