nodejs开发接口自动化02-处理cookie问题
发布于 2 个月前 作者 imzengyang 686 次浏览 来自 分享

本教程使用的到技术栈如下: 操作系统:windows10, 编程语言:node.js 8.9.4 https://nodejs.org/en/ 代码编辑器: CukeTest http://cuketest.com/ 用到的库 got :https://www.npmjs.com/package/got cooike : https://www.npmjs.com/package/cookie

cookie 简介

这里引自维基百科的说明 https://zh.wikipedia.org/wiki/Cookie

Cookie(复数形态Cookies),中文名称为“小型文本文件”或“小甜饼”[1],指某些网站为了辨别用户身份而储存在用户本地终端(Client Side)上的数据(通常经过加密)。网景公司的前雇员卢·蒙特利在1993年3月的发明[2]。最初定义于 RFC 2109。目前使用最广泛的 Cookie标准却不是 RFC 中定义的任何一个,而是在网景公司制定的标准上进行扩展后的产物。

Cookie总是保存在客户端中,按在客户端中的存储位置,可分为内存Cookie和硬盘Cookie。 内存Cookie由浏览器维护,保存在内存中,浏览器关闭后就消失了,其存在时间是短暂的。硬盘Cookie保存在硬盘里,有一个过期时间,除非用户手工清理或到了过期时间,硬盘Cookie不会被删除,其存在时间是长期的。所以,按存在时间,可分为非持久Cookie和持久Cookie。

因为HTTP协议是无状态的,即服务器不知道用户上一次做了什么,这严重阻碍了交互式Web应用程序的实现。在典型的网上购物场景中,用户浏览了几个页面,买了一盒饼干和两瓶饮料。最后结帐时,由于HTTP的无状态性,不通过额外的手段,服务器并不知道用户到底买了什么,所以Cookie就是用来绕开HTTP的无状态性的“额外手段”之一。服务器可以设置或读取Cookies中包含信息,借此维护用户跟服务器会话中的状态。

在刚才的购物场景中,当用户选购了第一项商品,服务器在向用户发送网页的同时,还发送了一段Cookie,记录着那项商品的信息。当用户访问另一个页面,浏览器会把Cookie发送给服务器,于是服务器知道他之前选购了什么。用户继续选购饮料,服务器就在原来那段Cookie里追加新的商品信息。结帐时,服务器读取发送来的Cookie就行了。

Cookie另一个典型的应用是当登录一个网站时,网站往往会请求用户输入用户名和密码,并且用户可以勾选“下次自动登录”。如果勾选了,那么下次访问同一网站时,用户会发现没输入用户名和密码就已经登录了。这正是因为前一次登录时,服务器发送了包含登录凭据(用户名加密码的某种加密形式)的Cookie到用户的硬盘上。第二次登录时,如果该Cookie尚未到期,浏览器会发送该Cookie,服务器验证凭据,于是不必输入用户名和密码就让用户登录了。

举例说明cookie的应用场景

大家熟悉的百度,如果我们在百度上登录过用户,当把浏览器关闭再次打开浏览器导航到百度的时候就会看到我们的账户自动登录,原理就是浏览器里存储的有cookie, 具体查看cookie的方式为: 打开chrome浏览器,url前面的安全可以看到
image.png 点击cookie 可以看到具体的cookie信息 image.png 如果讲这些cookie 都删除掉,点击删除按钮,那么我们再次打开百度首页我们看到的页面将会是未登录个人用户的页面。

使用got 库模拟 get请求

以百度为例,如果打开百度为用户未登录状态,那么我们看到的页面将是这样的 image.png 先用代码 模拟未登录用户的时候,操作步骤如下:

let got = require('got')

let url = "http://www.baidu.com"

got.get(url).then(function(result){
    console.log(result.body)
})

CukeTest中将代码界面最大化,可以点击 运行脚本 按钮 ,运行完成直接看到结果输出 image.png

CukeTest输出界面中可以看到 百度网页的源代码 image.png

在CukeTest中新建一个html文件,并将上一步打印出来的结果复制到html文件中–保存,在html文件上右键 可以在浏览器中打开,也可以用报表打开。 image.png 我们可以看到 没有cookie 的时候 百度的未登录页面信息。

  • 编写带有cookie的代码 我们事先打开浏览器导航到百度页面登录自己的百度账号,检查cookie,将cookie信息复制出来添加到如下代码 image.png
let got = require('got')
let cookie = require('cookie')

let option={
    headers:{
        cookie:[
            cookie.serialize('BAIDUID', 'B4F438F72D1CA0468D67EF98A20D3BA2:FG=1'),
            cookie.serialize('BDUSS', 'UFzYlctWERjckZRdEJPQ1gwOX5yNmlFbTBEbWhxb2s3MkJrdHAtVkxiODFQNk5hQVFBQUFBJCQAAAAAAAAAAAEAAAAXv9JNy6vX02ltenp5AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAADWye1o1sntaS'),
            cookie.serialize('BIDUPSID', 'B4F438F72D1CA0468D67EF98A20D3BA2'),
            cookie.serialize('H_PS_PSSID', '1442_13290_21082_17001_20927'),
            cookie.serialize('PSINO', '5'),
            cookie.serialize('PSTM', '1518055990')
        ]
    }
}

let url = "http://www.baidu.com"

got.get(url,option).then(function(result){
    console.log(result.body)
})

再次执行脚本,将打印出来的结果放到html中可以看到不再原来的未登录的首页,而是已经跳转到登录界面,说明我们的cookie已经成功加载。 image.png

总结

通过got库,配合使用cookie 我们可以很方便的将cookie运用到我们的实际项目。

4 回复

用什么http client库都好, 不过有那么多流行的库为什么不用呢, 以前有request, 最近一年axios真是火遍大江南北, 通吃前端后端.

@XiaozhongLiu 嗯 原理都一样,这些库都很流行,都可以实现这些。 不过看下了下 npm上面的下载量。好像 got更多些。 image.png image.png

@imzengyang 哈哈这个下载量对比, 我竟无言以对. 肯定都是优秀的东西, 所以用户量会这么大. 我之前也没听过got, 从最初开始选就只看的最流行的, 开始用一个库之后也不会再关注其它的, 毕竟http client是个基础工具.

这么一说我去看了一下, 这两个项目都是2014年开始的, got比axios早了将近5个月. 看下载量, got用得更多, 而看star趋势, axios又有爆发, 或许是因为axios在vue火之前不太流行吧. image.png

哈哈, 这些库哪个顺手用哪个。网上搜了搜,发现还有人专门做了下对比。原文在 https://www.twilio.com/blog/2017/08/http-requests-in-node-js.html 可以参考学习下 :)

回到顶部