中止请求和超时 跨域的HTTP请求 认证方式 JSONP

中止请求和超时

一个栗子在上传多少秒以后直接终止请求

// 发起HTTP GEt请求获取指定URl的内容
// 如果响应成功到达,将会传入responseText给回调函数
// 如果响应在timeout毫秒内没有到达,将会中止这个请求
function timedGetText(url, timeout, callback) {
    var request = new XMLHttpRequest(); // 创建新请求
    var timedout = false;   // 是否超时,设置标志
    // 启动计时器,在timeout毫秒后将终止请求
    var timer = setTimeout(() => {  // 设置计时器,将在timeout时间之后执行该操作,不同于直接定义,是直接
        timedout = true;    // 设置标记
        request.abort();    // 直接中止请求
    }, timeout);    // 直接终止请求
    request.open('GET', url);
    request.onreadystatechange = () => {    // 定义事件处理程序,如果事件处理完成,直接终止计时器
        if (request.readyState !== 4) return;   // 如果此时仍然有没有下载完成的,直接忽视,等待计时器取消
        if (timedout) return;   // 确定此时仍然没有超时,如果此时仍然没有超时,直接取消
        cleraTimeout(timer);    // 此时已经执行完成任务,取消计时器
        if (request.status === 200) // 对回调函数的处理
            callback(request.responseText); // 如果请求成功,将会直接返回成功的文本,并调用回调函数
    };
    request.send(null); // 直接发送请求(此请求为异步操作)
}

跨域的HTTP请求

作为同源策略的一部分,XMLHttpRequest对象可以发起HTTP请求,由于同源的影响,导致必须是同源的,

ps script元素不是真正的受到了同源策略的影响,它加载并执行任何来源的脚本,使用ajax的方式为直接script脚本完成

或者依旧可以使用cors的方式跨域访问网站

一些安全问题

如果传入用户名和密码,其不能通过跨域发送(因为这样可以利用js客户端的方式,使得分布式破解密码成为可能)
跨域请求不会包含其他任何的用户证书
cookie和token 都会被丢弃,如果跨域请求需要这几种凭证,必须在send方法之前,使用withCredentials

一些认证方式介绍

Singnature 认证

即签名认证

一次性身份校验方式,常常用于不同项目之间的api通信

举例来自百度翻译的api接口
https://fanyi-api.baidu.com/api/trans/product/apidoc
上方是百度翻译的api文档

get请求url如下 http://api.fanyi.baidu.com/api/trans/vip/translate?q=apple&from=en&to=zh&appid=2015063000000001&salt=1435660288&sign=f89f9594663708c1605f3d736d01d2d4

最后一个为签名,在这里,这个api使用的是md5的 还有一种加密方式为rsa加密

md5 MD5是输入不定长度信息,输出固定长度128-bits的算法。经过程序流程,生成四个32位数据,最后联合起来成为一个128-bits散列。基本方式为,求余、取余、调整长度、与链接变量进行循环运算。得出结果。

目前已经被证实可被破解
还有一些哈希算法等其他的加密算法

继续举例
https://help.aliyun.com/document_detail/54274.html
上方的是来自于阿里云的一个api
只不过使用的是Hmac SHA1算法加密得到签名的

HMAC-SHA1 为哈希运算消息认证码,HMAC运用的是哈希算法,以一个秘钥和一个消息为输入,生成一个消息摘要作为输出。为一种最常用的签名算法。用于对一段信息生成一段签名的摘要,在GET或者POST请求内

token

token的鉴权流程
https://help.aliyun.com/document_detail/54226.html?spm=a2c4g.11186623.4.1.NKz4kZ
整个流程是先通过用户账号体系登录,接着对token认证服务器发送申请token的请求,token的有效期自定义,验证通过后,直接返回给客户端token,最后验证token到要访问的服务器。即上方为完整的用户登录过程

ps 用户登录需要进行鉴权

由于http可被局域网抓包,所以一般使用ssl

后方的token会和后端服务器进行token的同步
一篇博文 http://www.cnblogs.com/xiekeli/p/5607107.html

还有其他,不在说

举个栗子

下方的栗子实现一个简单的跨域的js请求,使用的是来自于百度翻译的api
使用的cors

ps 我根本找不到支持cors的api 貌似是浏览器不兼容的缘故。。唉。

那就暂时不举了,总体来说浏览器在发现是跨域请求的时候,会自动添加origin头,如果服务端Access-Control-Allow-Origin 的头部和origin相同,或者为*号的时候,即可进行同源请求,否则将会拒绝同源请求。

JSONP

可以借助script发送HTTP请求,script元素作为一种ajax传输机制。
使用script,不会受到同源策略的影响,并且包含JSON编码数据的响应体会自动解码

脚本和安全性 使用script元素进行AJAX传输,会运行执行发送过来的任何js脚本,这种方式适用于可信的第三方脚本,如广告,统计等。

使用script元素调用数据时,必须用js函数名和圆括号包裹起来。

使用script元素发送JSONP请求

一个栗子

// 根据指定的URL发送一个JSONP请求
function getJSONP(url) {
    // 为本次请求创建一个唯一的回调函数名称,将会拼接成 getJSONP.cb3
    // 将会拼接成 ?jsonp=getJSONP.cb3
    var cbnum = 'cb' + getJSONP.counter++;  // 自增计算器
    var cbname = "getJSONP." + cbnum;   // 作为JSONP函数的属性

    // 将回调函数名以表单彪马的形式添加到url的?后面部分中
    // 使用JSONP作为参数名
    if (url.indexOf('?') === -1) // 如果url没有查询部分
        url += '?jsonp=' + cbname;  // 进行添加参数,拼接成为完整的url
    else // 否则
        url += "&jsonp" + cbname;   // 将会作为新的参数进行添加

    // 创建script元素用于发送请求
    var script = document.createElement('script');

    // 触发HTTP请求,直接操作DOM创建script节点,让浏览器加载
    script.src = url;
    document.body.appendChild(script);
}

总体思路是,直接创建script元素,通过添加src属性,让script元素代为发送get请求
查看响应


此处输入图片的描述
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,189评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,577评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,857评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,703评论 1 276
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,705评论 5 366
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,620评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,995评论 3 396
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,656评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,898评论 1 298
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,639评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,720评论 1 330
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,395评论 4 319
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,982评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,953评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,195评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 44,907评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,472评论 2 342

推荐阅读更多精彩内容