Selenium模拟浏览器自动上传文件的操作实现

天行健,君子以自强不息;地势坤,君子以厚德载物。


每个人都有惰性,但不断学习是好好生活的根本,共勉!


文章均为学习整理笔记,分享记录为主,如有错误请指正,共同学习进步。


执行程序前请先配置驱动:
关于Java selenium使用前浏览器驱动的下载和环境变量的配置
关于Selenium自动化测试工具的Java实现详情请参考文章:
如何查看页面对应的Selenium定位参数
Java实现 selenium Web自动化测试(简单篇)
Java实现 selenium Web自动化测试(详细篇)


1. 上传文件的html网页

先编写一个带有上传文件功能的html网页
upfile.html

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta http-equiv="content-type" content="text/html;charset=utf-8" />
  <title>upload_file</title>
  <!--bootstrap 核心 CSS 文件-->
  <link href="http://cdn.bootcss.com/bootstrap/3.3.0/css/bootstrap.min.css" rel="stylesheet" >
</head>
<body>
<div class="row-fluid">
  <div class="span6 well">
    <h3>文件上传</h3>
    <p></p>
    <br>
    <br>
    <input type="file" name="file" id="fu" />
<!--    <button id="btn" type="button" name="BTN">提交按钮</button>-->
  </div>
</div>
</body>
<!--<script src="http://cdn.bootcss.com/jquery/1.11.1/jquery.min.js"></script>-->

<!--bootstrap 核心 javascript 文件-->
<script src="http://cdn.bootcss.com/bootstrap/3.3.0/js/bootstrap.min.js"></script>
</html>

2. 访问html

上面的html的完成路径,访问html

        //这里有一个上传文件的html文件,访问该文件可以测试上传文件的按钮
        webDriver.get("E:\\PROJECTS\\MYSELF\\libai-multifunctional-platform\\src\\main\\java\\com\\libai\\test\\selenium\\chrome\\html\\upfile.html");

3. 所需上传的文件

本地准备一个文件,把完整路径定义一个变量

        // 需要上传的文件的本地路径
        String filePath = "F:\\CSDN\\CsdnFileBg\\selenium20240509.png";

4. 定位

定位要上传的位置

        //定位到html中上传文件的输入位置
        WebElement kw = webDriver.findElement(By.id("fu"));

5. 上传

通过sendKeys上传

        //通过sendKeys传入文件全路径,执行程序后可以看到文件被选中后显示在文件上传按钮后面
        kw.sendKeys(filePath);

6. 完整代码

FileUploadTest.java

package com.libai.test.selenium.chrome;

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.chrome.ChromeOptions;

import java.io.File;

/**
 * @ClassDescription: 文件上传模拟
 * @JdkVersion: 1.8
 * @Author: 李白
 * @Created: 2024/5/9 9:34
 */
public class FileUploadTest {
    public static void main(String[] args) throws InterruptedException {
        //指定驱动,第一个参数为驱动名称,不同浏览器的参数名称不一样,请根据浏览器查询到对应的浏览器参数名,第二个参数为驱动文件路径,即驱动完整文件路径
        System.setProperty("webdriver.chrome.driver", "D:\\JavaSoftWares\\Google\\driver\\chromedriver-win64\\chromedriver.exe");
        // 谷歌驱动
        ChromeOptions cops = new ChromeOptions();
        // 允许所有请求
        cops.addArguments("--remote-allow-origins=*");
        //默认设置开始打开网页时窗口最大化
        cops.addArguments("--start-maximized");
        //创建驱动对象
        WebDriver webDriver = new ChromeDriver(cops);
        // 启动需要打开的网页
//        webDriver.get("https://www.baidu.com");
        //这里有一个上传文件的html文件,访问该文件可以测试上传文件的按钮
        webDriver.get("E:\\PROJECTS\\MYSELF\\libai-multifunctional-platform\\src\\main\\java\\com\\libai\\test\\selenium\\chrome\\html\\upfile.html");
//        webDriver.get("./chrome/html/upfile.html");
        //指定窗口大小--最大化
//        webDriver.manage().window().maximize();


        //上传文件主要通过sendKeys
        // 需要上传的文件的本地路径
        String filePath = "F:\\CSDN\\CsdnFileBg\\selenium20240509.png";
        //定位到html中上传文件的输入位置
        WebElement kw = webDriver.findElement(By.id("fu"));
        Thread.sleep(3000);
        //通过sendKeys传入文件全路径,执行程序后可以看到文件被选中后显示在文件上传按钮后面
        kw.sendKeys(filePath);
        Thread.sleep(3000);
        //提交按钮
//        webDriver.findElement(By.id("btn")).click();
        Thread.sleep(3000);


        //关闭资源(关闭浏览器)
        webDriver.close();

    }
}

7. 浏览器自动操作的截图

首先会将html页面用浏览器打开
在这里插入图片描述

然后会将本地文件上传到页面
在这里插入图片描述


感谢阅读,祝君暴富!

  • 9
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

寒山李白

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值