zoukankan      html  css  js  c++  java
  • LoadRunner字符串编码转换函数:lr_convert_string_encoding

    最近在调试脚本的过程中,多次用到LoadRunner字符串编码转换函数lr_convert_string_encoding,这里简单总结一下,方便以后参考~

    1.函数实现
    Loadrunner自带函数,直接使用即可

    lr_convert_string_encoding

    //C Language

    int lr_convert_string_encoding( const char *sourceString, const char *fromEncoding,const char *toEncoding, const char *paramName);
    官方参数解释:
    sourceString

    The string to convert

    fromEncoding

    The encoding of the sourceString

    toEncoding

    The encoding to convert of the string saved in parameter paramName

    paramName

    The name of the parameter in which the destination string will be saved


    对应的中文参数解释:
       sourceString:被转换的源字符串。

       fromEncoding:转换前的字符编码。

       toEncoding:要转换成为的字符编码。

       paramName:转换后的目标字符串。

    lr_convert_string_encoding converts a string encoding betweenthe following encodings: System locale, Unicode, and UTF-8. The function savesthe result string, including its terminating NULL, in the parameter paramName.

    根据上面的说明,这个函数其实只是把字符串在三种编码格式中做转换,所以其实功能也是有限的,不过也已经可以适用到我们常见的一些场景了。
    常量和值的对应关系如下:

    Possible values for 'fromEncoding'and 'toEncoding' :

    Constant

    Value

    LR_ENC_SYSTEM_LOCALE

    NULL

    LR_ENC_UTF8

    "utf-8"

    LR_ENC_UNICODE

    "ucs-2"


    2.Loadrunner中的使用
       在URL请求的返回消息中,我们有时候会遇到中文返回被编码的情况,不易识别,这时候就可以用编码转换函数,方便调试脚本。

    Action()
    {
    int compare=1;
    web_reg_save_param("payRespBody",
    "LB=",
    "RB=",
    "NotFound=ERROR",
    "Search=Body",
    LAST);

    web_reg_save_param("responseMsg",
    "LB=responseMsg":"",
    "RB=",",
    "NotFound=ERROR",
    "Search=All",
    LAST);

    web_custom_request("pay.htm",
    "URL=http://xxx/a/b/pay.htm?x={orderId}&pwd=x",
    "Method=POST",
    "TargetFrame=",
    "Resource=0",
    "RecContentType=application/json",
    "Referer=",
    "Mode=HTML",
    "EncType=application/x-www-form-urlencoded; charset=UTF-8",
    LAST);

    lr_convert_string_encoding(lr_eval_string("{responseMsg}"),"utf-8",NULL,"msg");//将返回消息responseMsg值做编码转换

    lr_output_message("转换编码前payRespBody----%s",lr_eval_string("{payRespBody}"));

    lr_convert_string_encoding(lr_eval_string("{payRespBody}"),"utf-8",NULL,"bodymsg"); <pre name="code" class="cpp"> //将返回消息的body做编码转换

    compare=strcmp(lr_eval_string("{msg}"),"支付成功");//将编码转换后的responseMsg值与可识别的中文做比较,判断事务成功或失败

    if(compare==0){

    lr_end_transaction("3--支付",LR_PASS);

    }
    else{
    lr_end_transaction("3--支付",LR_FAIL);

    lr_output_message("支付失败orderId:----%s,responseMsg----%s",lr_eval_string("{orderId}"),lr_eval_string("{msg}"));//打印转换编码后的返回

    lr_output_message("转换编码后payRespBody----%s",lr_eval_string("{bodymsg}"));//打印转换编码后的返回,便于定位问题
    }

    return 0;
    }
    通过对比转换前和转换后的值可以发现,编码转换后,中文变得可识别,方便了脚本调试和脚本问题定位及解决。
    Action.c(x): 转换编码前payRespBody----{"responseMsg":"鏀�粯澶辫触","success":false}
    Action.c(y): 转换编码后payRespBody----{"responseMsg":"支付失败","success":false}
    ---------------------
    作者:小英子妮
    来源:CSDN
    原文:https://blog.csdn.net/flyaway_07/article/details/50311721
    版权声明:本文为博主原创文章,转载请附上博文链接!

  • 相关阅读:
    C++多线程同步技巧(三)--- 互斥体
    Windows核心编程笔记之进程
    HTTP协议之分块传输与分段编码
    CVE-2013-2551:Internet Explore VML COALineDashStyleArray 整数溢出漏洞简单调试分析
    SQLServer数据库及注入方法
    Windows核心编程笔记之内核对象
    Windows核心编程笔记之错误处理
    Windows核心编程笔记之处理字符串
    CVE-2012-0774:Adobe Reader TrueType 字体整数溢出漏洞调试分析
    CVE-2012-1876:Internet Exporter MSHTML.DLL CaculateMinMax 堆溢出简单分析
  • 原文地址:https://www.cnblogs.com/lnn123/p/9944820.html
Copyright © 2011-2022 走看看