ホームページ  >  記事  >  Java  >  Java は Cookie ログイン操作をシミュレートします

Java は Cookie ログイン操作をシミュレートします

高洛峰
高洛峰オリジナル
2017-01-18 14:25:401174ブラウズ

Java を使用して URL にアクセスする場合、URL に認証が必要な場合は、ログインしていないため、直接アクセスすることはできません。では、この問題をどうやって解決すればよいでしょうか?

その方法は、ログイン後に Cookie 情報を記録し、次のリクエスト時に ID を示すために Java を使用して、権限のある 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 を取得して ID を記録し、次のリクエストで ID を示すために Cookie を送信することです。

以上がこの記事の全内容です。皆さんの学習に役立つことを願っています。また、皆さんも PHP 中国語 Web サイトをサポートしていただければ幸いです。

Java のシミュレートされた Cookie ログイン操作に関連するその他の記事については、PHP 中国語 Web サイトに注目してください。


声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。