本文转载张飞的博客http://www.cnblogs.com/zhangfei/p/4359408.html在此感谢博主的分享!

最早用Jsoup是有一个小的爬虫应用要写,发现Jsoup较HttpClient轻便多了,API也方便易懂,上手很快,对于response的Document解析的选择器用的是cssSelector(Jquery)选择器,觉得还不错,后来因为其它原因,没有深入的研究,最近看到一位大神用这个,我也就再学习了一下,顺便把这个用Jsoup做接口测试的相关知识点发出来给大家参考下!

一. 接口测试的相关知识点准备:

  1.firefox, firebug安装

  2.如何查看请求方式及链接,如下图

  

  我们可以看出,请求的方式是GET, 链接是www.baidu.com

二. Jsoup示例

  1.所使用到的jar包:jsoup-*.jar

  2.示例:(不要使用百度首页来做试验!!!使用百度首页做试验出不来结果的人,不要来问我为什么!!!)  

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
import java.io.IOException;
import org.jsoup.Jsoup;
import org.jsoup.nodes.Document;
 
public class Test {     
    public void testJsop(){
        try {
            Document doc = Jsoup.connect("http://www.cnblogs.com/zhangfei/p/4283930.html").get();
            System.out.println(doc);
        catch (IOException e) {          
            e.printStackTrace();
        }
    }     
    public static void main(String[] args) {
        Test t = new Test();
        t.testJsop();
    }    
}

  输出结果就是当前页面的Document对象,然后再解析这个页面对象就可以了。

三. 参数的处理

  1.Get请求中的参数

  

  对于这种参数,一般有两种写法:

  第一种:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
public class Test {     
    public void testJsop(){
        try {
            Document doc = Jsoup.connect("http://www.cnblogs.com/zhangfei/p/?page=3").get();
            System.out.println(doc);
        catch (IOException e) {          
            e.printStackTrace();
        }
    }     
    public static void main(String[] args) {
        Test t = new Test();
        t.testJsop();
    }     
}

  第二种:  

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
public class Test {     
    public void testJsop(){
        try {
            Connection conn = Jsoup.connect("http://www.cnblogs.com/zhangfei/p/");
            conn.data("page","3");
            Document doc = conn.get();         
            System.out.println(doc);
        catch (IOException e) {          
            e.printStackTrace();
        }
    }     
    public static void main(String[] args) {
        Test t = new Test();
        t.testJsop();
    }     
}

  2.post请求中的参数

   post请求的参数,一般以表单提交居多,我们来看看如何确定参数:

  

  上图中,左边红框框是key, 右边红框框是value,一般情况下,在测试系统中,输入用户名与密码就行了,比如:  

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
public class Test {     
    public void testJsop(){
        try {
            Connection conn = Jsoup.connect("https://passport.jd.com/new/login.aspx");
            conn.data("loginname","test1");
            conn.data("loginpwd","test1");

conn.header("Accept", "application/json");
                       conn.header("Content-Type", "application/json");

            Document doc = conn.post();        
            System.out.println(doc);
        catch (IOException e) {          
            e.printStackTrace();
        }
    }     
    public static void main(String[] args) {
        Test t = new Test();
        t.testJsop();
    }     
}

在这里就是data就是url末尾?key=value           data=parameter=body

四.响应超时请求处理  

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
public class Test {     
    public void testJsop(){
        try {
            Connection conn = Jsoup.connect("https://passport.jd.com/new/login.aspx");
            conn.data("loginname","test1");
            conn.data("loginpwd","test1");
            conn.timeout(30000);
            Document doc = conn.post();        
            System.out.println(doc);
        catch (IOException e) {          
            e.printStackTrace();
        }
    }     
    public static void main(String[] args) {
        Test t = new Test();
        t.testJsop();
    }     
}

五.cookies的管理

  在我们登录后,保存此次登录的cookies,这样,后续的操作才可以继续进行,Jsoup提供了很简便的方式来保存cookies  

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
public class Test {     
    public void testJsop(){
        try {
            Connection conn = Jsoup.connect("https://passport.jd.com/new/login.aspx");
            conn.data("loginname","test1");
            conn.data("loginpwd","test1");
            conn.timeout(30000);           
            conn.method(Method.POST);
            Response response = conn.execute();
            Map<String, String> cookies = response.cookies();
            Document doc = Jsoup.connect("http://order.jd.com/center/list.action")
                .cookies(cookies)
                .timeout(30000)
                .get();
        catch (IOException e) {          
            e.printStackTrace();
        }
    }     
    public static void main(String[] args) {
        Test t = new Test();
        t.testJsop();
    }     
}

上面的示例中,可以看出,要取得cookies,必须要有个Response的对象,所以,要用execute方法,如果直接用post方面,返回的则是Document对象,但在用execute方法时,要事先调用一下method方法设定好请求方式即可。

jsoup做http接口测试的更多相关文章

