在使用java存取URL時,如果該URL需要身份驗證,那麼就無法直接訪問,因為沒有登陸。那麼,如何解決這個問題呢?
方法是使用java模擬登陸,登陸後記錄下cookie訊息,在下次發起請求時時將cookie發送過去用以表明身份,這樣就能夠存取帶有權限的URL了。
下面先介紹使用java模擬登陸。
// 连接地址(通过阅读html源代码获得,即为登陆表单提交的URL) String surl = "http://login.goodjobs.cn/index.php/action/UserLogin"; /** * 首先要和URL下的URLConnection对话。 URLConnection可以很容易的从URL得到。比如: // Using * java.net.URL and //java.net.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.php/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以表明身份。
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持PHP中文網。
更多java模擬cookie登陸操作相關文章請追蹤PHP中文網!