首页 >

ajax跨域问题如何解决

web前端|js教程ajax跨域问题如何解决
ajax跨域
web前端-js教程
试看充值源码,下不了vscode,网易开源ubuntu下载,tomcat安装部署,sqlite3 文件,jq 幻灯 插件,桌面开发 前端框架,python爬虫操作word,php mp3,小伞seo,网站3d效果可拖动,网页播放代码 php,discuz资源网模板,html5登陆页面,jsp超市管理系统代码,用vb编写实现语音读取文本框内容的程序lzw
ajax跨域问题的解决方法:
知识库源码 php,vscode符号插件,Ubuntu系统使用光盘,Tomcat动态编译,sqlite数据存储模型,h5上传头像图片插件,做表格的前端框架,爬虫采集图表数据,微信公众平台php,杭州SEO招聘图片,小说网站源编码,怎么查看源码来查找网页中动态图片,html聊天室页面模板,页面加载百叶窗,三层管理系统.net源码,单机游戏网站程序lzw
解决方式1:响应头添加Header允许访问
js滚动新闻源码,繁体转中文vscode,aptget改ubuntu,tomcat 请求阻塞,sqlite 设置唯一性,爬虫对于共享单车可行性分析,php 下载站,汕尾seo公司咨询报价,.net网站调用头部底部,dw网页编辑器,微信日志模板lzw
跨域资源共享(CORS)Cross-Origin Resource Sharing

这个跨域访问的解决方案的安全基础是基于”JavaScript无法控制该HTTP头”

它需要通过目标域返回的HTTP头来授权是否允许跨域访问。

response.addHeader(‘Access-Control-Allow-Origin:*’);//允许所有来源访问 response.addHeader(‘Access-Control-Allow-Method:POST,GET’);//允许访问的方式

解决方式2:jsonp 只支持get请求不支持post请求

用法:①dataType改为jsonp ②jsonp : “jsonpCallback”————发送到后端实际为http://a.a.com/a/FromServlet?userName=644064&jsonpCallback=jQueryxxx ③后端获取get请求中的jsonpCallback ④构造回调结构

