http请求传参的几种类型

简介: postman及java应用中对http请求传参的类型总结

首先看到postman的请求页面

postman.png

当我们不设置请求头时,使用 Params 传参时,参数是直接拼接在URL后面的,springboot中接收参数是这样的


@PostMapping("/post/url")
    public String postUrl(String id, String name){
        log.info("id : {}, name:{}",id,name);
        return "success";
    }

当使用 Body 来传递参数时



可以看到,有 以下几种传参方式,对应的是不同的 Content-Type


  • none:不设置,默认值
  • form-data:multipart/form-data
  • x-www-form-urlencoded:application/x-www-form-urlencoded
  • raw:application/json


form-data


通常用于表单提交,后台接口可以直接使用(String name)等接收单个参数,也可以使用 实体类来接收全部参数,注意这里的参数名或者实体类里的属性名称必须与传递的名称一致


@PostMapping("/post/form")
    public String postForm(String id, String name, User user){
        log.info("id : {}, name:{}",id,name);
        return "success";
    }

x-www-form-urlencoded


参数被编码为名称/值对,接收参数的方式和 form-data 相同


application/json


最常用的传参方式,传递参数为json,后台必须使用 @RequestBody注解来接收参数。可以使用实体类或者 Map, 值得注意的是,@RequestBody注解在一个接口中只能有一个,多个不生效的



@PostMapping("/post/json")
    public String postJson(@RequestBody User user){
        log.info("user : {}",user);
        return "success";
    }


@PostMapping("/post/json")
    public String postJson(@RequestBody Map map){
        log.info("map : {}",map);
        return "success";
    }

RestTemplate构造请求


RestTemplate 是从 Spring3.0 开始支持的一个 http 请求工具,RestTemplate是Spring提供的用于访问Rest服务的客户端,它提供了很多可以方便访问远程http服务的方法,这些方法可以帮助开发人员减少编写客户端代码的工作量。


SpringFramework提供了一个RestTemplate模板工具类,对基于Http的客户端进行了封装,并且实现了对象与json的序列化和反序列化,非常方便


RestTemplate 是 Spring Resources 中一个访问第三方 RESTful API 接口的网络请求框架。 RestTemplate 的设计原则和其他 Spring Template (例如 JdbcTemplate、 JmsTemplate)类似,都 是为执行复杂任务提供了一个具有默认行为的简单方法。


RestTemplate 是用来消费 REST 服务的,所以 RestTemplate 的主要方法都与 REST 的 Http协议的一些方法紧密相连,例如 HEAD、 GET、 POST、 PUT、 DELETE 和 OPTIONS 等方法, 这些方法在 RestTemplate 类对应的方法为 headFor Headers()、 getForObject()、 postForObject()、 put()和 delete()等


  1. RestTemplate 默认是无法注入的,需要在配置类中直接new一个,或者自定义的各种参数,


@Bean
   public RestTemplate restTemplate(){
      return new RestTemplate();
   }
  1. 或者自定义他的各种参数


@Configuration
public class RestTemplateConfig {
    @Bean(name="httpClient")
    public CloseableHttpClient httpClient() {
        return HttpClientBuilder.create().build();
    }
    @Bean
    public RestTemplate restTemplate() {
        RestTemplate restTemplate = new RestTemplate(clientHttpRequestFactory());
        return restTemplate;
    }
    @Bean
    public HttpComponentsClientHttpRequestFactory clientHttpRequestFactory() {
        HttpComponentsClientHttpRequestFactory clientHttpRequestFactory = new HttpComponentsClientHttpRequestFactory();
        clientHttpRequestFactory.setHttpClient(httpClient());
        return clientHttpRequestFactory;
    }
    @Bean
    public TaskScheduler taskScheduler() {
        ThreadPoolTaskScheduler scheduler = new ThreadPoolTaskScheduler();
        scheduler.setThreadNamePrefix("poolScheduler");
        scheduler.setPoolSize(50);
        return scheduler;
    }
}
  1. x-www-form-urlencoded 格式


直接拼接在URL后面即可


  1. form-data 格式


HttpHeaders headers = new HttpHeaders();
        HttpMethod method = HttpMethod.POST;
            // 设置以表单的方式提交
        headers.add("Content-Type",MediaType.MULTIPART_FORM_DATA_VALUE);
        headers.add("token","aaaaaa");
            //将请求头部和参数合成一个请求
        MultiValueMap<String, Object> paramMap = new LinkedMultiValueMap<>();
        paramMap.add("status","aaa");
        paramMap.add("compere","aa");
        paramMap.add("meetingSummary",ccpcGroupZzsh.getMeetingSummary());
        paramMap.add("token",bhToken);
        HttpEntity< MultiValueMap<String, Object>> requestEntity = new HttpEntity<>(paramMap, headers);
            //执行HTTP请求
        String url="http://"+host+"/test";
        ResponseEntity<String> response = restTemplate.exchange(url, method, requestEntity,String.class );
  1. json格式


  
HttpHeaders headers = new HttpHeaders();
        HttpMethod method = HttpMethod.POST;
        // 设置以json的方式提交
        headers.add("Content-Type", MediaType.APPLICATION_JSON_VALUE);
        headers.add("token",loginUser.getBhToken());
        headers.add("Accept", MediaType.APPLICATION_JSON.toString());
        //将请求头部和参数合成一个请求
        Map paramMap = new HashMap<>();
        paramMap.put("page",String.valueOf(pageParams.getCurrent()));
        paramMap.put("rows",String.valueOf(pageParams.getSize()));
        paramMap.put("userId",String.valueOf(memberId));
        JSONObject jsonObj = new JSONObject(paramMap);
        HttpEntity<String> requestEntity = new HttpEntity<>(jsonObj.toString(), headers);
        //执行HTTP请求,将返回的结构使用ResultVO类格式化
        String url="http://"+host+"/test/json";
        String response = restTemplate.postForObject(url,  requestEntity,String.class );
目录
相关文章
|
6月前
|
JSON 监控 API
掌握使用 requests 库发送各种 HTTP 请求和处理 API 响应
本课程全面讲解了使用 Python 的 requests 库进行 API 请求与响应处理,内容涵盖环境搭建、GET 与 POST 请求、参数传递、错误处理、请求头设置及实战项目开发。通过实例教学,学员可掌握基础到高级技巧,并完成天气查询应用等实际项目,适合初学者快速上手网络编程与 API 调用。
657 130
|
9月前
|
JavaScript 前端开发 API
Node.js中发起HTTP请求的五种方式
以上五种方式,尽管只是冰山一角,但已经足以让编写Node.js HTTP请求的你,在连接世界的舞台上演奏出华丽的乐章。从原生的 `http`到现代的 `fetch`,每种方式都有独特的风格和表现力,让你的代码随着项目的节奏自由地舞动。
826 65
|
7月前
HTTP协议中请求方式GET 与 POST 什么区别 ?
GET和POST的主要区别在于参数传递方式、安全性和应用场景。GET通过URL传递参数,长度受限且安全性较低,适合获取数据;而POST通过请求体传递参数,安全性更高,适合提交数据。
684 2
|
8月前
|
Go 定位技术
Golang中设置HTTP请求代理的策略
在实际应用中,可能还需要处理代理服务器的连接稳定性、响应时间、以及错误处理等。因此,建议在使用代理时增加适当的错误重试机制,以确保网络请求的健壮性。此外,由于网络编程涉及的细节较多,彻底测试以确认代理配置符合预期的行为也是十分重要的。
323 8
|
8月前
|
缓存
|
7月前
|
JSON JavaScript API
Python模拟HTTP请求实现APP自动签到
Python模拟HTTP请求实现APP自动签到
|
7月前
|
数据采集 JSON Go
Go语言实战案例:实现HTTP客户端请求并解析响应
本文是 Go 网络与并发实战系列的第 2 篇,详细介绍如何使用 Go 构建 HTTP 客户端,涵盖请求发送、响应解析、错误处理、Header 与 Body 提取等流程,并通过实战代码演示如何并发请求多个 URL,适合希望掌握 Go 网络编程基础的开发者。
|
8月前
|
缓存 JavaScript 前端开发
Vue 3 HTTP请求封装导致响应结果无法在浏览器中获取,尽管实际请求已成功。
通过逐项检查和调试,最终可以定位问题所在,修复后便能正常在浏览器中获取响应结果。
318 0
|
8月前
|
Go
如何在Go语言的HTTP请求中设置使用代理服务器
当使用特定的代理时,在某些情况下可能需要认证信息,认证信息可以在代理URL中提供,格式通常是:
557 0
|
10月前
|
Go
在golang中发起http请求以获取访问域名的ip地址实例(使用net, httptrace库)
这只是追踪我们的行程的简单方法,不过希望你跟着探险家的脚步,即使是在互联网的隧道中,也可以找到你想去的地方。接下来就是你的探险之旅了,祝你好运!
543 26