当前位置:网站首页>feign调用不通问题,JSON parse error Illegal character ((CTRL-CHAR, code 31)) only regular white space (r
feign调用不通问题,JSON parse error Illegal character ((CTRL-CHAR, code 31)) only regular white space (r
2022-07-28 22:23:00 【m0_54861649】
背景:feign调用不通,报错,困了我快一个月!!!可恶,中间花了两天解决,把百度都试了一遍,都没有用,都快哭了,现在说下解决过程。
①开始我打开了日志进行进一步查看报错信息,需要在feign使用配置文件中加入日志级别,日志级别是FULL,并在配置文件中也加入日志级别。


②然后发现报错404 not found,开始以为是参数不够,被调用为三个参数,调用时传两个参数,加上了之后还是报错,然后发现是注解用错了,之前用的是@PathVariable(复制过来没有改),使用@RequestParam后错误改变(低级错误)。
③报错:nested exception is com.fasterxml.jackson.core.JsonParseException: Illegal character ((CTRL-CHAR, code 31)): only regular white space ( , , ) is allowed between tokens
at [Source: (ByteArrayInputStream); line: 1, column: 2]。

④然后feign调用接口,使用String接收,把字符串打印出来,发现乱码了???

还发现传回来是二进制数据??
然后开始了疯狂的百度中,中间试了无数次,各种加什么配置,去掉压缩之类的都不行,还有加过滤器什么的也不行。
最后终于在一个大哥的文章中发现了答案,他和我一样是打印出来发现乱码,这个问题就是gzip接收到的还是压缩数据,所以乱码,还是试了一下他说没用的配置,结果对我有用!!!!!(他下面真正对她有用的方法对我没用,也是加拦截器)
答案:在配置文件中加入feign.compression.response.useGzipDecoder为true即可。
⑤乱码的事情没了,发现只有中文乱码了,靠!!!!!!又整了我好久好久,百度的所有方案都试过了,还看了feign日志所有参数,好像也没问题的,人都快哭了,终于找到了解决方案。
@Configuration
public class FeignConfig implements RequestInterceptor {
@Autowired
private ObjectFactory<HttpMessageConverters> messageConverters;
@Bean
public Encoder feignFormEncoder() {
return new SpringFormEncoder(new SpringEncoder(messageConverters));
}
@Bean
public Decoder feignDecoder() {
return new ResponseEntityDecoder(new SpringDecoder( () -> {
FastJsonHttpMessageConverter fastConverter = new FastJsonHttpMessageConverter() {
@Override
public Object read(Type type, Class<?> contextClass, HttpInputMessage inputMessage) throws IOException, HttpMessageNotReadableException {
Object result=null;
if ("java.lang.String".equals(type.getTypeName())) {
result= StreamUtils.copyToString(inputMessage.getBody(), Charset.forName("utf8"));
} else {
result=super.read(type, contextClass, inputMessage);
}
return result;
}
};
return new HttpMessageConverters(fastConverter);
}));
}
@Override
public void apply(RequestTemplate requestTemplate) {
try {
ServletRequestAttributes servletRequestAttributes = (ServletRequestAttributes) RequestContextHolder
.getRequestAttributes();
if (null != servletRequestAttributes) {
HttpServletRequest request = servletRequestAttributes.getRequest();
// 获取所有头文件信息的key
Enumeration<String> headerNames = request.getHeaderNames();
if (null != headerNames) {
while (headerNames.hasMoreElements()) {
// 获取头文件的key和value
String headerName = headerNames.nextElement();
String headerValue = request.getHeader(headerName);
// 跳过content-length,不然可能会报too many bites written问题
if ("content-length".equalsIgnoreCase(headerName)) {
continue;
}
// 将令牌数据添加到头文件中,当用feign调用的时候,会传递给下一个微服务
requestTemplate.header(headerName, headerValue);
}
}
}
} catch (Exception e) {
e.printStackTrace();
}
}
@Bean
public Logger.Level feignLoggerLevel() {
return Logger.Level.FULL;
}
}
参考:Feign乱码 - 知乎
答案:加了个解码器,转成utf8就可以了。
边栏推荐
- 1-7 解决类中方法的this指向问题
- 【C】 Reverse string (two recursive ideas)
- Detailed explanation of 9 common reasons for MySQL index failure
- Servlet operation principle_ API details_ Advanced path of request response construction (servlet_2)
- 【MySQL系列】MySQL数据库基础
- EN 1873屋面用装配附件.塑料单个屋面灯—CE认证
- 研发效能的道法术器
- curl (7) Failed connect to localhost8080; Connection refused
- SQL left connection, internal connection writing method "recommended collection"
- Build SSM project with JSP as view parser
猜你喜欢

PowerCL 批量创建及管理虚拟交换机

Detailed principle explanation and verification results of digital clock based on FPGA

Eight performance analysis indicators of effective supply chain management (Part 1)

Create AP hotspots for imx6 development board QT system based on rtl8723 cross compile iptables

Detailed explanation of 9 common reasons for MySQL index failure

【TA-霜狼_may-《百人计划》】美术2.2 模型基础

Real time data warehouse: meituan's implementation of real-time data warehouse construction based on Flink

EN 1935 building hardware. Single axis hinge - CE certification

【C】 Drink soda and find a single dog

ZABBIX 5.0 uses its own redis template for monitoring
随机推荐
【TA-霜狼_may-《百人计划》】美术2.2 模型基础
Leetcode63. Different paths II
实时数仓:美团基于Flink的实时数仓建设实施
CANoe应用案例之DoIP通信
The failure rate is as high as 80%. How to correctly complete the strategic planning of digital transformation?
Leetcode60. 排列序列
Control fillet stroke materialshapedrawable
【TA-霜狼_may-《百人计划》】图形3.6 纹理压缩——包体瘦身术
EN 1935 building hardware. Single axis hinge - CE certification
1-6 state与绑定事件
[TA frost wolf \u may - "hundred people plan"] Figure 3.6 texture compression - inclusion slimming
Compose 的声明式代码如此简洁?
Real time data warehouse: Didi's real-time data warehouse landing practice
【MySQL 8】Generated Invisible Primary Keys(GIPK)
【C】 Introduction and Simulation Implementation of ATOI and offsetof
Have passed hcip and joined the company of your choice, and share the learning experience and experience of Huawei certification
Leetcode 763. partition labels divide alphabetic intervals (medium)
Leetcode64. 最小路径和
VS2005 accesses the setting method "recommended collection" of vss2005 through sourceoffsite
Add build dependency error
