使用丝袜哥(swagger)postman测试文件下载接口遇到的中文乱码问题,坑!

今天周日,处理了一个下载Excel文件的小需求,代码很简单,往response里的输出流response.getOutputStream()写入数据,就完了。

但在测试时,使用postman测试,文件名中的中文部分乱码,使用swagger测试,不光文件名中文乱码,连内容都是乱码的!!!!!!

 

本来,下载文件接口使用get请求就行了,但我这的项目,为了前端能把请求参数封装为一个结构体,都是使用post方式,后台使用一个@RequestBody注解接收参数。post请求,不好直接使用Chrome浏览器测试,于是,我也就没忘这方便多想。

 

于是,就陷入了对 丝袜哥 和 postman 的乱码排除中,大概折腾了二三个小时,还是无果!!!!!如下图:

 

大周末的,给人整的有些烦躁了,于是,我转变了思考方式,又写了一个get接口,直接在Chrome中输入连接,来实现下载功能,结果测试成功!!内容也不乱码了,文件名也不乱码了,哈哈哈!

 

下载文件类型的接口,记得在swagger上的注解加上类型,如下图:

@ApiOperation(value = "根据文件链接 任务类型下载文件",produces="application/octet-stream")

加上之后,用swagger测试,中文文件名乱码依旧,但解决了文件内容乱码的问题!

如有同行,再遇到这个坑,不用管它,不要再陷进去找解决方案。

 

  • 9
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
Swagger 接口文档可以用于自动生成接口测试的 YAML 文件,具体步骤如下: 1. 在 Swagger UI 中找到要测试接口,并点击 "Try it out" 按钮。 2. 填写测试需要的参数,并点击 "Execute" 按钮。 3. 点击 "Code" 按钮,选择 "Shell"。 4. 复制代码,并粘贴到一个文本编辑器中保存为 YAML 文件。 YAML 文件中包含了测试所需的请求参数、请求方法、请求头等信息,可以通过自动化测试工具读取并执行测试。 示例代码如下: ```python import requests import yaml # Swagger 文档地址 SWAGGER_URL = 'http://your.swagger.host/swagger.json' # 发送 GET 请求,获取 Swagger 文档 response = requests.get(SWAGGER_URL) # 解析 Swagger 文档中的接口信息 if response.status_code == 200: swagger_doc = response.json() paths = swagger_doc.get('paths', {}) for path, methods in paths.items(): for method, info in methods.items(): # 获取接口的 URL url = f'{SWAGGER_URL.rstrip("/")}{path}' # 获取接口的请求方法 http_method = method.upper() # 获取接口的请求参数 parameters = info.get('parameters', []) # 获取接口的请求头部信息 headers = {} if 'headers' in info: for header in info['headers']: headers[header['name']] = header['description'] # 构造测试用例 test_case = { 'name': f'{http_method} {url}', 'request': { 'url': url, 'method': http_method, 'headers': headers, 'params': {} } } # 将请求参数添加到测试用例中 if parameters: for param in parameters: if 'name' in param: test_case['request']['params'][param['name']] = param.get('example') # 将测试用例转换为 YAML 格式并输出到文件中 with open(f'{http_method}_{path.replace("/", "_")}.yml', 'w') as f: yaml.dump(test_case, f, default_flow_style=False) else: print(f'Failed to get Swagger document. Status code: {response.status_code}') ``` 在上述代码中,我们使用 `requests` 库向 Swagger 文档的 URL 发送 GET 请求,获取 Swagger 文档的 JSON 数据。然后,解析 JSON 数据,获取每个接口的 URL、请求方法、请求参数和请求头信息等信息。最后,根据接口信息构造测试用例,并将测试用例转换为 YAML 格式并输出到文件中。你可以根据需要对测试用例进行扩展和优化。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值