51Testing软件测试论坛

 找回密码
 (注-册)加入51Testing

QQ登录

只需一步,快速开始

微信登录,快人一步

查看: 1966|回复: 0
打印 上一主题 下一主题

[原创] Day3-5测试积点任务

[复制链接]
  • TA的每日心情
    无聊
    昨天 09:32
  • 签到天数: 399 天

    连续签到: 5 天

    [LV.9]测试副司令

    跳转到指定楼层
    1#
    发表于 2018-7-17 09:55:13 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
    1测试积点
    java 项目中没去 log.info (cookie),运行时却把 cookie 给 log 出来了。。。求路过大神给出解决方案?
    直接上代码:如下是个依赖登录cookie的接口
    1. @Test
    2.    public void test1()throws Exception{
    3.        String api = "/actapi_v2/mapi/member.memberBuy";
    4.        Map<String,String> request1 = new HashMap<>();
    5.        request1.put("account","18656560102");
    6.        request1.put("password","w123456");
    7.        Map<String,String> request = new HashMap<>();
    8.        request.put("Cookie", UserInfo.Getcookie(request1));
    9.        //上一步会打印出cookie
    10.        String response = HttpUtils.getInstance().sendHttpRequest("POST",host+api,request);
    11.        System.out.println("------------------------"+response);
    12.    }
    复制代码
    运行后的结果



    得到cookie的方法
    1. public static String Getcookie(Map<String,String> map) throws Exception {
    2.       String api = "/actapi_v2/mapi/user.signIn";

    3.       return HttpUtils.getInstance().getSessionCookie(host+api,map);

    4.   }
    复制代码
    getSessionCookie方法里

    1. public String getSessionCookie(String url,Map<String,String>maps)throws Exception{
    2.        HttpPost httpPost = new HttpPost(url);
    3.        List<NameValuePair> nameValuePairs = new ArrayList<NameValuePair>();
    4.        for (String key : maps.keySet()) {
    5.            nameValuePairs.add(new BasicNameValuePair(key, maps.get(key)));
    6.        }
    7.        httpPost.setEntity(new UrlEncodedFormEntity(nameValuePairs, "UTF-8"));
    8.        CloseableHttpResponse closeableHttpResponse = httpResponse(httpPost);
    9.        Header[] headers = closeableHttpResponse.getAllHeaders();
    10.        StringBuilder stringBuilder = new StringBuilder();
    11.        for (Header header:headers){
    12.            HeaderElement[] elements = header.getElements();
    13.            for (HeaderElement element:elements){
    14.                if (element.getValue() != null && !element.getValue().isEmpty()){
    15.                    stringBuilder.append(element.getName()).append("=").append(element.getValue()).append(";");
    16.                }

    17.            }
    18.        }
    19.        return new String(stringBuilder);
    20.    }
    复制代码
    不知道运行后为什么会打印出两次cookie?按理应该一次都出现不了的。感觉是我的log4j框架问题?

    附件: 您需要 登录 才可以下载或查看,没有帐号?(注-册)加入51Testing
    分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
    收藏收藏
    回复

    使用道具 举报

    本版积分规则

    关闭

    站长推荐上一条 /1 下一条

    小黑屋|手机版|Archiver|51Testing软件测试网 ( 沪ICP备05003035号 关于我们

    GMT+8, 2024-4-20 15:42 , Processed in 0.064679 second(s), 22 queries .

    Powered by Discuz! X3.2

    © 2001-2024 Comsenz Inc.

    快速回复 返回顶部 返回列表