>  기사  >  Java  >  Java는 쿠키 로그인 작업을 시뮬레이션합니다.

Java는 쿠키 로그인 작업을 시뮬레이션합니다.

高洛峰
高洛峰원래의
2017-01-18 14:25:401180검색

Java를 사용하여 URL에 접속할 때 해당 URL에 인증이 필요한 경우 로그인하지 않았기 때문에 직접 접속할 수 없습니다. 그렇다면 이 문제를 해결하는 방법은 무엇입니까?

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에 접근할 수 있습니다. 아이디어는 로그인을 시뮬레이션하고, 신원을 기록하기 위한 쿠키를 얻고, 다음 요청 시 신원을 나타내기 위해 쿠키를 보내는 것입니다.

위 내용은 이 글의 전체 내용입니다. 모든 분들의 학습에 도움이 되기를 바랍니다. 또한 모든 분들이 PHP 중국어 웹사이트를 지지해주시기를 바랍니다.

Java 시뮬레이션 쿠키 로그인 작업과 관련된 더 많은 기사를 보려면 PHP 중국어 웹사이트를 주목하세요!


성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.