RestTemplate.postForObject - Error: 400 Bad Request

我们需要知道,RestTmplate是基于HTTP Rest风格的请求方式,它也支持配置SSL的HTTPS访问。

我们可以对基于HTTP协议进行Header,Body等进行自定义封装,但请求Request都存在一个限制值大小范围。

1.代码对比

/**
	 * 
	 * 发送post请求
	 * 
	 * @param url
	 *            请求URL地址
	 * @param data
	 *            json数据
	 * @param token
	 *            RSA加密token【RSA({PlatformCode+TenantCode+DateTime.Now()})//平台代码
	 *            +会员/租户代码+当前时间,然后进行RSA加密】
	 */
	public static String post(String url, String data, String token)
			throws Exception {
		HttpHeaders headers = new HttpHeaders();
		/*headers.add(HttpHeadersImpl.ACCEPT, "application/json");
		headers.add(HttpHeadersImpl.ACCEPT_ENCODING, "gzip");
		headers.add(HttpHeadersImpl.CONTENT_ENCODING, "UTF-8");
		headers.add(HttpHeadersImpl.CONTENT_TYPE,
				"application/json; charset=UTF-8");
		headers.add(HttpHeadersImpl.COOKIE, token);
		headers.add("Token", token);*/
		headers.add("Accept", "application/json");
		headers.add("Accpet-Encoding", "gzip");
		headers.add("Content-Encoding", "UTF-8");
		headers.add("Content-Type", "application/json; charset=UTF-8");
		headers.add("Token", token);

		HttpEntity<String> formEntity = new HttpEntity<String>(data, headers);
		return RestTemplateUtils.getInstance().postForObject(url, formEntity, String.class);
	}

将需要的属性定义到Header:

/**
	 * 
	 * 发送post请求
	 * 
	 * @param url
	 *            请求URL地址
	 * @param data
	 *            json数据
	 * @param token
	 *            RSA加密token【RSA({PlatformCode+TenantCode+DateTime.Now()})//平台代码
	 *            +会员/租户代码+当前时间,然后进行RSA加密】
	 */
	public static String postJZTD(String url, String data, String token)
			throws Exception {
		String platformCode = EhcacheUtil.get("JZTD_OMS_PLATFORMCODE").toString();
		String memberCode =  EhcacheUtil.get("JZTD_OMS_MEMBERCODE").toString();
		String warehouseCode =  EhcacheUtil.get("JZTD_OMS_WAREHOUSECODE").toString();
		HttpHeaders headers = new HttpHeaders();
		/*headers.add(HttpHeadersImpl.ACCEPT, "application/json");
		headers.add(HttpHeadersImpl.ACCEPT_ENCODING, "gzip");
		headers.add(HttpHeadersImpl.CONTENT_ENCODING, "UTF-8");
		headers.add(HttpHeadersImpl.CONTENT_TYPE,
				"application/json; charset=UTF-8");
		headers.add(HttpHeadersImpl.COOKIE, token);
		headers.add("Token", token);*/
		headers.add("Accept", "application/json");
		headers.add("Accpet-Encoding", "gzip");
		headers.add("Content-Encoding", "UTF-8");
		headers.add("Content-Type", "application/json; charset=UTF-8");
		headers.add("Token", token);
		headers.add("PlatformCode", platformCode);
		headers.add("MemberCode", memberCode);
		headers.add("WarehouseCode", warehouseCode);

		HttpEntity<String> formEntity = new HttpEntity<String>(data, headers);
		return RestTemplateUtils.getInstance().postForObject(url, formEntity, String.class);
	}

按照经验,第一种不出意外是可以正确访问的,第二种就值得商榷了,因为加入了非HTTP定义属性字段。

2.解决方案

1.去掉非HTTP Header Request属性。

2.缩短HTTP Header Request属性的值。

3.了解更多关于HTTP的设置相关,以及Spring RestTemplate的HTTP Header限制。

一个简洁的Header设置:

 public void foo(String state) {
        MultiValueMap<String, Object> headers = new LinkedMultiValueMap<String, Object>();
        headers.add("Accept", "application/json");
        headers.add("Content-Type", "application/json");
        String requestBody = "{\"statename\":\"" + state + "\"}";
        HttpEntity request = new HttpEntity(requestBody, headers);
        String apiResponse = getRestTemplate().postForObject(apiEndpoint,request, String.class);
        System.out.println(apiResponse);
     }

注:验证交互的数据最好定义在body里面,尽量让你的HTTP Header 更轻量。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值