$.ajax({type : "GET",async : false,url : "http://a.a.com/a/FromServlet?userName=644064",dataType : "jsonp",//数据类型为jsonp  jsonp : "jsonpCallback",//服务端用于接收callback调用的function名的参数success : function(data) {alert(data["userName"]);},error : function() {alert('fail');}}); //后端        String jsonpCallback = request.getParameter("jsonpCallback");//构造回调函数格式jsonpCallback(数据)resp.getWriter().println(jsonpCallback+"("+jsonObject.toJSONString()+")");

JSONP实现原理

在同源策略下,在某个服务器下的页面是无法获取到该服务器以外的数据的,即一般的ajax是不能进行跨域请求的。但 img、iframe 、script等标签是个例外,这些标签可以通过src属性请求到其他服务器上的数据。利用标签的开放策略,我们可以实现跨域请求数据,当然这需要服务器端的配合。 Jquery中ajax的核心是通过 XmlHttpRequest获取非本页内容,而jsonp的核心则是动态添加标签来调用服务器提供的 js脚本。

当我们正常地请求一个JSON数据的时候,服务端返回的是一串JSON类型的数据,而我们使用 JSONP模式来请求数据的时候服务端返回的是一段可执行的JavaScript代码。因为jsonp 跨域的原理就是用的动态加载的src ,所以我们只能把参数通过url的方式传递,所以jsonp的 type类型只能是get !

示例:

$.ajax({    url: 'http://192.168.10.46/demo/test.jsp',        //不同的域    type: 'GET',        // jsonp模式只有GET 是合法的    data: {        'action': 'aaron'    },    dataType: 'jsonp',              // 数据类型    jsonp: 'jsonpCallback',     // 指定回调函数名,与服务器端接收的一致,并回传回来})

其实jquery 内部会转化成

http://192.168.10.46/demo/test.jsp?jsonpCallback=jQuery202003573935762227615_1402643146875&action=aaron

然后动态加载

然后后端就会执行jsonpCallback(传递参数 ),把数据通过实参的形式发送出去。

使用JSONP 模式来请求数据的整个流程:客户端发送一个请求,规定一个可执行的函数名(这里就是 jQuery做了封装的处理,自动帮你生成回调函数并把数据取出来供success属性方法来调用,而不是传递的一个回调句柄),服务器端接受了这个 jsonpCallback函数名,然后把数据通过实参的形式发送出去

(在jquery 源码中, jsonp的实现方式是动态添加标签来调用服务器提供的 js脚本。jquery 会在window对象中加载一个全局的函数,当 代码插入时函数执行,执行完毕后就 会被移除。同时jquery还对非跨域的请求进行了优化,如果这个请求是在同一个域名下那么他就会像正常的 Ajax请求一样工作。)

解决方式3:httpClient内部转发

实现原理很简单,若想在B站点中通过Ajax访问A站点获取结果,固然有ajax跨域问题,但在B站点中访问B站点获取结果,不存在跨域问题,这种方式实际上是在B站点中ajax请求访问B站点的HttpClient,再通过HttpClient转发请求获取A站点的数据结果。但这种方式产生了两次请求,效率低,但内部请求,抓包工具无法分析,安全。

$.ajax({type : "GET",async : false,url : "http://b.b.com:8080/B/FromAjaxservlet?userName=644064",dataType : "json",success : function(data) {alert(data["userName"]);},error : function() {alert('fail');}}); @WebServlet("/FromAjaxservlet")public class FromAjaxservlet extends HttpServlet{protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {try {//创建默认连接CloseableHttpClient httpClient = HttpClients.createDefault();//创建HttpGet对象,处理get请求,转发到A站点HttpGet httpGet = new HttpGet("http://a.a.com:8080/A/FromServlet?userName="+req.getParameter("userName"));         //执行CloseableHttpResponse response = httpClient.execute(httpGet);int code = response.getStatusLine().getStatusCode();//获取状态System.out.println("http请求结果为:"+code);if(code == 200){//获取A站点返回的结果String result = EntityUtils.toString(response.getEntity());System.out.println(result);//把结果返回给B站点resp.getWriter().print(result);}response.close();httpClient.close();} catch (Exception e) {}}}

解决方式4:使用nginx搭建企业级接口网关方式

www.a.a.com不能直接请求www.b.b.com的内容,可以通过nginx,根据同域名,但项目名不同进行区分。什么意思呢?这么说可能有点抽象。假设我们公司域名叫www.nginxtest.com

当我们需要访问www.a.a.com通过www.nginxtest.com/A访问,并通过nginx转发到www.a.a.com

当我们需要访问www.b.b.com通过www.nginxtest.com/B访问,并通过nginx转发到www.a.a.com

我们访问公司的域名时,是”同源”的,只是项目名不同,此时项目名的作用只是为了区分,方便转发。如果你还不理解的话,先看看我是怎么进行配置的:

server {        listen       80;        server_name  www.nginxtest.com;        location /A {    proxy_pass  http://a.a.com:81;index  index.html index.htm;        }location /B {    proxy_pass  http://b.b.com:81;index  index.html index.htm;        }    }

我们访问以www.nginxtest.com开头且端口为80的网址,nginx将会进行拦截匹配,若项目名为A,则分发到a.a.com:81。实际上就是通过”同源”的域名,不同的项目名进行区分,通过nginx拦截匹配,转发到对应的网址。整个过程,两次请求,第一次请求nginx服务器,第二次nginx服务器通过拦截匹配分发到对应的网址。


ajax跨域问题如何解决
  • 为什么相同的代码部署在线上 ajax异步返回的json多一串奇怪的url?
  • 为什么相同的代码部署在线上 ajax异步返回的json多一串奇怪的url? | 为什么相同的代码部署在线上 ajax异步返回的json多一串奇怪的url? ...

    ajax跨域问题如何解决
  • PHP实现服务器端允许客户端ajax跨域
  • PHP实现服务器端允许客户端ajax跨域 | PHP实现服务器端允许客户端ajax跨域 ...

    ajax跨域问题如何解决
  • ajax-返回值 - MUI用ajax如何请求thinkphp中返回的json的内容?
  • ajax-返回值 - MUI用ajax如何请求thinkphp中返回的json的内容? | ajax-返回值 - MUI用ajax如何请求thinkphp中返回的json的内容? ...