• Jmeter-响应结果unicode转成中文显示


    本文为转载微信公众号文章,如作者发现后不愿意,请联系我进行删除 

    原文链接:http://mp.weixin.qq.com/s?__biz=MjM5OTI2MTQ3OA==&mid=2652178311&idx=1&sn=9ac05bc08e688018b9df1681d17fdc43&chksm=bcdf83ce8ba80ad8177307c44f74d4acc5d5e247af69894986b2d3c72e1847cebee6117c4d4e&scene=0#rd

    在jmeter工具的使用中,不管是测试接口还是调试性能时,查看结果树必不可少,然而在查看响应数据时,其中的中文经常以Unicode的编码形式显示,如图1。这样不能直接查看到对应的中文是否为期望的结果,很不方便。

             我找到一个曲线救国的方法,供大家参考。得到结果,如图2。

    操作步骤

    第一步

    在对应请求上添加后置处理器BeanShellPostProcessor,如图3.


    得到页面,图4。

                                                

    图4

    第二步

    在后置处理器BeanShellPostProcessor的script中贴入Unicode的转中文的编码,如图5。

    代码如下:

    //获取响应代码Unicode编码的

    String s2=newString(prev.getResponseData(),"UTF-8");

    //---------------一下步骤为转码过程---------------

    charaChar;

    intlen= s2.length();

    StringBufferoutBuffer=newStringBuffer(len);

    for(int x =0; x <len;){

    aChar= s2.charAt(x++);

    if(aChar=='\'){

    aChar= s2.charAt(x++);

    if(aChar=='u'){

    int value =0;

    for(inti=0;i<4;i++){

    aChar= s2.charAt(x++);

    switch(aChar){

    case'0':

    case'1':

    case'2':

    case'3':

    case'4':

    case'5':

    case'6':

    case'7':

    case'8':

    case'9':

    value=(value <<4)+aChar-'0';

    break;

    case'a':

    case'b':

    case'c':

    case'd':

    case'e':

    case'f':

    value=(value <<4)+10+aChar-'a';

    break;

    case'A':

    case'B':

    case'C':

    case'D':

    case'E':

    case'F':

    value=(value <<4)+10+aChar-'A';

    break;

    default:

    thrownewIllegalArgumentException(

    "Malformed   \uxxxx  encoding.");}}

    outBuffer.append((char) value);}else{

    if(aChar=='t')

    aChar=' ';

    elseif(aChar=='r')

    aChar=' ';

    elseif(aChar=='n')

    aChar=' ';

    elseif(aChar=='f')

    aChar='f';

    outBuffer.append(aChar);}}else

    outBuffer.append(aChar);}

    //-----------------以上内容为转码过程---------------------------

    //将转成中文的响应结果在查看结果树中显示

    prev.setResponseData(outBuffer.toString());

    第三步

    正常调试并查看结果树,发现之前的Unicode的编码的中文,已经转码完毕。

    <End>

    原理

             通过BeanShell内置变量prev,获得响应数据,经过java程序编码,把Unicode代码转成中文,最后修改查看结果树中响应数据为转换完毕的中文数据。

    备注

    1、  在性能测试前,请把这个后置处理器删除,不然会大量消耗本机的内存和CPU,影响性能的结果

    2、  以上代码中的转码过程可以更改为更适合的代码,但要注意的是Jmeter3.0这个版本依旧对Integer.parseint()方法不能很好支持,运行会报错。

    3、  关于获取响应结果的变量值prev,具体API查看:

    http://jmeter.apache.org/api/org/apache/jmeter/samplers/SampleResult.html

     
     
  • 相关阅读:
    python操作mysql数据库
    Turtle绘制带颜色和字体的图形(Python3)
    Windows单机最大TCP连接数的问题
    This network connection does not exist
    python3 条件判断,循环,三元表达式
    基于SolidWorks设计算例的柴油机飞轮平衡孔的研究
    VOC2007数据集转换成CSV格式[
    xml -> csv
    目标检测 – 解析VOC和COCO格式并制作自己的数据集
    什么是电磁阀,电磁阀常见故障与解决方法
  • 原文地址:https://www.cnblogs.com/w770762632/p/13644455.html
Copyright © 2020-2023  润新知