Skip to content

Cookie 复用


uml diagram


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")
@Slf4j
public class LoginTest {
    static ObjectMapper mapper = new ObjectMapper(new YAMLFactory());
    static WebDriver driver;

    @BeforeAll
    static void setUp(){
        ChromeOptions options = new ChromeOptions();
        //防止连接报错
        options.addArguments("--remote-allow-origins=*");
        driver = new ChromeDriver(options);
    }

    @Test
    void dumpCookie() throws  IOException {
        // 保存cookie
        ObjectMapper mapper = new ObjectMapper(new YAMLFactory());
        String url = "https://work.weixin.qq.com/wework_admin/frame";
        // 1. 访问企业微信主页
        driver.get(url);
        // 2. 判断url是否登录成功
        WebDriverWait wait = new WebDriverWait(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(new File("cookies.yaml"), cookies);

    }

    @Test
    void loadCookie() throws IOException {
        String url = "https://work.weixin.qq.com/wework_admin/frame";
        // 访问企业微信主页
        driver.get(url);
        // 使用 cookie 登录
        // 1.声明一个泛型
        TypeReference<List<HashMap<String, Object>>> typeReference =
                new TypeReference<>() {};
        // 2. 从yaml中获取cookies
        List<HashMap<String, Object>> loadCookies =
                mapper.readValue(new File("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(
                            new Cookie(cookie.get("name").toString(),
                                    cookie.get("value").toString()));
                });
        // 4. 刷新页面,登录成功
        driver.navigate().refresh();
    }
}

常见问题

  1. 企业微信等具有互踢机制
  2. 获取cookie时为登录成功状态。
  3. 复用 cookie 之后的验证问题

总结

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