java模拟cookie登陆操作

在使用Java访问URL时,如果该URL需要身份验证,那么就不能够直接访问,因为没有登陆。那么,如何解决这个问题呢?

  方法是使用java模拟登陆,登陆后记录下cookie信息,在下次发起请求时时将cookie发送过去用以表明身份,这样就能够访问带有权限的URL了。

  下面首先介绍使用java模拟登陆。
 // 连接地址(通过阅读html源代码获得,即为登陆表单提交的URL)  
String surl = "http://login.goodjobs.cn/index.<a href="http://lib.csdn.net/base/php" class='replace_word' title="PHP知识库" target='_blank' style='color:#df3434; font-weight:bold;'>PHP</a>/action/UserLogin";  

/** 
 * 首先要和URL下的URLConnection对话。 URLConnection可以很容易的从URL得到。比如: // Using 
 * java<a href="http://lib.csdn.net/base/dotnet" class='replace_word' title=".NET知识库" target='_blank' style='color:#df3434; font-weight:bold;'>.NET</a>.URL and //java<a href="http://lib.csdn.net/base/dotnet" class='replace_word' title=".NET知识库" target='_blank' style='color:#df3434; font-weight:bold;'>.net</a>.URLConnection 
 */  
URL url = new URL(surl);  
HttpURLConnection connection = (HttpURLConnection) url.openConnection();  

/** 
 * 然后把连接设为输出模式。URLConnection通常作为输入来使用,比如下载一个Web页。 
 * 通过把URLConnection设为输出,你可以把数据向你个Web页传送。下面是如何做: 
 */  
connection.setDoOutput(true);  
/** 
 * 最后,为了得到OutputStream,简单起见,把它约束在Writer并且放入POST信息中,例如: ... 
 */  
OutputStreamWriter out = new OutputStreamWriter(connection  
        .getOutputStream(), "GBK");  
              //其中的memberName和password也是阅读html代码得知的,即为表单中对应的参数名称  
out.write("memberName=myMemberName&password=myPassword"); // post的关键所在!  
// remember to clean up  
out.flush();  
out.close();  

// 取得cookie,相当于记录了身份,供下次访问时使用  
String cookieVal = connection.getHeaderField("Set-Cookie");  

登陆成功后,即可访问其他URL了。

           String s = "http://user.goodjobs.cn/dispatcher.<a href="http://lib.csdn.net/base/php" class='replace_word' title="PHP知识库" target='_blank' style='color:#df3434; font-weight:bold;'>php</a>/module/Resume/action/Preview";  
//重新打开一个连接  
              url = new URL(s);  
HttpURLConnection resumeConnection = (HttpURLConnection) url  
        .openConnection();  
if (cookieVal != null) {  
                      //发送cookie信息上去,以表明自己的身份,否则会被认为没有权限  
    resumeConnection.setRequestProperty("Cookie", cookieVal);  
}  
resumeConnection.connect();  
InputStream urlStream = resumeConnection.getInputStream();  
BufferedReader bufferedReader = new BufferedReader(  
        new InputStreamReader(urlStream));  
String ss = null;  
String total = "";  
while ((ss = bufferedReader.readLine()) != null) {  
    total += ss;  
}  
IOUtils.write(total, new FileOutputStream("d:/index.html"));  
bufferedReader.close();  

通过上述方式,就能访问带有权限控制的URL了。思路即为:模拟登陆,取得cookie以记录身份,下次请求时发送cookie以表明身份。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值