java模拟cookie登陆操作
在使用java访问URL时,如果该URL需要身份验证,那么就不能够直接访问,因为没有登陆。那么,如何解决这个问题呢?
方法是使用java模拟登陆,登陆后记录下cookie信息,在下次发起请求时时将cookie发送过去用以表明身份,这样就能够访问带有权限的URL了。
下面首先介绍使用java模拟登陆。
//连接地址(通过阅读html源代码获得,即为登陆表单提交的URL) Stringsurl="http://login.goodjobs.cn/index.php/action/UserLogin"; /** *首先要和URL下的URLConnection对话。URLConnection可以很容易的从URL得到。比如://Using *java.net.URLand//java.net.URLConnection */ URLurl=newURL(surl); HttpURLConnectionconnection=(HttpURLConnection)url.openConnection(); /** *然后把连接设为输出模式。URLConnection通常作为输入来使用,比如下载一个Web页。 *通过把URLConnection设为输出,你可以把数据向你个Web页传送。下面是如何做: */ connection.setDoOutput(true); /** *最后,为了得到OutputStream,简单起见,把它约束在Writer并且放入POST信息中,例如:... */ OutputStreamWriterout=newOutputStreamWriter(connection .getOutputStream(),"GBK"); //其中的memberName和password也是阅读html代码得知的,即为表单中对应的参数名称 out.write("memberName=myMemberName&password=myPassword");//post的关键所在! //remembertocleanup out.flush(); out.close(); //取得cookie,相当于记录了身份,供下次访问时使用 StringcookieVal=connection.getHeaderField("Set-Cookie");
登陆成功后,即可访问其他URL了。
Strings="http://user.goodjobs.cn/dispatcher.php/module/Resume/action/Preview"; //重新打开一个连接 url=newURL(s); HttpURLConnectionresumeConnection=(HttpURLConnection)url .openConnection(); if(cookieVal!=null){ //发送cookie信息上去,以表明自己的身份,否则会被认为没有权限 resumeConnection.setRequestProperty("Cookie",cookieVal); } resumeConnection.connect(); InputStreamurlStream=resumeConnection.getInputStream(); BufferedReaderbufferedReader=newBufferedReader( newInputStreamReader(urlStream)); Stringss=null; Stringtotal=""; while((ss=bufferedReader.readLine())!=null){ total+=ss; } IOUtils.write(total,newFileOutputStream("d:/index.html")); bufferedReader.close();
通过上述方式,就能访问带有权限控制的URL了。思路即为:模拟登陆,取得cookie以记录身份,下次请求时发送cookie以表明身份。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。