本文實例講述了Java 模擬cookie登陸簡單操作。分享給大家供大家參考,具體如下:
最近在做將禪道上的功能接口做到手機端,在做登陸的時候,看了禪道的源碼,是由cookie來登陸,所以要做一個模擬cookie登陸的接口,將拿到的cookie放到每次接口請求的頭部中去,就可以正常訪問了。
import java.io.OutputStreamWriter;
import java.net.HttpURLConnection;
import java.net.URL;
/**
* @Author: jljiang
* @Description:Java 模擬cookie登陸
* @Date: Created in 2019/1/16 15:14
*/
public class ImitateLoginController {
public static void main(String args[]) throws Exception {
//登陸接口地址
String loginStr = "http://zenta.51fb.com/index.php?m=user&f=login";
/**
* 首先要和URL下的URLConnection對話。 URLConnection可以很容易的從URL得到。比如: // Using
* java.net.URL and //java.net.URLConnection
*/
URL url = new URL(loginStr);
HttpURLConnection connection = (HttpURLConnection) url.openConnection();
connection.setDoOutput(true);
OutputStreamWriter out = new OutputStreamWriter(connection
.getOutputStream(), "GBK");
//其中的account和password可以通過控制臺去查看,或者看頁面html去查看
out.write("account=you-user-name&password=you-password");
// remember to clean up
out.flush();
out.close();
// 取得cookie,使用該cookie放在頭部就可以訪問其他需要登陸才可以訪問的接口了
String cookieVal = connection.getHeaderField("Set-Cookie");
/*------------------------------------訪問其他接口-------------------------------------------------*/
String otherUrl = "http://zenta.51fb.com/index.php?m=bug&f=browse";
url = new URL(otherUrl);
HttpURLConnection otherConnection = (HttpURLConnection) url.openConnection();
if(cookieVal != null){
otherConnection.setRequestProperty("Cookie",cookieVal);
}
otherConnection.connect();
InputStream urlStream = otherConnection.getInputStream();
BufferedReader bufferedReader = new BufferedReader(
new InputStreamReader(urlStream));
String content = null;
StringBuilder total = new StringBuilder();
while ((content = bufferedReader.readLine()) != null) {
total.append(content);
}
bufferedReader.close();
System.out.println(content);
}
}
更多關于java算法相關內容感興趣的讀者可查看本站專題:《Java數據結構與算法教程》、《Java操作DOM節點技巧總結》、《Java文件與目錄操作技巧匯總》和《Java緩存操作技巧匯總》
希望本文所述對大家java程序設計有所幫助。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。