找回密码
 立即注册
首页 业界区 业界 Java+Playwright自动化测试-22- 操作鼠标拖拽 - 下篇 ...

Java+Playwright自动化测试-22- 操作鼠标拖拽 - 下篇

冷晓晴 2025-9-26 11:32:36
1.简介

上一篇中,宏哥说的宏哥在最后提到网站的反爬虫机制,那么宏哥在自己本地做一个网页,没有那个反爬虫的机制,谷歌浏览器是不是就可以验证成功了,宏哥就想验证一下自己想法,其次有人私信宏哥说是有那种类似拼图的验证码如何处理。于是写了这一篇文章,另外也是相对前边做一个简单的总结分享给小伙伴们或者童鞋们。废话不多数,直接进入今天的主题。
2.滑动验证码

2.1演示模拟验证码点击拖动场景

例如:演示模拟验证码点击拖动场景示例如下:
1.png

2.png

3.png

3.代码准备

3.1前端HTML代码

前端HTML代码如下:
  1.   北京-宏哥 滑动条  北京-宏哥</p><p> 请按住滑块,拖动到最右边
复制代码
3.2滑块CSS样式

HTML滑块CSS样式代码如下:
  1. #drag{ position: relative; background-color: #e8e8e8; width: 300px; height: 34px; line-height: 34px; text-align: center; } #drag .handler{ position: absolute; top: 0px; left: 0px; width: 40px; height: 32px; border: 1px solid #ccc; cursor: move; } .handler_bg{ background: #fff url("../img/slider.png") no-repeat center; } .handler_ok_bg{ background: #fff url("../img/complet.png") no-repeat center; } #drag .drag_bg{ background-color: #7ac23c; height: 34px; width: 0px; } #drag .drag_text{ position: absolute; top: 0px; width: 300px; color:#9c9c9c; -moz-user-select: none; -webkit-user-select: none; user-select: none; -o-user-select:none; -ms-user-select:none; font-size: 12px; // add }
复制代码
3.3滑块拖拽JS

滑块拖拽JS代码如下:
  1. $.fn.drag = function(options) { var x, drag = this, isMove = false, defaults = { }; var options = $.extend(defaults, options); var handler = drag.find(&#39;.handler&#39;); var drag_bg = drag.find(&#39;.drag_bg&#39;); var text = drag.find(&#39;.drag_text&#39;); var maxWidth = drag.width() - handler.width(); //能滑动的最大间距 //鼠标按下时候的x轴的位置 handler.mousedown(function(e) { isMove = true; x = e.pageX - parseInt(handler.css(&#39;left&#39;), 10); }); //鼠标指针在上下文移动时,移动距离大于0小于最大间距,滑块x轴位置等于鼠标移动距离 $(document).mousemove(function(e) { var _x = e.pageX - x;// _x = e.pageX - (e.pageX - parseInt(handler.css(&#39;left&#39;), 10)) = x if (isMove) { if (_x > 0 && _x <= maxWidth) { handler.css({&#39;left&#39;: _x}); drag_bg.css({&#39;width&#39;: _x}); } else if (_x > maxWidth) { //鼠标指针移动距离达到最大时清空事件 dragOk(); } } }).mouseup(function(e) { isMove = false; var _x = e.pageX - x; if (_x < maxWidth) { //鼠标松开时,如果没有达到最大距离位置,滑块就返回初始位置 handler.css({&#39;left&#39;: 0}); drag_bg.css({&#39;width&#39;: 0}); } }); //清空事件 function dragOk() { handler.removeClass(&#39;handler_bg&#39;).addClass(&#39;handler_ok_bg&#39;); text.removeClass(&#39;slidetounlock&#39;).text(&#39;验证通过&#39;).css({&#39;color&#39;:&#39;#fff&#39;}); //modify // drag.css({&#39;color&#39;: &#39;#fff !important&#39;}); handler.css({&#39;left&#39;: maxWidth}); // add drag_bg.css({&#39;width&#39;: maxWidth}); // add handler.unbind(&#39;mousedown&#39;); $(document).unbind(&#39;mousemove&#39;); $(document).unbind(&#39;mouseup&#39;); } };
复制代码
3.4jquery-1.7.1.min.js下载地址

 jquery-1.7.1.min.js下载链接:http://www.jqueryfuns.com/resource/2169
3.5demo滑动演示效果

最后用浏览器打开HTML文件,看一下效果如下图所示:
4.gif

4.自动化代码实现

4.1代码设计

5.png

4.2参考代码
  1. 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自动化测试-22- 操作鼠标拖拽 - 下篇(详细教程) * * 2024年10月08日 */ public class Test_Drag_Demo { 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("E:\\Desktop\\test\\MouseDrag\\identifying_code.html"); //4.开始拖拽 //*[@id=&#39;drag&#39;]/div[3] //获取拖动按钮位置并拖动 Locator slider = page.locator("//*[@id=&#39;drag&#39;]/div[3]"); // 使用鼠标滑动滑块 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(); System.out.println("Test Pass"); //关闭page page.close(); //关闭browser browser.close(); } } }
复制代码
4.3运行代码

1.运行代码,右键Run As->Java Application,就可以看到控制台输出,如下图所示:
6.png

2.运行代码后电脑端的浏览器的动作。如下图所示:
7.gif

5.项目实战

闲暇之际,宏哥突然想到以前的一个网站,于是抱着试一试的想法看看能不能找到这样的一个演示实例,果然皇天不负有心人,在:https://www.jq22.com/ 找了一个demo(也是没有发爬虫机制的)用于演示:https://www.jq22.com/demo/slideVerify201909022305/。如下图所示:
8.gif

5.1代码设计

9.png

5.2参考代码
  1. 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_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.jq22.com/demo/slideVerify201909022305/"); //4.开始拖拽 //获取拖动按钮位置并拖动: Locator slider = page.locator("//*[@id=&#39;verify-wrap&#39;]/span[1]"); // 使用鼠标滑动滑块 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(); System.out.println("Test Pass"); //关闭page page.close(); //关闭browser browser.close(); } } }
复制代码
5.3运行代码

1.运行代码,右键Run As->Java Application,就可以看到控制台输出,如下图所示:
10.png

2.运行代码后电脑端的浏览器的动作(滑动并验证通过)。如下图所示:
11.gif

6.小结

好了,今天时间也不早了,宏哥就讲解和分享到这里,感谢您耐心的阅读,希望对您有所帮助。
公众号(关注宏哥)                      微信群(扫码进群)                             客服微信
12.png
13.png
14.png


来源:程序园用户自行投稿发布,如果侵权,请联系站长删除
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!

相关推荐

您需要登录后才可以回帖 登录 | 立即注册