atitit.浏览器web gui操作类库 和 操作chrome浏览器的类库使用总结

atitit.浏览器web gui操作类库 和 操作chrome浏览器的类库使用总结

1. 常见标准 1

1.1. 录制重放 1

1.2. 一个窗体一个proxy cookie 1

1.3. exec js 1

1.4. js 调用java 1

1.5. 修改dom属性 2

1.6. 关键字驱动 2

1.7. 加载js类库 2

1.8. 一个窗口一个代理 2

1.9. 独立窗口cookie 2

1.10. 无图模式支持 2

1.11. 支持自定义路径 2

2. 框架选型selenium2(webdriver)  QTP 2

3. 操作chrome浏览器 3

3.1. chromedriver 3

3.2. 自定义路径 3

3.3. 独立窗口代理器 3

3.4. 无图模式 3

3.5. code 3

1. 常见标准

1.1. 录制重放

这个功能好.不熟悉的时候儿直接能使用...相像help chm雅十..

1.2. 一个窗体一个proxy cookie

webdrive的ff可以。。swt browser,native swing的都是ie默认,改ff可麻烦了。。

1.3. exec js

作者:: 老哇的爪子 Attilax 艾龙,  EMAIL:[email protected]

转载请注明来源: http://blog.csdn.net/attilax

1.4. js 调用java

一般是浏览器扩展,,js调用。。如果不支持,只能使用cookie的方式了。。

1.5.  修改dom属性

通过js或者 后台的dom操作。ie com 可通过后台dom,webdrive,swt browser是通过js

1.6. 关键字驱动

”,测试人员不需要“录制”测试脚本,而可以改成“设计”测试脚本。即:先将应用程序的GUI 对象添加到QTP的对象仓库(Object Repository)中,然后针对每一个需要操作到的对象设计每个测试步骤。我个人感觉,这的确是一个很酷的特性,它使我们可以不必实际去操作应用程 序,就可以编写出测试脚本,这样做既节省了时间,而且还有一个更大的好处就是可以在应用程序还没有设计完成,或者由于出错无法正常执行的时候仍然可以编写 我们的测试脚本。应用程序只需要有使用界面(UI),而不必实际运行,测试人员就可以开始建立测试脚本,为我们实施自动化测试赢得更充足的时间。而

1.7. 加载js类库

原理一般是创建一个script 标签....添加js

1.8. 一个窗口一个代理

1.9. 独立窗口cookie

1.10. 无图模式支持

1.11. 支持自定义路径

2. 框架选型selenium2(webdriver)  QTP

3. 操作chrome浏览器

3.1. chromedriver

// 在java程序中添加

System.setProperty("webdriver.chrome.driver", pathx.classPathParent()+ "\\chromedriver.exe");

selenium不能直接操作chrome,要通过这个驱动...

3.2. 自定义路径

ChromeOptions co = new ChromeOptions();

co.setBinary(path);

}

return new ChromeDriver(co);

3.3. 独立窗口代理器

默认gui界面是同ie的设置一样,多个窗口一个proxy。。不过命令行可以。-proxy-server 参数

co.addArguments(“-proxy-server=host:port”);

3.4. 无图模式

命令行参数 --disable-images不过好像不去作用。。只能gui界面禁止。。这样所有的chrome窗口就生效了。

3.5. code

private static WebDriver getChromeDriver(FirefoxProfile profile) {

// 在java程序中添加

System.setProperty("webdriver.chrome.driver", pathx.classPathParent()+ "\\chromedriver.exe");

ChromeOptions co = new ChromeOptions();

String max = "--start-maximized";

String proxyParem = "";

try {

if (browserParams.get().get("network.proxy.http") != null) {

String proxy = browserParams.get().get("network.proxy.http")

+ ":"

+ browserParams.get().get("network.proxy.http_port");

proxyParem = "-proxy-server=" + proxy;

}

} catch (Exception e) {

e.printStackTrace();

}

String noimg = "";

if (browserParams.get().get("permissions.default.image") != null

&& browserParams.get().get("permissions.default.image")

.equals("2"))

noimg = "--disable-images";

//--disable-image-transport-surface

// haox bsin .only gui setting/privert//img

co.addArguments(proxyParem);

String path = pathx.classPathParent()

+ "\\Chrome\\Application\\chrome.exe";

if (new File(path).exists()) {

System.out.println(path);

co.setBinary(path);

}

return new ChromeDriver(co);

}

时间: 2024-10-25 12:50:27

atitit.浏览器web gui操作类库 和 操作chrome浏览器的类库使用总结的相关文章

Chrome浏览器扩展开发系列之九:Chrome浏览器的chrome.alarms.* API

