一次奇怪的“乱码”

客户端在发送HTTP请求时,默认设置了Accept-Encoding为gzip,导致服务端使用nginx返回了gzip压缩内容。客户端未解压内容,从而显示为“乱码”。解决方案包括在客户端移除http头或添加解压处理。通过分析报文和对比curl请求,找出问题在于请求头携带了gzip压缩标识,服务端响应时进行了压缩,而客户端未能正确解压。
摘要由CSDN通过智能技术生成

问题:

客户端,http请求头默认设置了'accept-encoding: gzip, deflate',服务端使用的nginx开启了gzip压缩,返回了压缩内容。客户端收到请求后没有进行解压缩,导致解析失败,打印出来的是压缩数据,误认为是乱码。

解决:

方法一:客户端将http头中的'accept-encoding: gzip, deflate'去掉。(不推荐)

方法二:客户端接收到响应报文后,判断响应是否压缩(响应头中content-encoding属性),如果已经压缩,则进行加压缩操作。

代码中使用了netty作为http客户端,netty这么优秀的框架,支持很多种codec,只需要将解压处理的handler HttpContentDecompressor加到netty的pipeline中就好了,注意位置。

问题发现以及排查过程:

同事对接了一个新的下游服务,发现下游服务返回“乱码”,客户端的代码在线上运行了很久,对接了很多下游,从来没有说乱码过。服务端也表示,自己接了很多客户端,也没有出现过乱码。两个一直运行正常的模块,接到一起就出现问题。大家都坚信自己的模按道理没有问题的。

服务端还表示:自己通过curl访问自己的服务就不会有乱码现象。

分析:

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
UG二次开发中文乱码问题可能由以下原因引起: 1. 字符集设置问题:在UG二次开发时,需要确保使用的字符集与系统或文件本身的字符集一致。如果字符集不匹配,就会导致中文乱码问题。因此,可以尝试在代码中设置正确的字符集,如UTF-8或GBK。 2. 文件编码问题:如果在UG二次开发中涉及到读取或写入文件,需要注意文件的编码格式。如果文件编码格式与读取或写入时指定的格式不匹配,就会导致中文乱码问题。可以尝试使用正确的文件编码格式,如UTF-8或GBK。 3. 程序逻辑问题:有时候,中文乱码问题可能是由于程序逻辑上的错误导致的。例如,在处理字符串时没有正确地转换字符编码,或者没有正确地设置字符集。需要仔细检查代码中涉及到中文处理的部分,确保逻辑正确。 4. 环境配置问题:UG二次开发可能需要在特定的开发环境中进行,例如Eclipse、Visual Studio等。在安装和配置开发环境时,需要确保正确地设置编码格式和字符集。如果环境配置不正确,就会导致中文乱码问题。 为解决中文乱码问题,可以按照以下步骤进行操作: 1. 检查代码中的字符集设置,确保使用的字符集与系统或文件的字符集一致。 2. 如果涉及到文件操作,检查文件的编码格式,并在读取或写入时指定正确的编码格式。 3. 仔细检查代码中的中文处理部分,确保逻辑正确,包括字符编码的转换和字符集的设置等。 4. 确认开发环境的正确配置,包括编码格式和字符集的设置。 如果以上方法仍未解决中文乱码问题,可以参考UG开发文档或向UG开发社区寻求更多帮助。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值