当前位置: 首页 > wzjs >正文

h5自适应网站建设郑州网站seo外包

h5自适应网站建设,郑州网站seo外包,什么叫做电商平台,大连品牌网站建设公司【Django restframework】django跨域问题,解决PUT/PATCH/DELETE用ajax请求无法提交数据的问题 1 问题描述: 我用restframework(ModelSerializerGenericApiView)开发了一组符合RestFul接口标准的接口,这意味着它将支持客户端发来的GET、POST、…

【Django restframework】django跨域问题,解决PUT/PATCH/DELETE用ajax请求无法提交数据的问题


1 问题描述:

我用restframework(ModelSerializer+GenericApiView)开发了一组符合RestFul接口标准的接口,这意味着它将支持客户端发来的GET、POST、PATCH、PUT、DELETE请求,分别对某一资源进行获取、创建、部分修改、全部修改、删除操作。
在进行前后端联调的时候,我遇到了跨域问题:ccess to XMLHttpRequest at ‘http://127.0.0.1:8000/book/’ from origin ‘http://localhost:63342’ has been blocked by CORS policy: No ‘Access-Control-Allow-Origin’ header is present on the requested resource
于是我使了用第三方库django-cors-headers,并在settings中做了一些配置。此时,GET、POST请求(简单请求)可以正常的提交与请求数据,但是PUT请求提示:net::ERR_CONNECTION_ABORTED,浏览器返回NetworkError: Failed to execute ‘send’ on ‘XMLHttpRequest’: Failed to load
在这里插入图片描述
我很困惑,并不清楚为什么跨域请求资源只允许提交GET/POST请求,因为之前我已在后端做好了一系列配置。这个问题困扰了我两天,期间我尝试了各种方法,包括自定义CORS中间件、重写ajax提交PUT请求的方式等,都没有解决PUT无法提交的问题。终于,我找到了一个办法,并且成功了。

我的服务器是Windows Server2016


2 解决办法:

2.1 解决方法综述

① 前端用POST请求替代PUT/DELETE,并且在header中定义`X-HTTP-Method-Override:PUT`
② 后端引入python第三方库`django-method-override`,它用于识别前端http请求header中的X-HTTP-Method-Override参数值,并将它与相应的视图对应起来。

2.2 解决方法实行

2.2.1 前端

前端我用的是jQuery ajax来发起PUT请求,我做了以下配置:

$.ajax({url: 'yourUrl',type: 'POST',   // 此处必须是POSTheaders: {'X-HTTP-Method-Override': 'PUT',  // 此处是实际的请求方式 对应后端视图可接受的请求方式'accept': 'application/json',  // 这也是必须的},data: JSON.stringify({'name': name,'mobile': mobile,'province': province,}),dataType: 'json',contentType: 'application/json',async: false,crossDomain: true,success: function (res) {// 成功的操作},error: function (res) {// 失败的操作}
})
2.2 后端的配置

第一步:安装django-method-override

pip install django-method-override

第二步:重写项目配置文件settings.py

INSTALLED_APPS = ['corsheaders','method_override',  # 新增的# ...
]MIDDLEWARE = ['corsheaders.middleware.CorsMiddleware',# ...'django.middleware.csrf.CsrfViewMiddleware','method_override.middleware.MethodOverrideMiddleware',  # 新增method_override中间件,注意在CSRF之下# ...
]

第三步:重启项目
成功提交,并且成功的更新了数据库。
在这里插入图片描述


目前我只尝试了PUT请求,PATCH和DELETE还未用此法进行测试。如果有问题我将回来更新这篇文章,希望能对大家解决此问题提供一些思路。
PATCH也已经用这种方法试过了,没有问题,可以正常提交。

http://www.dtcms.com/wzjs/143876.html

相关文章:

  • 杭州专业网站排名优化看今天的新闻
  • 360提交网站备案ttkefu在线客服系统官网
  • 中文域名网站好不好优化怎么免费自己做推广
  • 平面设计网上培训机构快速将网站seo
  • 做淘宝要网站?无锡百度公司王东
  • 怎么做百度搜到的网站免费的seo和sem的区别是什么?
  • 网站制作协议书友好链接
  • 集团网站建设需求自助建站网
  • java网站开发优缺点百度指数的使用
  • 做网站的思路产品线上推广渠道
  • 知名跟单网站做信号提供方百度竞价是什么工作
  • 厦门seo报价惠州百度seo在哪
  • 东营网站制作团队网盘资源搜索神器
  • 成都高标建设有限公司官方网站今天的新闻 联播最新消息
  • 在线qq登录入口太原seo计费管理
  • 可以网上做单的网站谷歌ads广告投放
  • net 网站开发整站优化方案
  • 平面设计做兼职网站qq引流推广软件哪个好
  • 附近的装修公司地点网站优化有哪些类型
  • cc域名做网站怎么样百度小说风云榜排名
  • 自己做ppt网站吗软文是什么
  • 哪里购买网站空间灰色词排名推广
  • 湖南微信网站东莞seo代理
  • 专注高密做网站的推广产品怎么发朋友圈
  • 巢湖网站开发网站运营推广的方法有哪些
  • 如果安装wordpress主题成都爱站网seo站长查询工具
  • 佛山 顺德网站设计广州seo推广培训
  • 什么公司时候做网站广州权威发布
  • 网站运营怎样做百度收录网站链接入口
  • 企业网站 程序网站优化推广招聘