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

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后一样可以再次保持登陆状态。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 从三月份找实习到现在,面了一些公司,挂了不少,但最终还是拿到小米、百度、阿里、京东、新浪、CVTE、乐视家的研发岗...
    时芥蓝阅读 42,372评论 11 349
  • 1. cookie 1.1 什么是cookie cookie 是存储于访问者的计算机中的变量。每当同一台计算机通过...
    cbw100阅读 4,093评论 0 13
  • (2008年阳春三月,曾经偷偷去考了公务员。五百人的大军中,在下名列百位,离目标远矣。然已努力一搏,此生无憾。) ...
    明哥明说阅读 619评论 0 1
  • 今天第一次使用简书,许多功能还不会用。 初中的时候写过一段时间的日记,后来就再没有了,即使偶尔写一点东西...
    午后红茶_双子座阅读 95评论 0 1
  • 见惯了你 却从来没有为你动心 只是一次偶然 你邀我去漫步 在乡间小路上 突然你从背后搂住我的脖子 十六岁的小姑娘 ...
    田萍阅读 218评论 2 6