《刚刚问世》系列初窥篇-Java+Playwright自动化测试-21
1.简介上一篇中,主要是介绍了拖拽的各种方法的理论知识以及实践,今天宏哥讲解和分享一下划取字段操作。例如:需要在一堆log字符中随机划取一段文字,然后右键选择摘取功能。
2.划取字段操作
划取字段操作就是在一段文字中随机选中一段文字,或者在标记文字。当然了,这个在一些网站的登录也需要滑块验证等。
selenium中提供了ActionChains类来处理鼠标事件。这个类中有2个方法和滑块移动过程相关。click_and_hold():模拟按住鼠标左键在源元素上,点击并且不释放;release():松开鼠标按键。字面意思就可以理解这2个函数的作用。今天跟随宏哥看一下,playwright是如何处理这种测试场景的。
3.牛刀小试
3.1dragTo()
在一段文字中,随机划取一小段文字(这个感觉比较鸡肋,貌似没有什么卵用,但是宏哥还是说一下吧)。那么宏哥就用度娘的免责声明进行实践,划取其中的一小段文字。
使用locator.dragTo()执行拖放操作,实现自动化测试。
3.1.1代码设计
3.1.2参考代码
package com.bjhg.playwright; import com.microsoft.playwright.Browser; import com.microsoft.playwright.BrowserContext; import com.microsoft.playwright.BrowserType; import com.microsoft.playwright.Page; import com.microsoft.playwright.Playwright; /** * @author 北京-宏哥 * * @公众号:北京宏哥(微信搜索,关注宏哥,提前解锁更多测试干货) * * 《刚刚问世》系列初窥篇-Java+Playwright自动化测试-21-操作鼠标拖拽 -中篇(详细教程) * * 2024年10月11日 */ public class Test_DragTo { public static void main(String[] args) { try (Playwright playwright = Playwright.create()) { //1.使用chromium浏览器,# 浏览器配置,设置以GUI模式启动Chrome浏览器(要查看浏览器UI,在启动浏览器时传递 headless=false 标志。您还可以使用 slowMo 来减慢执行速度。 Browser browser = playwright.chromium().launch(new BrowserType.LaunchOptions().setHeadless(false).setSlowMo(3000)); //2.创建context BrowserContext context = browser.newContext(); //创建page Page page = context.newPage(); //3.浏览器访问demo page.navigate("https://www.baidu.com/duty"); //4.开始拖拽划线 page.locator("//*/p").dragTo(page.locator("//*/ul[@class='privacy-ul-gap']/li")); System.out.println("Test Pass"); //关闭page page.close(); //关闭browser browser.close(); } } }
3.1.3运行代码
1.运行代码,右键Run As->Java Application,就可以看到控制台输出,如下图所示:
2.运行代码后电脑端的浏览器的动作(可以看到划取了一段内容,和我们平时按住鼠标左键滑动鼠标划取大同小异)。如下图所示:
3.2dragAndDrop()
使用page.dragAndDrop(locator, loacator),实现自动化测试。
3.2.1代码设计
3.2.2参考代码
package com.bjhg.playwright; import com.microsoft.playwright.Browser; import com.microsoft.playwright.BrowserContext; import com.microsoft.playwright.BrowserType; import com.microsoft.playwright.Page; import com.microsoft.playwright.Playwright; /** * @author 北京-宏哥 * * @公众号:北京宏哥(微信搜索,关注宏哥,提前解锁更多测试干货) * * 《刚刚问世》系列初窥篇-Java+Playwright自动化测试-21-操作鼠标拖拽 -中篇(详细教程) * * 2024年10月11日 */ public class Test_DragTo { public static void main(String[] args) { try (Playwright playwright = Playwright.create()) { //1.使用chromium浏览器,# 浏览器配置,设置以GUI模式启动Chrome浏览器(要查看浏览器UI,在启动浏览器时传递 headless=false 标志。您还可以使用 slowMo 来减慢执行速度。 Browser browser = playwright.chromium().launch(new BrowserType.LaunchOptions().setHeadless(false).setSlowMo(3000)); //2.创建context BrowserContext context = browser.newContext(); //创建page Page page = context.newPage(); //3.浏览器访问demo page.navigate("https://www.baidu.com/duty"); //4.开始拖拽划线 //page.locator("//*/p").dragTo(page.locator("//*/ul[@class='privacy-ul-gap']/li")); page.dragAndDrop("//*/p", "//*/ul[@class='privacy-ul-gap']/li"); System.out.println("Test Pass"); //关闭page page.close(); //关闭browser browser.close(); } } }
3.2.3运行代码
1.运行代码,右键Run As->Java Application,就可以看到控制台输出,如下图所示:
2.运行代码后电脑端的浏览器的动作。如下图所示:
4.项目实战
这里宏哥用java+selenium中的携程旅行,手机号查单页面的一个滑动,进行项目实战,结果发现挂了,携程取消了,可以能是用的人太多了吧,然后宏哥继续逛,果然皇天不负有心人啊,在其上边又找的一个滑动验证的地址(注册颜面),不过需要先点击同意协议才可以使用的哦,写代码的时候要注意了,地址:https://passport.ctrip.com/user/reg/home ,如下图所示:
4.1思路说明
[*]使用locator定位到要拖动滑块元素,如元素名叫ele
[*]获取元素ele的bounding_box含4分属性值:x,y,width,height
[*]把鼠标移动到元素ele的中心点,中心点位置为:x+width/2,y+height/2
[*]按下鼠标
[*]计算出要移动的下一个位置,以长条滑块为例,拖动到长条头部实现解锁,那x的位置应该为x+width/2 + 某个固定值(足够大就好)
[*]执行移动操作,下一个位置坐标为:x+width/2 + 某个固定值,y+height/2
[*]释放鼠标
4.2调用方法
[*]元素定位:page.locator();
[*]获取元素位置及大小:ele.boundingBox();
[*]鼠标移动:page.mouse().move();
[*]按下鼠标:page.mouse().down();
[*]释放鼠标:page.mouse().up();
4.3代码设计
4.4参考代码
package com.bjhg.playwright; import com.microsoft.playwright.Browser; import com.microsoft.playwright.BrowserContext; import com.microsoft.playwright.BrowserType; import com.microsoft.playwright.Locator; import com.microsoft.playwright.Page; import com.microsoft.playwright.Playwright; /** * @author 北京-宏哥 * * @公众号:北京宏哥(微信搜索,关注宏哥,提前解锁更多测试干货) * * 《刚刚问世》系列初窥篇-Java+Playwright自动化测试-21-操作鼠标拖拽 -中篇(详细教程) * * 2024年10月11日 */ public class Test_DragDemo { public static void main(String[] args) { try (Playwright playwright = Playwright.create()) { //1.使用chromium浏览器,# 浏览器配置,设置以GUI模式启动Chrome浏览器(要查看浏览器UI,在启动浏览器时传递 headless=false 标志。您还可以使用 slowMo 来减慢执行速度。 Browser browser = playwright.chromium().launch(new BrowserType.LaunchOptions().setHeadless(false).setSlowMo(3000)); //2.创建context BrowserContext context = browser.newContext(); //创建page Page page = context.newPage(); //3.浏览器访问demo page.navigate("https://passport.ctrip.com/user/reg/home"); page.locator("//*[@id='agr_pop']/div/a").click(); //4.开始拖拽 //获取拖动按钮位置并拖动 Locator slider = page.locator("//*[@id='slideCode']/div/div"); // 使用鼠标滑动滑块 page.mouse().move(slider.boundingBox().x + slider.boundingBox().width / 2, slider.boundingBox().y + slider.boundingBox().height / 2); page.mouse().down(); // 根据滑动的范围,这里使用滑动最大距离 page.mouse().move(slider.boundingBox().x + slider.boundingBox().width / 0.5+300, slider.boundingBox().y + slider.boundingBox().height / 2); page.mouse().up(); page.pause(); System.out.println("Test Pass"); //关闭page page.close(); //关闭browser browser.close(); } } }
4.5运行代码
1.运行代码,右键Run As->Java Application,就可以看到控制台输出,如下图所示:
2.运行代码后电脑端的浏览器的动作(滑动并验证通过,但是由于反爬虫机制,看的不是很清楚)。如下图所示:
3.之前宏哥也是用这个网站演示的,宏哥不是打广告也没有付宏哥广告费,因此之前跟随宏哥学习的有些小伙伴和同学们私信宏哥,说那不是发爬虫机制,是因为你没有滑动验证成功,所以才出现二次验证机制。宏哥没有多做解释。好吧,那就用事实说话吧,宏哥就用断点调试让小伙伴或者童鞋们自己看一下,到底第一步的滑动验证有没有成功。
4.运行代码后电脑端的浏览器的动作(宏哥手动点击验证这个反爬虫的验证,然后可以清楚的看的第一步滑动验证是成功的。。。。并不是私信说的那样子吧),如下图所示:
5.小结
之前宏哥在java+selenium的文章中测试的时候,就会跳转到这个页面,之前说的是selenium检查机制,但是这里没有用selenium,怎么还会有这个,查了半天资料说是反爬虫机制。但是代码中加入反爬虫的机制不好使。有知道怎么回事的可以给宏哥留言。
5.1测试网站
测试链接:https://bot.sannysoft.com/
正常浏览结果:
宏哥然后加入暂停代码(page.pause()),在这个页面用网址监测一下,看到绕过Chrome的selenium反爬虫检测机制,但是还是会出现那个选择字的验证。查了半天也不知道怎么回事,有知道给宏哥留言,让宏哥学习学习。如下图所示:
好了,时间不早了,今天就分享和讲解到这里。
公众号(关注宏哥) 微信群(扫码进群) 客服微信
来源:程序园用户自行投稿发布,如果侵权,请联系站长删除
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!
页:
[1]