问题背景
项目中碰到调用其他厂家的接口,厂家不仅提供了接口文档还提供了调用基类,但是使用厂家提供的基类调用其服务却失败。看了源码之后发现是connection.setRequestProperty("host","xxxx")
没有设置成功,导致厂家不能识别到host
的值。
问题原因
一个属性能不能加到request中,由allowRestrictedHeaders和restrictedHeaderSet决定的。如果key在restrictedHeaderSet,而且allowRestrictedHeaders为false时,这个key的值是不能加到request中的。
基类源码里面虽然设置了System.setProperty("sun.net.http.allowRestrictedHeaders", "true")
,但是没有生效。allowedRestrictedHeaders系统属性是静态代码块来设置的,在HttpURLConnection
初始化后不会重置。
解决办法
1、在 pom.xml
中添加系统属性变量
<build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-surefire-plugin</artifactId>
<version>2.17</version>
<configuration>
<systemPropertyVariables>
<sun.net.http.allowRestrictedHeaders>true</sun.net.http.allowRestrictedHeaders>
</systemPropertyVariables>
</configuration>
</plugin>
</plugins>
</build>
2、 添加 JVM arg
-Dsun.net.http.allowRestrictedHeaders = true
3、在tomcat
的 catalina.sh
里面添加系统属性变量
-Dsun.net.http.allowRestrictedHeaders=true