Maison >Java >javaDidacticiel >Java simule l'opération de connexion aux cookies

Java simule l'opération de connexion aux cookies

高洛峰
高洛峰original
2017-01-18 14:25:401221parcourir

Lorsque vous utilisez Java pour accéder à une URL, si l'URL nécessite une authentification, vous ne pouvez pas y accéder directement car vous n'êtes pas connecté. Alors, comment résoudre ce problème ?

La méthode consiste à utiliser Java pour simuler la connexion, à enregistrer les informations du cookie après la connexion et à envoyer le cookie pour indiquer l'identité lors de la prochaine demande, afin que vous puissiez accéder à l'URL avec des autorisations.

Ce qui suit présente d'abord l'utilisation de Java pour simuler la connexion.

// 连接地址(通过阅读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");

Après une connexion réussie, vous pouvez accéder à d'autres 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();

En utilisant la méthode ci-dessus, vous pouvez accéder aux URL avec contrôle d'autorisation. L'idée est la suivante : simuler la connexion, obtenir un cookie pour enregistrer l'identité et envoyer le cookie pour indiquer l'identité lors de la prochaine requête.

Ce qui précède représente l'intégralité du contenu de cet article. J'espère qu'il sera utile à l'apprentissage de chacun. J'espère également que tout le monde soutiendra le site Web PHP chinois.

Pour plus d'articles liés aux opérations de connexion aux cookies simulés Java, veuillez faire attention au site Web PHP chinois !


Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn