51Testing软件测试论坛

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

QQ登录

只需一步,快速开始

微信登录,快人一步

手机号码,快捷登录

查看: 1179|回复: 1
打印 上一主题 下一主题

[转贴] Jmeter接口测试踩过的坑

[复制链接]
  • TA的每日心情
    擦汗
    13 小时前
  • 签到天数: 1048 天

    连续签到: 1 天

    [LV.10]测试总司令

    跳转到指定楼层
    1#
    发表于 2022-1-6 11:42:28 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
    接口测试看着很简单,但是操作过程中还是出现很多问题,现总结如下:
    一、jmeter中乱码问题
    可在jmeter.properties 这个文件里面找到sampleresult.default.encoding=xx,后面xx改成utf-8,然后取消注释。
    解决jmeter的body里面中文显示不出来,可找到 JSyntaxTextArea然后把以js开头的注释取消即可。
    JDBC请求查询结果乱码,可在JDBC连接配置中将URL加上characterEncoding=UTF-8即可。
    二、报错检查
    请求中的url、路径、请求方式、参数等一定写准确,多个空格都不行。
    三、JDBC Request 之Query Type
    1、Select statement
    这是一个查询语句类型;如果JDBC Request中的Query内容为一条查询语句,则选择这种类型。
    PS:多个查询语句(不使用参数的情况下)可以放在一起顺序执行,需要设置Query Type为:Callable Statement;
    如果Query Type为:select Statement,则只执行第一条select语句。
    2、Update statement
    这是一个更新语句类型(包含insert和update);如果JDBC Request中的Query内容为一条更新语句,则选择这种类型。
    PS:如果该类型下写入多条update语句,依然只执行第一条
    3、Callable statement
    这是一个可调用语句类型,CallableStatement 为所有的 DBMS 提供了一种以标准形式调用已储存过程的方法。
    4、编辑(${})
    jmeter中的JDBC请求中的SQL语句是无法使用参数的,比如: SELECT * FROM ${table_name} 是无效的。
    如果需实现同时多个不同用户使用不同的SQL,可以通过把整条SQL语句参数化来实现;(把SQL语句放在csv文件中,然后在JDBC Request的Query 中使用参数代替 ${SQL_Statement})。
    对比:
    1. Select Statement:  仅支持测试select语句,并且一次只能测试一条
    2. Update Statement: 支持测试非select语句,并且支持测试多条
    3.           若其中夹杂select语句,自动忽略
    4.           若第一条语句为select语句,报错
    5. Callable Statement:只要语法正确,任何语句,再多的条数都能支持
    复制代码
    四、下载文件
    以下载百度上的图片为例,图片的url是:http://a.hiphotos.baidu.com/image/pic/item/4b90f603738da977b1e8c6c7ba51f8198718e313.jpg
    PS:  HTTP请求一定要放在BeanShell Sampler的前面,不然Jmeter会按顺序执行,BeanShell Sampler中会取不到请求的返回值,就会报错
    1、在线程组中添加beanshell,获取到返回的文件内容,保存到一个文件里面。右键线程组,添加-Sampler-BeanShell Sampler,beanshell代码如下:

    1. import java.io.*;
    2. byte[] result = prev.getResponseData();  //这个是获取到请求返回的数据,prev是获取上个请求的返回
    3. String file_name = "C:\\Users\\zhangrui6\\Desktop\\a.jpg";  //代表存放文件的位置和文件名
    4. File file = new File(file_name);
    5. FileOutputStream ut = new FileOutputStream(file);
    6. out.write(result);
    7. out.close();
    复制代码

    2、添加HTTP请求


    3、察看结果树


    4、查看保存到本地的文件



    本帖子中包含更多资源

    您需要 登录 才可以下载或查看,没有帐号?(注-册)加入51Testing

    x
    分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
    收藏收藏
    回复

    使用道具 举报

    本版积分规则

    关闭

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

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

    GMT+8, 2024-11-18 22:59 , Processed in 0.066671 second(s), 23 queries .

    Powered by Discuz! X3.2

    © 2001-2024 Comsenz Inc.

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