我爱编程

Selenium-java(XML-元素管理篇)

2017-05-09  本文已影响0人  Test木羽

Selenium-java(XML-元素管理篇)

有效的对页面元素管理有利于脚本的维护,避免修改代码引起不必要的麻烦。这里我使用到了xml对元素的管理。

<?xml version="1.0" encoding="UTF-8"?>
<!--登录页面元素-->
<LoginEleData>
    <!--账号输入框-->
    <property name="name_input" type="id" value="textfield-1009-inputEl"/>
    <!--密码输入框-->
    <property name="pwd_input" type="id" value="textfield-1010-inputEl"/>
    <!--保存密码勾选框-->
    <property name="save_pwd" type="id" value="checkbox-1013-inputEl"/>
    <!--登录按钮-->
    <property name="login_button" type="id" value="loginBtn-btnEl"/>
</LoginEleData>

这是一个举例的xml文件,我把各个元素信息写入其中。开始解析首先需要导入dom4j包。在maven项目pom文件中导入jar包。

<!-- https://mvnrepository.com/artifact/dom4j/dom4j -->
        <dependency>
            <groupId>dom4j</groupId>
            <artifactId>dom4j</artifactId>
            <version>1.6.1</version>
        </dependency>

开始封装获得元素方法了。

import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.io.SAXReader;

import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.IOException;
import java.io.InputStream;
import java.net.URL;


public class Dom4j {
    private String file;
    public Document document;
    private InputStream input = null;
    private Map<String,String[]> eles;

    public Dom4j(String file) {
        this.file = file;
        ClassLoader classLoader = Dom4j.class.getClassLoader();
        URL resource = classLoader.getResource(file);
        String path = resource.getPath();
        try {
            input = new FileInputStream(path);
        } catch (FileNotFoundException e) {
            e.printStackTrace();
            System.out.println("打开文件错误");
        }
        // 创建saxReader对象
        SAXReader reader = new SAXReader();
        // 通过read方法读取一个文件 转换成Document对象
        try {
            document = reader.read(input);
        } catch (DocumentException e) {
            e.printStackTrace();
        }
    }
  /**
     * 提供关闭文件方法
     */
    public void close() {
        try {
            input.close();
        } catch (IOException e) {
            e.printStackTrace();
            System.out.println("关闭文件错误");
        }

    }
    /**
     *提供一个从xml文件获取ele数组的方法
     * @return Map集合 通过name获取数组values
     * 数组第一位为类型   第二位为类型值
     */
    private Map<String,String[]> setele() {
        Iterator<Element> elements;
        Element property = null;
        eles = new HashMap<String, String[]>();
        //获取根节点元素对象
        Element node = super.document.getRootElement();
        //获得一个element列表迭代器
        elements = node.elements("property").iterator();
        while (elements.hasNext()) {
            property = elements.next();
            String[] ele =new String[2];
            ele[0] = property.attributeValue("type");
            ele[1] = property.attributeValue("value");
            eles.put(property.attributeValue("name"),ele);
        }
        close();
        return eles;
    }

    /**
     * 提供一个获取element元素集合
     * @return Map集合 通过name获取数组values
     * 数组第一位为类型   第二位为类型值
     */
    public Map<String,String[]> getele() {
        return this.setele();
    }

然后让我们开始获取页面的元素了。


上一篇 下一篇

猜你喜欢

热点阅读