首先了解一下Java Cookie类的一些方法。
在jsp中处理cookie数据的常用方法:
getDomain();返回cookie的域名.
getMaxAge();返回cookie的存活时间
getName();返回cookie的名字
getPath();返回cookie适用的路径
getSecure();如果浏览器通过安全协议发送Cookie将返回true值,如果浏览器使用标准协议刚返回false值
getValue();返回cookie的值
getVersion();返回cookie所遵从的协议版本setComment(String purpose);设置cookie的注释
setPath(String url);设置Cookie的适用路径
setSecure(Boolean flag);设置浏览器是否仅仅使用安全协议来发送cookie,例如使用Https或ssl
setValue(String newvalue);cookie创建后设置一个新的值
setVersion(int v);设置cookie所遵从的协议版本
selenium WebDriver 通过driver.manage().getCookies() 和driver.manage().addCookie(ck); 获取cookie 加载cookie
首先,获取cookie 保存的browser.data内
import java.io.BufferedWriter; import java.io.File; import java.io.FileWriter; import java.util.concurrent.TimeUnit; import org.openqa.selenium.By; import org.openqa.selenium.WebDriver; import org.openqa.selenium.WebElement; import org.openqa.selenium.Cookie; public class Cookies { public static void main(String[] args) { WebDriver driver=DriverFactory.create(); driver.get("http://selenium.jd-app.com/wp-login.php"); driver.manage().timeouts().implicitlyWait(10, TimeUnit.SECONDS); WebElement user = driver.findElement(By.xpath("//*[@id='user_login']")); user.clear(); user.sendKeys("username"); WebElement password = driver.findElement(By .xpath("//*[@id='user_pass']")); password.clear(); password.sendKeys("password"); WebElement submit=driver.findElement(By.xpath("//*[@id='wp-submit']")); submit.submit(); try { Thread.sleep(3000); } catch (InterruptedException e) { // TODO Auto-generated catch block e.printStackTrace(); } File file=new File("broswer.data"); try { //delete file if exists file.delete(); file.createNewFile(); FileWriter fw=new FileWriter(file); BufferedWriter bw=new BufferedWriter(fw); for(Cookie ck:driver.manage().getCookies()) { bw.write(ck.getName()+";"+ck.getValue()+";"+ck.getDomain()+";"+ck.getPath()+";"+ck.getExpiry()+";"+ck.isSecure()); bw.newLine(); } bw.flush(); bw.close(); fw.close(); } catch(Exception e) { e.printStackTrace(); } finally { System.out.println("cookie write to file"); } } } |