Chrome浏览器扩展程序通过chrome.alarms.* API,可以制定计划周期性地执行代码,或在指定时间执行代码. 要使用chrome.alarms.* API,首先需要在manifest.json文件中声明alarms授权如下: { "permissions": [ "alarms" ], } chrome.alarms.Alarm对象的属性如下: 属性名 类型 必选/可选 注释 name string 必选 alarm的名字 scheduledTime

用golang chromedp 操作已经打开的chrome浏览器

win7 环境,主要是一开始想在代码中先用exec.Command启动chrome,但始终不能成功监听9222端口,折腾了很长时间, 需要先手工启动chrome监听端口,具体写在代码注释中了. 然后再运行代码,代码只是在开源代码基础上稍作修改,将访问不了的google换成sohu.代码效果就是通过代码将浏览器导航到了sohu.com // Command standalone is a chromedp example demonstrating how to use chromedp // w

Appium对手机chrome浏览器操作

appium操作chrome浏览器 1.安卓手机下载手机版chrome浏览器2.Andriod setting中选择"chrome"3.通过css定位得到百度输入框为:#index-kw4.编写代码import io.appium.java_client.AppiumDriver;import io.appium.java_client.TouchAction; import org.junit.*;import org.junit.Before;import org.junit.Te

渗透技巧——导出Chrome浏览器中保存的密码

0x00 前言 在后渗透阶段,获得权限后需要搜集目标系统的信息.信息越全面,越有助于进一步的渗透.对于Windows系统,用户浏览器往往包含有价值的信息. 在之前的文章<本地密码查看工具LaZagne中的自定义脚本开发>曾介绍过利用LaZagne导出多个浏览器密码的方法. 本文将要针对Chrome浏览器,介绍具体的导出原理和利用方法,解决一个实际问题: 如何导出另一系统下Chrome浏览器中保存的密码? 0x01 简介 本文将要介绍以下内容: ·Chrome浏览器保存密码的方式 ·如何导出Ch

chrome浏览器tab页内存占用变大,网站变慢为哪般?

问题概述: 公司做的是BS应用. 之前我们的后台服务器程序是带状态的,用ehcache存储登录状态:这两天被我改成了redis存储,应用本身不再存储登录状态. 然后自测,我在测试某个很耗时间的网页操作的时候,发现第一次请求的时候还比较快(这个请求会开200个iframe出来,每个iframe内部还有2个ajax请求)(期间浏览器会向服务器发送了大概600个请求),耗时1分钟内: 然后第二次请求的时候,发现很多请求一直处于pending状态(chrome的开发者工具可以看),等待很久也出不来页面,

编写一个 Chrome 浏览器扩展程序

浏览器扩展允许我们编写程序来实现对浏览器元素(书签.导航等)以及对网页元素的交互, 甚至从 web 服务器获取数据,以 Chrome 浏览器扩展为例,扩展文件包括: 一个manifest文件(主文件,json格式) 至少一个HTML文件(主题可以没有HTML文件) JavaScript文件 (可选,非必须) 任何其他你需要的文件(比如图片) 将这些文件放在一个文件夹内,并通过浏览器提供的打包程序进行打包,就可以发布使用了. 这里以一个简单的例子,说明 Chrome 扩展的创建和运行过程. 首先创

Visual Studio 2017 本地调试 Chrome浏览器自动退出

在使用VS 2017(15..6 .15.7)对.NET Core MVC应用程序进行本地调试的时候,选择使用Chrome浏览器.但输入中文 就自动关闭Chrome浏览器,随后结束调试.但复制.粘贴中文则不会自动退出.其它浏览器如 搜狗.Microsfot Edge.IE.FireFox,输入中文则不会自动退出. 解决办法:在VS中,工具>选项>项目和解决方案> Web项目",取消选中"浏览器窗口关闭时停止调试器". 原文地址:https://www.cnb

关于如何解决谷歌Chrome浏览器空白页的问题

谷歌Chrome浏览器突然不打开任何网页,无论是任何站点(如http://www.baidu.com), 还是Chrome浏览器的设置页面(chrome://settings/), 扩展页面 ( chrome://extensions/ ) ,  所有其他浏览器(如IE浏览器,Mozilla Firefox浏览器等)很好地工作. 这可能是由于恶意软件/病毒破坏谷歌Chrome浏览器的设置,并危及其首选项文件. 具体而言,以下问题 - 症状当您试图打开谷歌Chrome浏览器出现: 如何解决和修复C

第二章:WebDriver 打开Firefox浏览器 和 Chrome 浏览器

1. 使用Firefox 和 Chrome 来打开浏览器代码如下: 2. 使用 Firefox 浏览器打开百度网页: 3. 使用 Chrome 浏览器中打开 百度页面