300字范文,内容丰富有趣,生活中的好帮手!
300字范文 > AngularJs解决跨域问题案例详解(简单方法)_AngularJS

AngularJs解决跨域问题案例详解(简单方法)_AngularJS

时间:2022-01-09 13:30:11

相关推荐

AngularJs解决跨域问题案例详解(简单方法)_AngularJS

web前端|js教程

angularjs解决跨域,angularjs跨域

web前端-js教程

首先我们做点准备说明,不然你明白我说的是啥意思别人不明白,就算别人明白了那总有人不明白,那你要说了,我的意思是这个说明必须要做了,答案是必须的,为了更好的方便大家理解嘛。

全民挂机全套源码.7z,ubuntu桌面web化,网站部署到tomcat中,r 爬虫 rvest,php 智能搜索,蔡甸seo排名哪家公司好lzw

我们以两个主域名或者一个主域名+一个二级域名为例,均可演示跨域问题。

科讯源码,ubuntu怎么开swap,飞机爬虫余票,php ,seo陈浩lzw

客户端

培训教育crm源码,vscode终端不会编译,ubuntu删除垃圾,TOMCAT下载视频调色,爬虫 天蝎 天鹰,php 服务器优化,seo用什么东西制作,潮县分类网站源码,html5 模板 源代码下载lzw

服务端 或者

angularJs版本 V1.2.25

准备工作做得很充分嘛,就差把我们的编辑器是subline暴露出来了,这个一般人我是不告诉他滴。

有人嚷嚷了,这问题老早就有了,你现在提出来有啥意义呢?难不成你还能把花忽悠开了?嗯,我还真能把花写开了。看戏吧,我们本篇要上演的是完整版跨域实例。

接下来我们先看客户端是如何请求数据的

注意哦,我们的代码是写在域名下面的

var app = angular.module(app, []);app.controller(appCtrl, [$scope, function ($scope) {$http({method: JSONP,url: /test.php?callback=JSON_CALLBACK,}).success(function (msg) {console.log(data);});//或者$http.jsonp(/test.php?callback=JSON_CALLBACK).success(function (msg){console.log(msg);}); }]);

我们看到,这里是直接以jsonp的形式进行跨域请求的,其操作同jquery中对跨域的请求方式如出一辙。注意,我们的callback是固定的,即JSON_CALLBACK,尽量不要去做任何改动

我们再看服务端中的test.php对请求数据的处理方式,这里以原生php的方式做参考

$callBack = isset($_GET[callback]) ? $_GET[callback] : DEFAULT_CALLBACK;exit($callBack.(.json_encode($data).));

我们再回来看看客户端console.log记录的结果

到此,也就是说我们跨域请求是成功的!

最后我们做个小总结,注意下其中的重点:

1.客户端跨域请求的url后追加的参数是?callback=JSON_CALLBACK,参数callback的值指定为JSON_CALLBACK,注意是大写,就是JSON_CALLBACK不要作任何改动,感觉这里是个不小的坑,?callback的值稍作改动,客户端就需要全局定义callback函数,而且还特么怎么再传给$scope处理?为了避免不必要的麻烦,这里建议就这么搞吧

2.再看服务端,服务端需要指定$callBack = $_GET[‘callback’];接收callback,而且你还会发现接收的callback不是我们客户端写的?callback的值,客户端指定JSON_CALLBACK应该是为了触发angularJs内部的机制

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。