首页 > 其他分享 >Cookie复用的妙用:数据处理中的高效利器!

Cookie复用的妙用:数据处理中的高效利器!

时间:2024-03-25 12:11:54浏览次数:25  
标签:妙用 cookies 登录 get 复用 获取 Cookie cookie

在这里插入图片描述

简介

浏览网站时,服务器会往浏览器发一些数据,叫做 Cookie。它是一种认证数据,存储在电脑浏览器上,用于后续访问时身份验证和记录登录信息。通常,服务器会把一些关键信息如用户 ID,会话 ID,密码等存在 Cookie 里。

Cookie 相当于个人信息,浏览器请求页面时携带 Cookie,这样服务器就能通过 Cookie 判断用户是否有效。通过获取和管理 Cookie,我们能模拟用户登录状态、记录用户信息,实现多个页面间的数据共享等。

需要注意的是,一旦 Web 服务器把页面发给浏览器后,在连接关闭后,服务端不再保留用户的信息。

在进行自动化测试时,通常需要登录网站进行操作。复用浏览器仍然在每次用例开始都需要人为介入,只要关闭浏览器后就需要在重新人为介入。会导致测试效率将非常低下,甚至无法进行大规模的测试。使用 Cookie 自动化登录可以很好地解决这个问题。

通过 Cookie,可以在不需要手动登录的情况下访问网站,从而避免了重复输入用户名和密码的麻烦。同时,由于大部分 Cookie 的时效性都很长,只需要扫描一次 Cookie,就可以在多个测试用例中使用。

具体实现方法包括以下几个步骤:

  1. 打开浏览器并登录,确保登录成功后获取 Cookie 信息。
  2. 将获取到的 Cookie 信息存储到本地文件中,以便于下次使用。通过文件读写操作,可以将 Cookie 信息保存到一个文本文件中。
  3. 检查本地文件中是否已经成功获取了 Cookie 信息。
  4. 再次打开浏览器并植入 Cookie 信息进入主页。

Python 实现

通过以下两个方法,可以在自动化测试过程中模拟用户的登录状态,以便于进行后续的测试操作:

  1. 获取当前页面所有 cookie 信息,确保正确的 cookie 写入到一个本地文件中,通过driver.get_cookies()方法获取浏览器的当前所有 Cookie,具体代码参考方法:test_get_cookies()
  2. 读取 Cookie 信息,并向浏览器添加 Cookie: driver.add_cookie(cookie),具体代码参考方法:test_add_cookie()
class TestCookieLogin:
    def setup_class(self):
        self.drvier = webdriver.Chrome()

    def test_get_cookies(self):
        # 1. 访问企业微信主页/登录页面
        self.drvier.get("https://work.weixin.qq.com/wework_admin/frame#contacts")
        # 2. 等待20s,人工扫码操作
        time.sleep(20)
        # 3. 等成功登陆之后,再去获取cookie信息
        cookie = self.drvier.get_cookies()
        # 4. 将cookie存入一个可持久存储的地方,文件
        # 打开文件的时候添加写入权限
        with open("cookie.yaml", "w") as f:
            # 第一个参数是要写入的数据
            yaml.safe_dump(cookie, f)

    def test_add_cookie(self):
        # 1. 访问企业微信主页面
        self.drvier.get("https://work.weixin.qq.com/wework_admin/frame#contacts")
        # 2. 定义cookie,cookie信息从已经写入的cookie文件中获取
        cookie = yaml.safe_load(open("cookie.yaml"))
        # 3. 植入cookie
        for c in cookie:
            self.drvier.add_cookie(c)
        time.sleep(3)
        # 4.再次访问企业微信页面,发现无需扫码自动登录,而且可以多次使用
        self.drvier.get("https://work.weixin.qq.com/wework_admin/frame#contacts")

Java 实现

@Slf4j
publicclass LoginTest{
staticObjectMappermapper=newObjectMapper(newYAMLFactory());
staticWebDriverdriver;

@BeforeAll
staticvoidsetUp(){
ChromeOptionsoptions=newChromeOptions();
//防止连接报错
options.addArguments("--remote-allow-origins=*");
driver=newChromeDriver(options);
}

@Test
voiddumpCookie()throwsIOException{
// 保存cookie
ObjectMappermapper=newObjectMapper(newYAMLFactory());
Stringurl="https://work.weixin.qq.com/wework_admin/frame";
// 1. 访问企业微信主页
driver.get(url);
// 2. 判断url是否登录成功
WebDriverWaitwait=newWebDriverWait(driver,
Duration.ofSeconds(20),
Duration.ofSeconds(1));
wait.until(webDriver1->StringUtils.contains(webDriver1.getCurrentUrl(),"wework_admin/frame"));
// 3. 等成功登陆之后,再去获取cookie信息
Set<Cookie>cookies=driver.manage().getCookies();
log.info("登录cookies:",cookies);
mapper.writeValue(newFile("cookies.yaml"),cookies);

}

@Test
voidloadCookie()throwsIOException{
Stringurl="https://work.weixin.qq.com/wework_admin/frame";
// 访问企业微信主页
driver.get(url);
// 使用 cookie 登录
// 1.声明一个泛型
TypeReference<List<HashMap<String,Object>>>typeReference=
newTypeReference<>(){};
// 2. 从yaml中获取cookies
List<HashMap<String,Object>>loadCookies=
mapper.readValue(newFile("cookies.yaml"),
typeReference);
loadCookies.stream()
// 找到domain包含work.weixin.qq.com
.filter(cookie->cookie.get("domain").toString().
contains("work.weixin.qq.com"))
.forEach(cookie->{
driver.manage().addCookie(
newCookie(cookie.get("name").toString(),
cookie.get("value").toString()));
});
// 4. 刷新页面,登录成功
driver.navigate().refresh();
}
}

