Ajax----原生,jquery, 跨域:jsonp, cors
ajax简介AJAX即“AsynchronousJavascriptAndXML”(异步JavaScript和XML),是指一种创建交互式网页应用的网页开发技术。Ajax不是一种新的编程语言,而是使用现有标准的新方法。AJAX可以在不重新加载整个页面的情况下,与服务器交换数据。这种异步交互的方式,使用户单击后,不必刷新页面也能获取新数据。使用Ajax,用户可以创建接近本地桌面应用的直接、高可用、更丰富、更动态的Web用户界面。 Ajax包括:
利用AJAX可以做:
ajax伪造iframe就是我们常用的iframe标签:<iframe>。iframe标签是框架的一种形式,也比较常用到,iframe一般用来包含别的页面,例如我们可以在我们自己的网站页面加载别人网站或者本站其他页面的内容。iframe标签的最大作用就是让页面变得美观。iframe标签的用法有很多,主要区别在于对iframe标签定义的形式不同,例如定义iframe的长宽高。 因此,iframe标签具有局部加载内容的特性,所以可以使用其来伪造Ajax请求。 <!DOCTYPE html> <html> head lang="en"> meta charset="UTF-8"title>伪造AJAX</</headbodydiv> p>请输入要加载的地址:span id="currentTime"></span> input ="url" type="text" /> type="button" value="提交" onclick="LoadPage();"h3>加载页面位置:iframe ="iframePosition" style="width: 100%;height: 500px;"iframescript ="text/javascript"> window.onload= function(){ var myDate new Date(); document.getElementById('currentTime).innerText = myDate.getTime(); }; LoadPage(){ targetUrl document.getElementById(url).value; document.getElementById("iframePosition).src targetUrl; } script> 原理是这样的,设置一个提交按钮,再设置一个输入框,当我们输入一个网址的时候,在当前的页面加载输入网址的页面信息,呈现在iframe框里,这样就能做到不刷新URL来提交不同的信息。 原生ajaxAjax的核心是XMLHttpRequest对象(XHR)。XHR为向服务器发送请求和解析服务器响应提供了接口。能够以异步方式从服务器获取新数据。 一、XMLHttpRequest对象 XHR的主要方法有: 1. void open(String method,String url,Boolen async)
用于创建请求
参数:
method: 请求方式(字符串类型),如:POST、GET、DELETE...
url: 要请求的地址(字符串类型)
async: 是否异步(布尔类型)
XHR的主要属性有: 1. Number readyState
状态值(整数),可以确定请求/响应过程的当前活动阶段
3. String responseText 作为响应主体被返回的文本(字符串类型)
二、get请求 GET用于向服务器查询某些信息: > h1>XMLHttpRequest - Ajax请求="XmlGetRequest();"="Get发送请求" /> src="/statics/jquery-1.12.4.js"> GetXHR(){ xhr null; if(XMLHttpRequest){ xhr XMLHttpRequest(); }else{ xhr ActiveXObject(Microsoft.XMLHTTP); } return xhr; } XmlGetRequest(){ GetXHR(); // 定义回调函数 xhr.onreadystatechange (xhr.readyState == 4){ 已经接收到全部响应数据,执行以下操作 data xhr.responseText; console.log(data); } }; 指定连接方式和地址----文件方式 xhr.open(get,/test/true); 发送请求 xhr.send(); } > 三、post请求 POST请求用于向服务器发送应该被保存的数据。POST请求的主体可以包含非常多的数据,而且格式不限。 >POST="XmlPostRequest();"="Post发送请求" XmlPostRequest(){ POST 设置请求头 xhr.setRequestHeader(Content-Typeapplication/x-www-form-urlencoded; charset-UTF-8 xhr.send(n1=1;n2=2;); } > jquery ajaxjQuery 提供多个与 AJAX 有关的方法。 通过 jQuery AJAX 方法,您能够使用 HTTP Get 和 HTTP Post 从远程服务器上请求文本、HTML、XML 或 JSON - 同时您能够把这些外部数据直接载入网页的被选元素中。
注:2.+版本不再支持IE9以下的浏览器 1. jQuery.get(...) 所有参数: url: 待载入页面的URL地址 data: 待发送 Key/value 参数。 success: 载入成功时回调函数。 dataType: 返回内容格式,xml,json,script,text,html 2.jQuery.post(...) 所有参数: url: 待载入页面的URL地址 data: 待发送 Key/value 参数 success: 载入成功时回调函数 dataType: 返回内容格式,xml,128)">3.jQuery.getJSON(...) 所有参数: url: 待载入页面的URL地址 data: 待发送 Key/value 参数。 success: 载入成功时回调函数。 4.jQuery.getScript(...) 所有参数: url: 待载入页面的URL地址 data: 待发送 Key/value 参数。 success: 载入成功时回调函数。 5.jQuery.ajax(...) 部分参数: url:请求地址 type:请求方式,GET、POST(1.9.0之后用method) headers:请求头 data:要发送的数据 contentType:即将发送信息至服务器的内容编码类型(默认: "application/x-www-form-urlencoded; charset=UTF-8") async:是否异步 timeout:设置请求超时时间(毫秒) beforeSend:发送请求前执行的函数(全局) complete:完成之后执行的回调函数(全局) success:成功之后执行的回调函数(全局) error:失败之后执行的回调函数(全局) accepts:通过请求头发送给服务器,告诉服务器当前客户端课接受的数据类型 dataType:将服务器端返回的数据转换成指定类型 xml": 将服务器端返回的内容转换成xml格式 text": 将服务器端返回的内容转换成普通文本格式 html": 将服务器端返回的内容转换成普通文本格式,在插入DOM中时,如果包含JavaScript标签,则会尝试去执行。 script": 尝试将返回值当作JavaScript去执行,然后再将服务器端返回的内容转换成普通文本格式 json": 将服务器端返回的内容转换成相应的JavaScript对象 jsonp": JSONP 格式使用 JSONP 形式调用函数时,如 myurl?callback=?" jQuery 将自动替换 ? 为正确的函数名,以执行回调函数 写一个最简单的例子: ="XmlSendRequest();"='Ajax请求' />
="text/javascript" src="jquery-1.12.4.js" JXmlSendRequest(){
$.ajax({
url: http://c2.com:8000/test/GETtext(data,statusText,xmlHttpRequest){ // 成功后返回的结果
console.log(data);
}
})
}
>
跨域ajax由于浏览器存在同源策略机制,同源策略阻止从一个源加载的文档或脚本获取或设置另一个源加载的文档的属性。所以ajax本身是不可以跨域的,通过产生一个script标签来实现跨域。因为script标签的src属性是没有跨域的限制的。 浏览器同源策略并不是对所有的请求均制约:
注:自己模拟跨域,需要现在自己电脑的host文件里面添加两条域名,我这里添加的是zhangyanlin.com和aylin.com这两个域名 一、JSONP实现跨域请求 JSONP是一个非官方的协议,它允许在服务器端集成Script tags返回至客户端,通过javascript callback的形式实现跨域访问。jsonp只能通过get方式进行跨域请求 html >Titleinput ="Ajax"="DoAjax();"="JsonpAjax"="JsonpAjax();"="http://aylin.com:8002/statics/jquery.cookie.js" func(arg) {
console.log(arg); // 输出结果就是python代码给传过来的列表[11,22,33,]
}
DoAjax() {
$.ajax({
url: http://alex.com:8002/indexk1: v1},success: (arg) {
console.log(arg);
}
});
}
JsonpAjax() {
var tag = document.createElement('script');
// tag.src = "http://alex.com:8002/index"; document.head.appendChild(tag); document.head.removeChild(tag);
$.ajax({
url: http://aylin.com:8002/indexjsonpfunc // 对端给返回函数名,函数接收的参数是内容
})
}
aylin.com域名这边可以给定义函数
# 采用pythontornado框架来进行的 class IndexHandler(tornado.web.RequestHandler): def get(self): self.write('func([11,33]);') def post(self,*args,**kwargs): self.write(t2.post') 在这里jsonp就采用script标签的src来进行跨域请求的 二、CORS 上面那种方法说到浏览器的同源策略导致ajax无法进行跨域传输,那么这种方法就可以突破浏览器限制来进行传输。当数据发送给对方域名的时候,对方已经收到,但是在返回的时候被浏览器给阻挡,我们可以写一串类似于身份证的字符串,通过浏览器的预检,从而达到数据的传输。 这方面分为简单请求和非简单请求 条件:
1、请求方式:HEAD、GET、POST
2、请求头信息:
Accept
Accept-Language
Content-Language
Last-Event-ID
Content-Type 对应的值是以下三个中的任意一个
application/x-www-form-urlencoded
multipart/form-data
text/plain
注意:同时满足以上两个条件时,则是简单请求,否则为复杂请求
基于cors实现AJAX请求: 1、支持跨域,简单请求 服务器设置响应头:Access-Control-Allow-Origin = '域名' 或 '*' ="submit"="XmlSendRequest();" ="JqSendRequest();" XmlSendRequest(){ XMLHttpRequest(); xhr.onreadystatechange ) { result xhr.responseText; console.log(result); } }; xhr.open(); xhr.send(); } JqSendRequest(){ $.ajax({ url: > class MainHandler(tornado.web.RequestHandler):
def get(self):
self.set_header('Access-Control-Allow-Origin',"http://www.xxx.com")
self.write('{"status": true,"data": "seven"}')
2、支持跨域,复杂请求 由于复杂请求时,首先会发送“预检”请求,如果“预检”成功,则发送真实数据。
PUThttp://aylin.com:8000/test/); xhr.setRequestHeader( 3、跨域传输cookie 在跨域请求中,默认情况下,HTTP Authentication信息,Cookie头以及用户的SSL证书无论在预检请求中或是在实际请求都是不会被发送。 如果想要发送:
xhr.responseText; console.log(result); } }; xhr.withCredentials ; xhr.open( (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |