thinkphp,javascript跨域请求解决方案
javascript跨域请求解决方案
前言
- 对于很多前端或者做混合开发的同学,我们难免会遇到跨域发起请求业务,比如A站点向B站点请求数据等等。由于最近要做一个站点集群的项目,所以具体业务要求很多个站点之间的消息推送,所以难免要做跨域请求。
- 这两天我在度娘上面用 “javascript php 跨域 ajax”等关键字找了好几遍,发现真的没有一篇博客写出一个具体的解决方案(ps.最多的方案基本都是选择jsonp,我相信get满足不了大家的吧?),所以我觉得总结一下我自己遇到的坑(其实是自己修炼不够,我会乱说?),以后少走弯路。
跨域方案
下面是我这几天摸索出来的一些具体的解决方案,大家可以参照自己的具体业务逻辑来选用不同的解决方案。
### jsonp
***
- 我知道程序员都是猴急的人(摆脱不了猿类的本性 - -!),所以按照惯例我们先贴代码:
- 客户端:
$.post('http://a.com',//接口URL地址
{
"username":"张三"//这里写你向服务器端发送的数据
},
function(data){
console.log(data);
//回调,这里是服务器端返回的数据
//这就是普通的json了
},'jsonp');
- 服务器端:
$callback = $_GET['callback'];
$username = $_GET['usernae'];
if(!empty($callback)){
$data = $username;//这是你业务逻辑处理好的数据,一般是个数组
header('Content-Type:Application/json;charset=utf-8');//必须设置
echo $callback.'('.json_encode($data).')';
exit();
}else{
exit('Access Denied!');//异常抛错
}
- 以上方案我是参照http://blog.chinaunix.net/uid-18899774-id-3915566.html的个人博客,他是解决extjs跨域问题,但是用在其他原生js亲试没有错误
- 注意事项
***
- 我知道程序员都是猴急的人(摆脱不了猿类的本性 - -!),所以按照惯例我们先贴代码:
- 客户端:
$.post('http://a.com',//接口URL地址
{
"username":"张三"//这里写你向服务器端发送的数据
},
function(data){
console.log(data);
//回调,这里是服务器端返回的数据
//这就是普通的json了
},'jsonp');
- 服务器端:
$callback = $_GET['callback'];
$username = $_GET['usernae'];
if(!empty($callback)){
$data = $username;//这是你业务逻辑处理好的数据,一般是个数组
header('Content-Type:Application/json;charset=utf-8');//必须设置
echo $callback.'('.json_encode($data).')';
exit();
}else{
exit('Access Denied!');//异常抛错
}
- 以上方案我是参照http://blog.chinaunix.net/uid-18899774-id-3915566.html的个人博客,他是解决extjs跨域问题,但是用在其他原生js亲试没有错误
- 注意事项
ajax(jsonp的另外一种写法)
- 按照管理先抛代码,客户端:
$.ajax({
url: 'http://example.com',//请求地址
type: 'POST',
data: { id: idValue },
//调小超时时间会引起异常
timeout: 3000,
//请求成功后触发
dataType:jsonp,
success: function (data) { show.append('success invoke!' + data+'
'); },
//请求失败遇到异常触发
error: function (xhr, errorInfo, ex) { show.append('error invoke!errorInfo:' + errorInfo+'
'); },
//完成请求后触发。即在success或error触发后触发
complete: function (xhr, status) { show.append('complete invoke! status:' + status+'
'); },
//发送请求前触发
beforeSend: function (xhr) {
//可以设置自定义标头
xhr.setRequestHeader('Content-Type', 'application/xml;charset=utf-8');
show.append('beforeSend invoke!' +'
');
},
//是否使用异步发送
async: true
})
- 服务器端代码跟第一种写法一样
cors
- 我相信很多人跟我一样,找跨域的相关资料的时候,大神们总是摔下一句“CORS Can Solve It!”然后就没有下文了,国内文档更是是说一个单词“CORS!”,好吧,像我这样的小白找半天,终于找到找好梯子,自行google到cors的具体用法,如下:
- 客户端:
function test(){
var xhr = new XMLHttpRequest();
xhr.open("POST", "http://www.example.com", true);
xhr.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded');
textdata = {
"username":"张三",
"num":"1",
"sex":"boy"
};
var testdata = JSON.stringify(textdata);
var getdata = "data=" + testdata;
xhr.send(getdata);
xhr.onreadystatechange = function() {
//如果执行状态成功,那么就把返回信息写到指定的层里
if (xhr.readyState == 4 && xhr.status == 200) {
var data = xhr.responseText;
$obj = eval('(' + data + ')');
console.log($obj);
}
}
}
- 服务器端:
public function test(){
$data = $_POST['data'];//接收POST数据
$jsonData = json_decode($data,true);//把接收到的数据封装成数组形式
//查看是否已经存在当前用户
//$name = $jsonData['uuid']; //调取相应数据
$outputdata['status'] = $jsonData;
$this->ajaxReturn($outputdata);//我这里是thinkphp框架封装好的返回调用
}
- 注意事项:
1.在服务器端里面加上请求头部信息:header('Access-Control-Allow-Origin: *');,允许任何站点访问,这里也可设置只允许某一个站点跨域访问。
2.还需要注意的是,在客户端需要先把数据变成json字符串形式在传到服务器端。
总结
- 以上就是javascript跨域请求的全部内容。
- 如果有任何疑问或者建议,请联系作者的个人邮箱(dream_zk2014@sohu.com)
- 转发请注明出处 dreamzk.cn
thinkphp,javascript跨域请求解决方案的更多相关文章
- cors跨域和jsonp劫持漏洞 和 同源策略和跨域请求解决方案
cors跨域和jsonp劫持漏洞: https://www.toutiao.com/a6759064986984645127/ 同源策略和跨域请求解决方案:https://www.jianshu.co ...
- ajax跨域请求解决方案
大家好,今天我们学习了js的跨域请求的解决方案,由于JS中存在同源策略,当请求不同协议名,不同端口号.不同主机名下面的文件时,将会违背同源策略,无法请求成功!需要进行跨域处理! 方案一.后台PHP进行 ...
- Javascript 跨域访问解决方案 总结
在客户端编程语言中,如javascript和ActionScript,同源策略是一个很重要的安全理念,它在保证数据的安全性方面有着重要的意义.同 源策略规定跨域之间的脚本是隔离的,一个域的脚本不能访问 ...
- js跨域请求解决方案
什么是跨域? 跨域是指一个域下的文档或脚本试图去请求另一个域下的资源,这里跨域是广义的. 广义的跨域: 1.) 资源跳转: A链接.重定向.表单提交 2.) 资源嵌入: <link>.&l ...
- 优雅绝妙的Javascript跨域问题解决方案
关于Javascript跨域问题的解决方案已在之前的一片文章中详细说明,详见:http://blog.csdn.net/sfdev/archive/2009/02/13/3887006.aspx: 除 ...
- thinkphp 设置跨域请求
场景:我的本地网页服务器无法访问本地的接口服务器接口提示一下错误:大致意思是:是一个跨域请求我的没有访问该地址的权限(接口服务器采用的是PHP编写) XMLHttpRequest cannot loa ...
- Javascript跨域请求的几种解决方法
什么情况下才会出现跨域? 假设域名是:http://www.example.com.cn/ 如果所请求的域名跟这个域名不致,这种情况就是跨域,由于跨域存在漏洞,所以一般来说正常的跨域请求方式是请求不到 ...
- jquery跨域请求解决方案(我们寻找,我还没有添加验证)
http://www.3lian.com/edu/2014/02-10/127921.html 本篇文章仅仅要是对jquery ajax跨域解决方法(json方式)进行了介绍,须要的朋友能够过来參考下 ...
- javascript 跨域请求详细分析(终极跨域解决办法)
自从我接触前端以来,接手的项目里面很大部分都是前后端分离的,后端只提供接口,前端根据后端接口渲染出实际页面.个人觉得这是一个挺好的模式,前后端各自负责各自的模块,分工明确,而且也给前端更大的发挥空间. ...
随机推荐
- (剑指Offer)面试题31:连续子数组的最大和
题目: 输入一个整型数组,数组里有正数也有负数,数组中一个或连续多个整数组成一个子数组,求所有子数组的和的最大值.要求时间复杂度为O(n) 思路: 1.数组累加 从头到尾逐个累加数组中的每个数字,当累 ...
- win7和linux下的文件共享
在vmware虚拟机下安装linux系统,如果自个电脑的win7设置成自动获取IP的话,每次使用FTP文件传输服务器都要检查win7和linux系统的IP是否处于同一网段,如果不是还要手动设置.再有一 ...
- cocos2dx 兼容性
报错: Caused by: java.lang.UnsatisfiedLinkError: Couldn't load cocos2dcpp: findLibrary returned null 因 ...
- c语言操作符 “++”另类行为
正常情况下,我们使用++ int a = 1; a++; printf(“%d”,a); // 2; 很简单没什么好说的. #include <stdio.h> int main() ...
- 在ASP.NET中支持断点续传下载大文件(ZT)
IE的自带下载功能中没有断点续传功能,要实现断点续传功能,需要用到HTTP协议中鲜为人知的几个响应头和请求头. 一. 两个必要响应头Accept-Ranges.ETag 客户端每次提交 ...
- [Angular 2 Router] Configure Your First Angular 2 Route
Using the Angular 2 router requires defining routes, passing them in to the RouterModule.forRoot and ...
- curl命令具体解释
对于windows用户假设用Cygwin模拟unix环境的话,里面没有带curl命令,要自己装,所以建议用Gow来模拟,它已经自带了curl工具,安装后直接在cmd环境中用curl命令就可,由于路径已 ...
- 写一个自己定义进度颜色和圆形转动的ProgressBar(具体介绍)
先上图: 我们得自己定义ProgressBar的样式 <span style="white-space:pre"> </span><style nam ...
- Linux显示全部执行中的进程
Linux显示全部执行中的进程 youhaidong@youhaidong-ThinkPad-Edge-E545:~$ ps aux | less USER PID %CPU %MEM VSZ RSS ...
- Linux TCP队列相关参数的总结 转
在Linux上做网络应用的性能优化时,一般都会对TCP相关的内核参数进行调节,特别是和缓冲.队列有关的参数.网上搜到的文章会告诉你需要修改哪些参数,但我们经常是知其然而不知其所以然,每次照抄过 ...