`
A牛哥哥
  • 浏览: 150632 次
社区版块
存档分类
最新评论

ajax跨域请求

阅读更多
1,什么情况属于跨域?
  url的一级域名或者二级域名不同都是跨域

2,跨域的ajax请求有什么问题?
  ajax请求默认是不能跨域,也就是说A项目想通过ajax请求访问B项目是不可行的,现在我们就是要解决ajax跨域不能调用的问题

3,我们把A项目作客户端,B项目作服务端,这是我的服务端代码,以下所有都是使用此服务端代码,用java的servlet写的
 
public class FileCheckServlet extends HttpServlet{

	protected void doGet(HttpServletRequest req, HttpServletResponse resp)
			throws ServletException, IOException {
			doPost(req, resp);
	}
	protected void doPost(HttpServletRequest req, HttpServletResponse resp)
			throws ServletException, IOException {
		String functionName = req.getParameter("callback");//获取回调函数名
		System.out.println(functionName);
		//resp.getWriter().print(functionName+"([{ name:\"Tom\"}])");//返回json数据的写法
		resp.getWriter().print(functionName+"('haha')");//返回非json字符串的写法,必须加单引号
	}
}
  

以上服务端的地址是http://127.0.0.1:9999/fileserver/fileCheck


4,第一种调用方式,最简单也能明白原理
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Insert title here</title>
</head>

<script type="text/javascript" >  
    function test(result) {  
    	alert(result);
    }  
</script> 

<!-- 用下面这个script标签的src向B项目发出请求, 这个src的请求是可以跨域的,在url后面拼接参数callback=test,这个test就是回调函数的名称,我已经在上面定义了test方法,注意:test方法一定要在下面这个script标签之前声明-->
<script type="text/javascript" src="http://127.0.0.1:9999/fileserver/fileCheck?callback=test"></script>


<body>
</body>
</html>


4.1,服务端debug截图


4.2,客户端的test函数执行截图



4.3,看清楚为什么test方法会执行了吗?
服务端获取到回调函数的名称---String functionName = req.getParameter("callback");
服务端返回---------resp.getWriter().print(functionName+"('haha')"),  即返回的是test('haha')

这个test('haha')就会添加到下面那个script中, 即
<script type="text/javascript" src="http://127.0.0.1:9999/fileserver/fileCheck?callback=test">
          test('haha')
</script>

这就是为什么test方法会执行了

5,采用jquery请求

5.1,用$.get()的方式
function test(result){
	  alert(result);
  }
  $.get('http://127.0.0.1:9999/fileserver/fileCheck?callback=test', {name:'lisi'}, 
		  function (result) {
	  		 alert(result);	 
	  	 }, 'jsonp');

说明:
如果$.get的请求后拼参数callback=test, 并且$.get方法外部定义回调函数test,则只执行test方法,不执行$.get方法内部的匿名回调函数
如果请求后拼参数callback=?,即没有指定回调函数名称, 则jquery会动态创建一个值赋给这个?,服务端debug可以看到这个值,格式是这样的:
jQuery19002410420545318534_1387557790026,这种情况就会执行$.get内部的匿名函数

5.2,用$.ajax的方式
 $.ajax({
		type : "get",
		async:false,
		url : "http://127.0.0.1:9999/fileserver/fileCheck",
		dataType : "jsonp",
		jsonp: "callback",
		jsonpCallback:"test",
		success : function(result){
			alert(result);
		},
		error:function(result){
			alert('fail');
		}
});

  
  function test(result){
	  alert(result);
  }

jsonpCallback:"test"------------jsonpCallback这个参数可有可无.
如果有, 相当于指定了回调函数名称为test,那么$.ajax外部的test方法会先执行,然后执行$.ajax内部的success方法或error方法
如果没有,即没有指定回调函数名,那么jquery会创建一个值(格式也是jQuery19002410420545318534_1387557790026),这种情况只会执行$.ajax内部的success方法或error方法

注意: jquery-1.3.js添加jsonpCallback参数不起作用,还是由jquery自动生成一个值,所以test方法不会执行, 后来换成jquery-1.9.js就可以了,其他jquery版本未测试

5.3, 用$.getJSON的方式
 $.getJSON("http://127.0.0.1:9999/fileserver/fileCheck?callback=?",  
    function(json) {
        alert(json);
    });

这种方式url后拼callback参数值只能是?,写为callback=test后请求发送不出去,因此这种就只能执行$.getJSON方法内的匿名函数
  • 大小: 79.1 KB
  • 大小: 10.7 KB
分享到:
评论

相关推荐

    解决ajax跨域请求问题

    本文将深入探讨如何解决Ajax跨域请求的问题。 首先,理解“同源策略”是解决问题的关键。同源策略是浏览器为了保障网络安全而设定的一种机制,它禁止了一个源的文档或脚本访问另一个源的属性,这里的“源”指的是...

    ajax跨域请求jsonp前后台代码

    基于ajax方式的跨域请求jsonp的前后台代码

    ajax跨域请求WebService.asmx

    【Ajax跨域请求WebService.asmx】是一个常见的Web开发技术应用场景,主要涉及到JavaScript的Ajax技术、C#编程语言以及ASP.NET的WebService组件。Ajax(Asynchronous JavaScript and XML)是一种在不刷新整个页面的...

    ajax跨域请求demo.zip

    这个"ajax跨域请求demo.zip"压缩包提供了一个关于如何实现Ajax跨域请求的示例,涉及到前后端的交互。 首先,我们关注"前端代码"部分。前端通常使用JavaScript库如jQuery来实现Ajax请求。jQuery的`$.ajax()`方法是...

    Ajax跨域请求解决方案-JSONP

    总的来说,JSONP是Ajax跨域请求的一种实用解决方案,尤其适用于只支持GET请求且不涉及复杂交互的场景。但是,它也有一些局限性,比如不支持POST请求、无法控制HTTP头部、无错误处理机制等。因此,在现代Web开发中,...

    利用JQuery jsonp实现Ajax跨域请求json数据

    本篇文章将详细讲解如何利用jQuery的jsonp方法实现Ajax跨域请求,以及如何在服务器端使用.Net的*.handler和WebService来返回JSON数据。 首先,理解JSONP的基本原理。JSONP是一种非官方的协议,通过动态创建`...

    ajax 跨域请求问题 jquery jsonp

    **Ajax跨域请求问题与jQuery JSONP解析** 在Web开发中,Ajax技术被广泛用于实现页面的异步更新,但浏览器的同源策略(Same-Origin Policy)限制了Ajax请求只能向同源(协议、域名、端口均相同)的服务器发送。这在...

    Jquery跨域Ajax请求测试

    jQuery,作为一个强大的JavaScript库,提供了便捷的方式来处理这种问题,特别是通过其Ajax功能进行跨域请求。本示例"Jquery跨域Ajax请求测试"将详细讲解如何利用jQuery实现这一功能。 首先,了解同源策略是理解跨域...

    ajax跨域请求调用webservice接口+视频教程

    【标题】"Ajax跨域请求调用WebService接口"是一个关键的技术点,主要涉及到Web开发中的异步数据交互和跨域安全策略。在Web应用程序中,Ajax(Asynchronous JavaScript and XML)技术允许我们在不刷新整个页面的情况...

    用代理避免ajax跨域请求(手机验证码)

    标题“用代理避免ajax跨域请求(手机验证码)”指出了解决这个问题的一种策略,即利用代理服务器来规避浏览器的同源策略限制。下面我们将深入探讨这个主题。 首先,我们了解什么是跨域请求。在Web开发中,由于...

    异常 AJAX 跨域请求报:No ‘Access-Control-Allow-Origin‘ header is present

    在HTMLTest文件中,可能包含了一个简单的AJAX跨域请求的示例代码。常见的使用jQuery或者原生JavaScript发起AJAX请求的方式如下: jQuery示例: ```javascript $.ajax({ url: 'http://otherdomain.com/api', type:...

    jsonpajax跨域请求

    4. AJAX跨域: AJAX本身不支持跨域,但是通过CORS(Cross-Origin Resource Sharing,跨源资源共享)机制,可以实现AJAX的跨域请求。服务器需要在响应头中添加`Access-Control-Allow-Origin`字段,允许指定的源进行...

    juery mobile使用ajax跨域请求服务器的小实例

    在这里,我们将探讨如何利用jQuery Mobile和Ajax实现跨域请求。 首先,理解什么是跨域请求。由于浏览器的安全策略,JavaScript通常被限制在同源策略之下,即只能访问与当前页面相同协议、域名和端口的资源。但有时...

    ajax跨域解决办法

    6. **Domain属性(仅限子域)**:在cookies中设置`domain`属性可以实现跨子域共享,但这仅限于同一主域下的子域名之间,对AJAX跨域请求帮助有限。 在实际应用中,开发者通常根据项目需求和服务器环境选择合适的跨域...

    jQuery.ajax 跨域请求webapi设置headers的解决方案

    客户端JavaScript代码中,使用jQuery的`$.ajax`进行跨域请求时,可以在`beforeSend`回调函数中设置请求的headers: ```javascript $("#btnSubmit").click(function () { var ticket = $.cookie("token"); var ...

    ajax跨域请求js拒绝访问的解决方法

    AJAX跨域请求是指当一个网页从一个域名下的服务器请求另外一个域名下的资源时,由于浏览器的同源策略,可能会被拒绝访问,产生跨域问题。同源策略是浏览器的一个安全机制,它要求网页的脚本只能访问和操作与该脚本...

    基于iframe实现ajax跨域请求 获取网页中ajax数据

    主要介绍了基于iframe实现ajax跨域请求,并获取网页中ajax数据,如何利用网页ajax请求暴露出来的接口去抓取网页数据?需要的朋友可以参考下

    怎样实现Ajax 跨域访问

    JSONP是一种常用的跨域数据获取方式,其原理是利用`&lt;script&gt;`标签没有跨域限制的特点来实现跨域请求。请求时,在URL中添加一个回调函数名作为参数,服务器收到请求后返回一个函数调用,其中包含所需的数据。 **案例...

Global site tag (gtag.js) - Google Analytics