当使用RestTemplate进行http请求时,的确很方便,但是当需要进行post请求时遇到了坑
1POST传递参数 :采用 LinkedMultiValueMap ,不能使用HashMap
String url = 'http://posturl'; MultiValueMap<String, String> map= new LinkedMultiValueMap<String, String>(); map.add("shopid","1"); HttpHeaders headers = new HttpHeaders(); headers.setContentType(MediaType.APPLICATION_FORM_URLENCODED); HttpEntity<MultiValueMap<String, String>> request = new HttpEntity<MultiValueMap<String, String>>(map, headers); return restTemplate.postForEntity(url, request,String.class);
- 注意 上面的请求支持参数类型均为String类型,如果MultiValueMap<String, Object> LinkedMultiValueMap 会将value放进list中,key --> [value]
2 采用JSONObject或者实体类传递参数
RestTemplate restTemplate = new RestTemplate(); HttpHeaders headers = new HttpHeaders(); MediaType type = MediaType.parseMediaType("application/json; charset=UTF-8"); headers.setContentType(type); headers.add("Accept", MediaType.APPLICATION_JSON.toString()); JSONObject param = new JSONObject(); param.put("username", "123"); HttpEntity<String> formEntity = new HttpEntity<String>(param.toString(), headers); String result = restTemplate.postForObject(url, formEntity, String.class);
- 使用这种方式可以传递任意类型的参数,避免上面的情况
总结,遇到这种问题时多看看源码会很有帮助。
public class LinkedMultiValueMap<K, V> implements MultiValueMap<K, V>, Serializable, Cloneable { private static final long serialVersionUID = 3801124242820219131L; private final Map<K, List<V>> targetMap; public LinkedMultiValueMap() { this.targetMap = new LinkedHashMap(); } public LinkedMultiValueMap(int initialCapacity) { this.targetMap = new LinkedHashMap(initialCapacity); } public LinkedMultiValueMap(Map<K, List<V>> otherMap) { this.targetMap = new LinkedHashMap(otherMap); } @Nullable public V getFirst(K key) { List<V> values = (List)this.targetMap.get(key); return values != null && !values.isEmpty() ? values.get(0) : null; } public void add(K key, @Nullable V value) { List<V> values = (List)this.targetMap.computeIfAbsent(key, (k) -> { return new LinkedList(); }); values.add(value); } public void addAll(K key, List<? extends V> values) { List<V> currentValues = (List)this.targetMap.computeIfAbsent(key, (k) -> { return new LinkedList(); }); currentValues.addAll(values); } public void addAll(MultiValueMap<K, V> values) { Iterator var2 = values.entrySet().iterator(); while(var2.hasNext()) { Entry<K, List<V>> entry = (Entry)var2.next(); this.addAll(entry.getKey(), (List)entry.getValue()); } } public void set(K key, @Nullable V value) { List<V> values = new LinkedList(); values.add(value); this.targetMap.put(key, values); } public void setAll(Map<K, V> values) { values.forEach(this::set); } public Map<K, V> toSingleValueMap() { LinkedHashMap<K, V> singleValueMap = new LinkedHashMap(this.targetMap.size()); this.targetMap.forEach((key, values) -> { if (values != null && !values.isEmpty()) { singleValueMap.put(key, values.get(0)); } }); return singleValueMap; }
标签:postForEntity,List,RestTemplate,application,values,key,new,public,targetMap From: https://www.cnblogs.com/okeyl/p/17325481.html