《手把手教你》系列技巧篇(三十一)-java+ selenium自動化測試- Actions的相關操作-番外篇(詳解教程)

巨集哥 發表於 2021-10-14
Java 自動化測試

1.簡介

  上一篇中,巨集哥說的巨集哥在最後提到網站的反爬蟲機制,那麼巨集哥在自己本地做一個網頁,沒有那個反爬蟲的機制,谷歌瀏覽器是不是就可以驗證成功了,巨集哥就想驗證一下自己想法,於是寫了這一篇文章,另外也是相對前邊做一個簡單的總結分享給小夥伴們或者童鞋們。廢話不多數,直接進入今天的主題。

2.滑鼠操作

  WebElement的click()方法可實現元素的點選操作,但是沒有提供滑鼠的右擊/雙擊/懸停/滑鼠拖動等操作.這些操作需要通過Action類提供的方法來實現!

2.1Action常用的API

Action常用的API如下:

1. contextClick() 右擊

2. clickAndHold() 滑鼠懸停

3. move_to_element() 滑鼠懸停

4. doubleClick() 雙擊

5. dragAndDrop() 拖動

6. release() 釋放滑鼠

7. perform() 執行所有Action中的儲存行為

2.2演示模擬驗證碼點選拖動場景

例如:演示模擬驗證碼點選拖動場景示例如下:

《手把手教你》系列技巧篇(三十一)-java+ selenium自動化測試- Actions的相關操作-番外篇(詳解教程)

《手把手教你》系列技巧篇(三十一)-java+ selenium自動化測試- Actions的相關操作-番外篇(詳解教程)

《手把手教你》系列技巧篇(三十一)-java+ selenium自動化測試- Actions的相關操作-番外篇(詳解教程)

3.程式碼準備

3.1前端HTML程式碼

