博客
关于我
LoadRunner测试下载文件
阅读量:803 次
发布时间:2023-02-06

本文共 1575 字,大约阅读时间需要 5 分钟。

如何让LoadRunner下载文件并保存本地

在使用LoadRunner进行功能测试时,很多人会遇到一个问题:虽然LoadRunner能够录制并分析客户端与服务器之间的交互,但在录制的脚本中却找不到任何与下载文件相关的操作。这种情况是为什么呢?我们来深入分析一下。

问题分析

  • 文件请求的特性

    在HTTP协议中,文件的下载请求实际上是通过GET方法发出的,与其他类型的GET请求没有本质区别。因此,从LoadRunner的录制日志中,我们只能看到客户端请求文件的具体路径和参数,而无法直接看到"下载"的明确动作。

  • 响应内容的关联性

    危险的是,虽然LoadRunner无法直接记录下载操作,但它确实能够完整地记录客户端与服务器之间的通信过程。这意味着我们可以从日志中提取出与文件下载相关的信息,然后利用这些信息自行构建下载文件的功能。

  • 解决方案

    通过对LoadRunner录制日志的分析,我们可以发现以下关键信息:

  • 文件请求的具体细节

    LoadRunner会记录下客户端向服务器发出的文件请求,包括请求的URL、内容类型、来源页面等信息。例如:

    web_url("viewfile.asp",         "URL=http://www.testage.net/bbs/viewFile.asp?BoardID=25&ID=217",        "Resource=0",        "RecContentType=text/html",        "Referer=http://www.testage.net/bbs/dispbbs.asp?boardID=25&ID=5187&page=1",        "Snapshot=t16.inf",        "Mode=HTML",        EXTRARES,        "Url=viewFile.asp?BoardID=25&ID=217",        "Referer=http://www.testage.net/bbs/dispbbs.asp?boardID=25&ID=5187&page=1",        ENDITEM,        LAST);
  • 文件内容的提取

    在响应中,我们可以找到文件的全部内容。通过关联请求和响应,我们可以知道文件的大小和具体内容。例如:

    flen = web_get_int_property(HTTP_INFO_DOWNLOAD_SIZE);
  • 文件本地存储

    通过LoadRunner提供的文件操作函数(如fopenfwritefclose等),我们可以将文件内容保存到本地。例如:

    filedes = fopen("c:\\test.rar", "wb");if (filedes == NULL) {    lr_output_message("Open File Failed!");    return -1;}fwrite(lr_eval_string("{fcontent}"), flen, 1, filedes);fclose(filedes);
  • 注意事项

  • 文件路径

    在上述代码中,c:\\test.rar是文件路径,需要根据实际情况修改。确保路径正确,避免出现错误。

  • 用户验证信息

    如果服务器需要验证用户信息(如username和passwd),请在代码中添加相应的验证逻辑。

  • 文件命名规则

    如果希望生成不同的文件名,可以根据实际需求添加命名规则。例如,根据文件扩展名自动生成文件名。

  • 总结

    通过上述方法,我们可以实现LoadRunner下载文件并保存到本地的功能。虽然LoadRunner本身并不直接支持文件下载操作,但通过分析请求和响应信息,我们可以模拟下载过程,并将文件内容保存到本地。

    转载地址:http://afufk.baihongyu.com/

    你可能感兴趣的文章
    OAuth 2.0 MAC Tokens
    查看>>
    OAuth 及 移动端鉴权调研
    查看>>
    OAuth2 + Gateway统一认证一步步实现(公司项目能直接使用),密码模式&授权码模式
    查看>>
    OAuth2 Provider 项目常见问题解决方案
    查看>>
    OAuth2 vs JWT,到底怎么选?
    查看>>
    Vue.js 学习总结(14)—— Vue3 为什么推荐使用 ref 而不是 reactive
    查看>>
    oauth2-shiro 添加 redis 实现版本
    查看>>
    OAuth2.0_JWT令牌-生成令牌和校验令牌_Spring Security OAuth2.0认证授权---springcloud工作笔记148
    查看>>
    OAuth2.0_JWT令牌介绍_Spring Security OAuth2.0认证授权---springcloud工作笔记147
    查看>>
    OAuth2.0_介绍_Spring Security OAuth2.0认证授权---springcloud工作笔记137
    查看>>
    OAuth2.0_完善环境配置_把资源微服务客户端信息_授权码存入到数据库_Spring Security OAuth2.0认证授权---springcloud工作笔记149
    查看>>
    OAuth2.0_授权服务配置_Spring Security OAuth2.0认证授权---springcloud工作笔记140
    查看>>
    OAuth2.0_授权服务配置_三项内容_Spring Security OAuth2.0认证授权---springcloud工作笔记141
    查看>>
    OAuth2.0_授权服务配置_令牌服务和令牌端点配置_Spring Security OAuth2.0认证授权---springcloud工作笔记143
    查看>>
    OAuth2.0_授权服务配置_客户端详情配置_Spring Security OAuth2.0认证授权---springcloud工作笔记142
    查看>>
    OAuth2.0_授权服务配置_密码模式及其他模式_Spring Security OAuth2.0认证授权---springcloud工作笔记145
    查看>>
    OAuth2.0_授权服务配置_授权码模式_Spring Security OAuth2.0认证授权---springcloud工作笔记144
    查看>>
    OAuth2.0_授权服务配置_资源服务测试_Spring Security OAuth2.0认证授权---springcloud工作笔记146
    查看>>
    OAuth2.0_环境介绍_授权服务和资源服务_Spring Security OAuth2.0认证授权---springcloud工作笔记138
    查看>>
    OAuth2.0_环境搭建_Spring Security OAuth2.0认证授权---springcloud工作笔记139
    查看>>