网站首页 > 技术文章 正文
JSONP解决跨域
发送请求时动态创建一个Script标签,在Script标签中发出请求,通过这种变通的方式实现跨域。非官方协议,而是前后端进行一个约定,约定请求的参数里边必须包含某个参数,比如callback,callback为页面JS函数名,函数参数就是后台需要返回的结果,例如:callback("{\"pass\":true}").
JQUERY发送JSONP请求代码示例:
$.ajax({
url:"http://localhost:8080/getData/getSecondData",
dataType:"jsonp",
jsonp:"callback",
success:function(json){
console.log(json);
}
});
CORS跨域解决方案
CORS解释
CORS是W3C标准,全名叫跨域资源共享Cross-origin resource sharing,允许浏览器向跨域服务器发出 XMLHttpRequest 请求。
简单请求
在做跨域请求资源的时候,会发现多了Origin字段,如下:
Origin: http://www.baidu.com
尝试修改后台代码:
request.addHeader("Access-Control-Allow-Origin","http://www.baidu.com");
此时就可以跨域了
预检命令
非简单请求需要先执行预检命令,因此跨域分为两类:
- 简单请求,先执行请求,后判断
GET、HEAD、POST
- 非简单请求,先发送预检命令
PUT、DELETE、带JSON参数的请求、自定义头的请求
在预检的时候,比如发送JSON,会设置header content-type:application/json,这个header是不被允许的,需要在后台设置:
request.addHeader("Access-Control-Allow-Headers", "Content-Type")
另外,如果要自定义header头,也需要后台设置
携带cookie跨域请求
后台需要设置:
request.addHeader(“Access-Control-Allow-Credentials”,”true”);
发送请求时,需要设置XMLHttpRequest的withCredentials属性为true
自定义header头的请求
后台需要指定允许自定义头:
request.addHeader("Access-Control-Allow-Headers",headers);
猜你喜欢
- 2024-09-26 Docker入门教程(5):堆栈(堆栈 堆 栈)
- 2024-09-26 全面解决1045 Access denied for user 'root'@'localhost'
- 2024-09-26 超赞的开发者门户-Backstage(开发者平台)
- 2024-09-26 Dubbo No provider问题排查思路(dubbo报错)
- 2024-09-26 如何解决浏览器跨域问题?(浏览器跨域访问设置)
- 2024-09-26 客户端navicat遇到问题怎么办?(navicat登录)
- 2024-09-26 前端必备基础知识:window.location 详解
- 2024-09-26 浏览器的跨域问题该怎么解决?(浏览器跨域cors)
- 2024-09-26 技术文档 | /bin/ld: 找不到 -lselinux
- 2024-09-26 浏览器跨域问题以及常用解决方案(浏览器跨域cors)
- 1514℃桌面软件开发新体验!用 Blazor Hybrid 打造简洁高效的视频处理工具
- 573℃Dify工具使用全场景:dify-sandbox沙盒的原理(源码篇·第2期)
- 513℃MySQL service启动脚本浅析(r12笔记第59天)
- 486℃服务器异常重启,导致mysql启动失败,问题解决过程记录
- 486℃启用MySQL查询缓存(mysql8.0查询缓存)
- 469℃「赵强老师」MySQL的闪回(赵强iso是哪个大学毕业的)
- 449℃mysql服务怎么启动和关闭?(mysql服务怎么启动和关闭)
- 447℃MySQL server PID file could not be found!失败
- 最近发表
- 标签列表
-
- cmd/c (90)
- c++中::是什么意思 (83)
- 主键只能有一个吗 (66)
- c#console.writeline不显示 (75)
- pythoncase语句 (81)
- es6includes (73)
- windowsscripthost (67)
- apt-getinstall-y (86)
- node_modules怎么生成 (76)
- c++int转char (75)
- static函数和普通函数 (76)
- el-date-picker开始日期早于结束日期 (70)
- js判断是否是json字符串 (67)
- checkout-b (67)
- c语言min函数头文件 (68)
- asynccallback (71)
- localstorage.removeitem (74)
- vector线程安全吗 (70)
- & (66)
- java (73)
- js数组插入 (83)
- mac安装java (72)
- eacces (67)
- 查看mysql是否启动 (70)
- 无效的列索引 (74)