首页 文章

使用JMeter对API进行API请求的JSON

提问于
浏览
0

我正在尝试使用JMeter测试Web API . Web服务器在JMeter和数据库之间进行交互 . 服务器应该从HTTP POST请求中的JSON中获取参数,并将它们解析为查询 .

相关控制器中的Web服务器代码如下所示:

[HttpPost]
    [Route("my_awesome_route_path")]
    public async Task<List<QueryResult>> invoice([FromBody]InvoiceInfo invoiceInfo) 
    {
     query = string.Format("INSERT INTO my_awesome_table (`my`,`awesome`,`columns`) " +
                       "VALUES ({0},{1},{2});", invoiceinfo.awesomeparam1, ... ,invoiceinfo.awesomeparamn);

          noRowsInserted = await db.Database.ExecuteSqlCommandAsync(query);

在我的JMeter HTTP请求表单中,我输入了上述控制器功能的正确路径 . 在使用以下内容填充正文数据选项卡时,我将参数和文件上传选项卡留空了:

${__FileToString(/my/awesome/file/path${__eval({awesome_json_file_name_with_no_dottxt_in_end_altough_it_has_it})}.txt,,)}

运行服务器并且没有正文数据确实将函数传递给我设置的断点 . 所以我知道路线很好 . 将上述代码添加到正文数据会导致415错误 - 不支持的媒体类型 . 以下是JMeter输出文件提供的httpsample:

<httpSample t="8023" it="0" lt="8023" ct="2" ts="1544434665189" s="false" lb="HTTP Request" rc="415" rm="Unsupported Media Type" tn="Thread Group 1-3" dt="text" by="382" sby="281" ng="1" na="1">
<responseHeader class="java.lang.String">HTTP/1.1 415 Unsupported Media Type
Cache-Control: no-cache
Pragma: no-cache
Content-Type: application/json; charset=utf-8
Expires: -1
Server: Microsoft-IIS/7.5
X-AspNet-Version: 4.0.30319
X-Powered-By: ASP.NET
Date: todays_awesome_date
Content-Length: 103
</responseHeader>
  <requestHeader class="java.lang.String">Connection: keep-alive
Content-Length: 37
Content-Type: multipart/form-data; boundary=jBtzRzXGjCNVf_3UH8LfxguE6qR9_xH
Host: awesome_ip_add
User-Agent: Apache-HttpClient/4.5.6 (Java/1.8.0_191)
</requestHeader>
  <responseData class="java.lang.String">{"Message":"The request entity's media type 'multipart/form-data' is not supported for this resource.'}</responseData>
  <cookies class="java.lang.String"></cookies>
  <method class="java.lang.String">POST</method>
  <queryString class="java.lang.String">--jBtzRzXGjCNVf_3UH8LfxguE6qR9_xH--&#xd;
</queryString>
  <java.net.URL>awesome_route_path</java.net.URL>
</httpSample>

问题也不在于sql语法 . 当通过URL给出参数时,它可以从控制器中的另一个函数运行良好 .

我还尝试用路径和参数名称填充文件上传,然后在参数中添加文件,它总是给出相同的错误代码 . 我只是希望JSON参数填充函数的参数,因此可以像代码中所示使用它 . 我错过了什么?谢谢 .

1 回答

相关问题