  1. Jsoup做接口测试

    最早用Jsoup是有一个小的爬虫应用要写,发现Jsoup较HttpClient轻便多了,API也方便易懂,上手很快,对于response的Document解析的选择器用的是cssSelector(Jq ...

  2. 《用Python做HTTP接口测试》学习感悟

    机缘巧合之下,报名参加了阿奎老师发布在"好班长"的课程<用Python做HTTP接口测试>,报名费:15rmb,不到一杯咖啡钱,目前为止的状态:坚定不移的跟下去,自学+ ...

  3. 使用 Jmeter 做 Web 接口测试

    接口测试概述 定义 API testing is a type of software testing that involves testing application programming in ...

  4. 【转】使用 Jmeter 做 Web 接口测试

    最近总结了一下在接口测试方面的知识与心得,在这里与大家分享一下,如有说的不对的地方请多多指正. 接口测试概述 定义 API testing is a type of software testing ...

  5. 使用jmeter做web接口测试

    接口测试概述 定义 API testing is a type of software testing that involves testing application programming in ...

  6. 使用 Jmeter 做 Web 接口测试-详解

    接口测试概述 定义 WIKI定义:接口测试作为集成测 试的一部分,通过直接控制API来判断系统的功能性,可靠性,性能与安全性.API测试是没有界面的,执行在通讯 层.API 测试在自动化测试中有着重要 ...

  7. web_custom_request函数做get接口测试

    最近研究了使用loadrunner做接口测试,刚开始一直不成功,后来加了QQ群,遇到大神了,经指导终于成功 下面是具体实例代码: //{"signIOS":1,"sign ...

  8. 怎么做web接口测试

        这就需要开发提供的接口文档了,接口文档和功能测试的需求说明书的功能是一样的.包括:接口说明.调用的url,请求方式(get or post),请求参数.参数类型.请求参数说明,返回结果说明.有 ...

  9. Jmeter做HTTP接口测试

    接口测试概述:https://www.cnblogs.com/mawenqiangios/p/7886115.html Jmeter接口测试教程:https://www.cnblogs.com/hou ...

随机推荐

  1. C++ 对象间的赋值与拷贝构造函数

    1.对象间的赋值 /***A.h文件***/ #pragma once class A { public: int va; A(void); A(char* name); A(const A& ...

  2. 判断app是否是第一次启动

    如何判断app是否是第一启动呢,第一次启动的时候,加载引导页面等, 一下是我的解决方案: 1.在"AppDelegate.h"中找到- (BOOL)application:(UIA ...

  3. details和summary标签

    用于文档说明,有自带收缩.展开功能 <!DOCTYPE HTML> <html> <body> <details> <summary>HTM ...

  4. 【RF库Collections测试】Count Values In List

    Name:Count Values In ListSource:Collections <test library>Arguments:[ list_ | value | start=0 ...

  5. 使用 XPath

    XPath 简介: (1) 前面我们爬取一个网页,都是使用正则表达式来提取想要的信息,但是这种方式比较复杂,一旦有一个地方写错,就匹配不出来了,因此我们可以使用 XPath 来进行提取(2) XPat ...

  6. 安装配置博客WordPress

    1.下载并解压WordPress cd /usr/local/src wget https://cn.wordpress.org/wordpress-4.4.2-zh_CN.tar.gztar zcv ...

  7. date类型数据插入

    --字段类型是dateinsert into tab(column) values(to_date('2017_06_30 11:38:22','yyyy-mm-dd hh24:mi:ss'));-- ...

  8. 说说M451的例程库的说明

    Directory Information Document   Driver reference manual and reversion history. Library         Driv ...

  9. js禁止img拖动

    其实只需要一句代码即可,那就是阻止元素的默认事件: <body> <img src="./../imgs/cat.jpg" id="test" ...

  10. iOS富文本组件的实现—DTCoreText源码解析 数据篇

    本文转载 http://blog.cnbang.net/tech/2630/ DTCoreText是个开源的iOS富文本组件,它可以解析HTML与CSS最终用CoreText绘制出来,通常用于在一些需 ...