美文网首页
JAVA代码模拟获取cookie以及携带cookie

JAVA代码模拟获取cookie以及携带cookie

作者: senninha | 来源:发表于2017-03-17 23:42 被阅读2546次

    JAVA代码模拟获取cookie以及携带cookie

    去年做android的时候,网络连接没有用类似OKHttp之类的框架,而是完全用jdk自带的api实现,今天不想看书。。就把笔记整理一下吧。。

    这里有个小demo,是先实现登陆,登陆的过程是通过post方式请求,登陆后通过携带的cookie判断是否已经成功登陆。

    1.获取cookie

    public void connect(String u) throws IOException{
            HttpURLConnection conn = null;
            OutputStream os = null;
            InputStream is = null;
            try {
                URL url = new URL(u);
                conn = (HttpURLConnection) url.openConnection();
                conn.setRequestMethod("POST");
                conn.setDoInput(true);
                conn.setDoOutput(true);
                os = conn.getOutputStream();
                String param = "account=senninha&password=senninha";
                String eparam = param;
                //这里是把post参数携带上去。
                os.write(eparam.getBytes("utf-8"));
                is = conn.getInputStream();
                byte[] b = new byte[1024];
                int len = is.read(b);
                while(len != -1){
                    System.out.println(new String(b,0,len,"utf-8"));
                    len = is.read(b);
                }
                //这里是读取第一次登陆时服务器返回的cookie,然后用一个全局变量cookie接收。因为是服务器往客户端发送cookie,所以名字是Set-Cookie
                cookie = conn.getHeaderField("Set-Cookie");
                System.out.println("read over" + cookie);
            } catch (Exception e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
            }   finally{
                if(os != null){
                    os.close();
                }
                
                if(is != null){
                    is.close();
                }
                if(conn != null){
                    conn.disconnect();
                }
                
                System.out.println("all close");
            }
        }
    

    2.携带cookie

    public void isLogin(String u) throws IOException{
            HttpURLConnection conn = null;
            InputStream is = null;
            try {
                URL url = new URL(u);
                conn = (HttpURLConnection) url.openConnection();
                conn.setRequestMethod("POST");
                //把上一步获取的cookie携带上去
                conn.setRequestProperty("cookie", cookie);
                conn.setDoInput(true);
                is = conn.getInputStream();
                byte[] b = new byte[1024];
                int len = is.read(b);
                while(len != -1){
                    System.out.println(new String(b,0,len,"utf-8"));
                    len = is.read(b);
                }
                System.out.println("read over");
            } catch (Exception e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
            }   finally{
                if(is != null){
                    is.close();
                }
                if(conn != null){
                    conn.disconnect();
                }
                
            }
                System.out.println("all close");
            }
    

    ok,以后每次访问,只要携带上这个cookie,就可以畅通无阻了。当然,是指用cookie维持登陆的网站。

    ps:java后端的维持登陆状态的cookie叫JSESSIONID,php的叫phpSessionId好像。。
    ps:对于安卓客户端来说,获取到的cookie可以存到数据库里,这样重启app后一样可以再次保持登陆状态。

    相关文章

      网友评论

          本文标题:JAVA代码模拟获取cookie以及携带cookie

          本文链接:https://www.haomeiwen.com/subject/rinynttx.html