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

简介: 本文介绍了Cookie在Web自动化登录中的应用。Cookie是存储在浏览器上的认证数据,用于身份验证和记录登录信息。通过获取和管理Cookie,自动化测试时可模拟用户登录状态,提高测试效率。使用Cookie自动化登录的步骤包括:登录获取Cookie、存储Cookie、读取Cookie并植入浏览器。Python和Java示例代码展示了如何实现这一过程。常见问题提醒注意Cookie的有效性和互踢机制,确保自动化测试的顺利进行。

image.png

简介

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

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

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

为什么要使用 Cookie 自动化登录

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

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

image.png

使用 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,更涉及到复用登录凭证,以减少繁琐的重复登录步骤,从而提高测试效率。这一技巧的核心在于有效地利用已有的登录状态,为测试过程增添便捷性和高效性。

相关文章
|
6月前
|
SQL 前端开发 程序员
【面试题】前端开发中如何高效渲染大数据量?
【面试题】前端开发中如何高效渲染大数据量?
121 0
|
27天前
|
缓存 算法 JavaScript
纯函数在实际开发中的应用场景有哪些
纯函数在实际开发中广泛应用,如React等框架的状态管理、数据处理和验证、缓存机制等,因其无副作用、可预测性及易于测试的特点,提升了代码的可靠性和维护性。
|
2月前
|
存储 前端开发 JavaScript
高效组件的设计与封装之道
本文结合了作者自身碰到的场景来说明如何做好组件设计和封装。
|
23天前
|
存储 安全 Java
Map的并发处理,助你提升编程效率,代码更优雅高效。
【10月更文挑战第19天】Map使用技巧大公开:从选择合适的Map实现(如HashMap、TreeMap、LinkedHashMap)到利用Map的初始化、使用Map.Entry遍历、运用computeIfAbsent和computeIfPresent方法,再到Map的并发处理,助你提升编程效率,代码更优雅高效。
24 2
|
1月前
|
安全 数据安全/隐私保护 UED
优化用户体验:前后端分离架构下Python WebSocket实时通信的性能考量
在当今互联网技术的迅猛发展中,前后端分离架构已然成为主流趋势,它不仅提升了开发效率,也优化了用户体验。然而,在这种架构模式下,如何实现高效的实时通信,特别是利用WebSocket协议,成为了提升用户体验的关键。本文将探讨在前后端分离架构中,使用Python进行WebSocket实时通信时的性能考量,以及与传统轮询方式的比较。
64 2
|
2月前
|
API 数据处理 数据库
掌握 Kotlin Flow 的艺术:让无限数据流处理变得优雅且高效 —— 实战教程揭秘如何在数据洪流中保持代码的健壮与灵活
Kotlin Flow 是一个强大的协程 API,专为处理异步数据流设计。它适合处理网络请求数据、监听数据库变化等场景。本文通过示例代码展示如何使用 Kotlin Flow 管理无限流,如实时数据流。首先定义了一个生成无限整数的流 `infiniteNumbers()`,然后结合多种操作符(如 `buffer`、`onEach`、`scan`、`filter`、`takeWhile` 和 `collectLatest`),实现对无限流的优雅处理,例如计算随机数的平均值并在超过阈值时停止接收新数据。这展示了 Flow 在资源管理和逻辑清晰性方面的优势。
61 0
|
3月前
|
缓存 NoSQL 数据库
【超实用秘籍】FastAPI高手教你如何通过最佳实践构建高效Web应用:从代码组织到异步编程与缓存优化的全方位指南!
【8月更文挑战第31天】FastAPI凭借出色性能和易用性成为现代Web应用的首选框架。本文通过示例代码介绍构建高效FastAPI应用的最佳实践,包括开发环境搭建、代码模块化组织、异步编程及性能优化等。通过模块化设计和异步数据库操作,结合缓存技术,大幅提升应用性能与可维护性,助您轻松应对高并发场景。
197 0
|
3月前
|
数据采集 XML C#
C#简化工作之实现网页爬虫获取数据
C#简化工作之实现网页爬虫获取数据
53 1
|
3月前
|
缓存 监控 中间件
构建高效的Go语言Web服务器:基于Fiber框架的性能优化实践
在追求极致性能的Web开发领域,Go语言(Golang)凭借其高效的并发处理能力、垃圾回收机制及简洁的语法赢得了广泛的青睐。本文不同于传统的性能优化教程,将深入剖析如何在Go语言环境下,利用Fiber这一高性能Web框架,通过精细化配置、并发策略调整及代码层面的微优化,构建出既快速又稳定的Web服务器。通过实际案例与性能测试数据对比,揭示一系列非直觉但极为有效的优化技巧,助力开发者在快节奏的互联网环境中抢占先机。
|
5月前
|
数据采集 存储 监控
构建高效爬虫系统:设计思路与案例分析
构建高效爬虫系统涉及关键模块如爬虫引擎、链接存储、内容处理器等,以及用户代理池、IP代理池等反反爬策略。评估项目复杂性考虑数据规模、网站结构、反爬虫机制等因素。案例分析展示了电子商务价格比较爬虫的设计,强调了系统模块化、错误处理和合规性的重要性。爬虫技术需要不断进化以应对复杂网络环境的挑战。
124 1