前端HTML程式碼如下:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>北京-巨集哥 滑動條</title>
    <link rel="stylesheet" href="drag.css">
    <script src="jquery-1.7.1.min.js"></script>
    <script src="drag.js"></script>
    <style type="text/css">
        .slidetounlock{
            font-size: 12px;
            background:-webkit-gradient(linear,left top,right top,color-stop(0,#4d4d4d),color-stop(.4,#4d4d4d),color-stop(.5,#fff),color-stop(.6,#4d4d4d),color-stop(1,#4d4d4d));
            -webkit-background-clip:text;
            -webkit-text-fill-color:transparent;
            -webkit-animation:slidetounlock 3s infinite;
            -webkit-text-size-adjust:none
        }
        @-webkit-keyframes slidetounlock{0%{background-position:-200px 0} 100%{background-position:200px 0}}
        .button1 {
            background-color: #f44336; 
            border: none;
            color: white;
            padding: 15px 32px;
            text-align: center;
            text-decoration: none;
            display: inline-block;
            font-size: 28px;
            margin-bottom: 100px;
            text-decoration:none;
            color: white;
        }
        #myAnchor
        {
          text-decoration:none;
          color: white;
        }
    </style>
</head>
<body>
<div id="wrapper" style="position: relative;top: 300px;left:300px;">
    <button class="button1"><a id="myAnchor" href="https://www.cnblogs.com/du-hong/">北京-巨集哥</a></button></br>
    <div id="drag">
        <div class="drag_bg"></div>
        <div class="drag_text slidetounlock" onselectstart="return false;" unselectable="on">
            請按住滑塊,拖動到最右邊
        </div>
        <div class="handler handler_bg"></div>
    </div>
</div>

    <!--<a href="#" class="img"><img src="img/Lighthouse.jpg"/></a>-->
<script>
    $('#drag').drag();
</script>
</body>
</html>

3.2滑塊CSS樣式

HTML滑塊CSS樣式程式碼如下:

#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程式碼如下:

$.fn.drag = function(options) {
    var x, drag = this, isMove = false, defaults = {
    };
    var options = $.extend(defaults, options);
    var handler = drag.find('.handler');
    var drag_bg = drag.find('.drag_bg');
    var text = drag.find('.drag_text');
    var maxWidth = drag.width() - handler.width();  //能滑動的最大間距

    //滑鼠按下時候的x軸的位置
    handler.mousedown(function(e) {
        isMove = true;
        x = e.pageX - parseInt(handler.css('left'), 10);
    });

    //滑鼠指標在上下文移動時,移動距離大於0小於最大間距,滑塊x軸位置等於滑鼠移動距離
    $(document).mousemove(function(e) {
        var _x = e.pageX - x;// _x = e.pageX - (e.pageX - parseInt(handler.css('left'), 10)) = x
        if (isMove) {
            if (_x > 0 && _x <= maxWidth) {
                handler.css({'left': _x});
                drag_bg.css({'width': _x});
            } else if (_x > maxWidth) {  //滑鼠指標移動距離達到最大時清空事件
                dragOk();
            }
        }
    }).mouseup(function(e) {
        isMove = false;
        var _x = e.pageX - x;
        if (_x < maxWidth) { //滑鼠鬆開時,如果沒有達到最大距離位置,滑塊就返回初始位置
            handler.css({'left': 0});
            drag_bg.css({'width': 0});
        }
    });

    //清空事件
    function dragOk() {
        handler.removeClass('handler_bg').addClass('handler_ok_bg');
        text.removeClass('slidetounlock').text('驗證通過').css({'color':'#fff'});       //modify
       // drag.css({'color': '#fff !important'});

        handler.css({'left': maxWidth});                   // add
        drag_bg.css({'width': maxWidth});                  // add

        handler.unbind('mousedown');
        $(document).unbind('mousemove');
        $(document).unbind('mouseup');

    }
};

3.4jquery-1.7.1.min.js下載地址

 jquery-1.7.1.min.js下載連結:http://www.jqueryfuns.com/resource/2169

4.自動化程式碼實現

4.1程式碼設計

《手把手教你》系列技巧篇(三十一)-java+ selenium自動化測試- Actions的相關操作-番外篇(詳解教程)

4.2參考程式碼

package lessons;
import org.junit.Test;
import org.openqa.selenium.By;
import org.openqa.selenium.WebDriver;
import org.openqa.selenium.WebElement;
import org.openqa.selenium.chrome.ChromeDriver;
import org.openqa.selenium.interactions.Actions;

/**
 * @author 北京-巨集哥
 * 
 * 《手把手教你》系列技巧篇(三十一)-java+ selenium自動化測試- Actions的相關操作-番外篇(詳解教程)
 *
 * 2021年10月15日
 */
public class ActionsTest {
    
    @Test
    public void test() throws InterruptedException {
        
        System.setProperty("webdriver.gecko.driver", ".\\Tools\\chromedriver.exe");
        
        WebDriver driver =null;
        try {
            driver =new ChromeDriver();
            driver.get("file:///C:/Users/DELL/Desktop/test/MouseDrag/identifying_code.html");
            driver.manage().window().maximize();
            Actions actions = new Actions(driver);
            WebElement targetElement = driver.findElement(By.xpath("//*[@id=\"drag\"]/div[3]"));
            int x = targetElement.getLocation().getX();
            int y = targetElement.getLocation().getY();
            Thread.sleep(3000);
            //首先定位到方塊並點選=》移動到目標位置=》鬆開釋放滑鼠=》perform執行Actions的一系列方法呼叫
            actions.clickAndHold(targetElement).moveToElement(targetElement, x+260, y).release().perform();
            Thread.sleep(3000);
        }catch (Exception e) {
            e.printStackTrace();
        }
    }

}

4.3執行程式碼

1.執行程式碼,右鍵Run AS->Junit Test,控制檯輸出,如下圖所示:

《手把手教你》系列技巧篇(三十一)-java+ selenium自動化測試- Actions的相關操作-番外篇(詳解教程)

2.執行程式碼後電腦端的瀏覽器的動作,如下小視訊所示:

5.小結

巨集哥這裡用了單元測試的方法,當然你也可以用之前的方法進行測試,在這裡巨集哥就不在贅述!

 1.在設計程式碼過程中會報錯:Type mismatch: cannot convert from Test to Annotation   

解決辦法:參考巨集哥這篇文章的小結:https://www.cnblogs.com/du-hong/p/15189106.html