常见问题

  1. 对于企业微信等具有互踢机制的系统,需要注意在获取 cookie 成功之后,不要再进行扫码登录操作,否则会导致之前获取的 cookie 失效。
  2. 在获取 cookie 时,务必确保已经成功完成登录操作,否则获取的 cookie 将变得无效。
  3. 获取 cookie 之后,应进入登录页面并刷新,以验证是否能够自动登录成功。若自动登陆失败,需检查获取 cookie 的代码是否存在问题或者 Cookie 是否已经国企。这一过程有助于确保所获取的 Cookie 在后续操作中能够有效使用。

总结

在 web 自动化测试中,掌握 Cookie 复用技巧至关重要。这不仅仅是关于复用 Cookie,更涉及到复用登录凭证,以减少繁琐的重复登录步骤,从而提高测试效率。这一技巧的核心在于有效地利用已有的登录状态,为测试过程增添便捷性和高效性。

标签:妙用,cookies,登录,get,复用,获取,Cookie,cookie
From: https://www.cnblogs.com/hogwarts/p/18094092

相关文章

  • Django cookie与session,CBV如何添加装饰器
    cookie与session简介会话跟踪技术什么是会话跟踪?我们需要先了解一下什么是会话!可以把会话理解为客户端与服务器之间的一次会晤,在一次会晤中可能会包含多次请求和响应。例如你给10086打个电话,你就是客户端,而10086服务人员就是服务器了。从双方接通电话那一刻起,会话就开始了,到某......
  • 网络模型 IO多路复用原理
    网络模型IO多路复用原理网络模型中的I/OI/OI/O多路复用是一种高效的......
  • cookie、session、token 区别
    title:cookie、session、token区别search:2024-03-20tags:“#cookie、session、token区别”cookie、session、token区别Tips:他们本质上是不同的,但是都跟维持状态信息有关一、三者在登录业务上的区别维持状态信息:当我们登录之后,如果我们希望后续所有的页面......
  • cookie一致性
    非跨域cookie一致性解决请求拦截器importjavax.servlet.http.Cookie;importjavax.servlet.http.HttpServletRequest;importjavax.servlet.http.HttppServletResponse;importorg.springframework.web.servlet.HandlerInterceptor;@ComponentpublicclassCustomIntercepto......
  • 复用与多址的联系与区别
    开头请记住一句话:复用针对资源,多址针对用户。一、复用1、复用是指一个信道传输多个信号,以提高资源利用率,针对的是信道资源。相当于高速公路上的车道,车道越多,传输速率越快,资源利用率也越高。2、分类:FDM/TDM/CDM/SDM二、多址1、多址是指多个用户共同接入......
  • outputStream(输出流)转inputstream(输入流)以及输入流如何复用
    https://blog.csdn.net/xuxu_study/article/details/129992752文件、流之间的转换MultipartFile转inputstream(输入流)outputStream(输出流)转为inputstream(输入流)inputstream(输入流)转ByteArrayOutputStreamMultipartFile文件直接转输入流上传和生成摘要MultipartFile文件需要......
  • Http-Only Cookie
    Http-OnlyCookie  设置Cookie的时候,如果服务器加上了HttpOnly属性,则这个Cookie无法被JavaScript读取(即document.cookie不会返回这个Cookie的值),只用于向服务器发送。Set-Cookie:key=value;HttpOnly上面的这个Cookie将无法用JavaScript获取。进行AJAX操作时,XMLHtt......
  • Koa项目总结五:Koa项目中cookie和session的配置和使用
    Koa项目总结五:Koa项目中cookie和session的配置和使用joyitsai关注IP属地:山东0.282019.05.2623:52:45字数1,326阅读2,4751.Cookie介绍:Cookie是保存在浏览器中的数据,可以让我们在同一个浏览器访问同一个域名时共享cookie数据。1.1使用cookie,可实现的几个常用场景:......
  • C IO复用select, epoll 简单总结
    1.文件描述符类型REG:文件DIR:目录CHR:字符BLK:块设备UNIX:unix域套接字FIFO:先进先出队列IPv4:网际协议(IP)套接字其中,标准输入STDIN(0)和STDOUT输出(1),STDERR错误(2)为指定的值2.  IO复用模型(1).select(在指定的一段时间内,轮询监听用户需要的文件描述符(用户添加到fd......
  • 拓扑的妙用
    拓扑的妙用拓扑不仅可以用于求DAG的拓扑序,还可以判断是否有环。用sum存储拓扑到点的个数,若sum小于实际点数,说明有环。P1347排序成功排序即为有确定拓扑序矛盾即为有环code:注:27行,sum++;......