使用java commons-net-2.2里的TelnetClient连接redis,在windows和linux上表现不同, linux平台下应答数据流里的\r\n序列被转换为\n ,导致linux下接收到redis应答之后不能正确解析。
最初以为是telnet模式(比如ANSI、VT100等)导致,但尝试所有模式结果都一样;查看源码发现,TelnetClient使用了 FromNetASCIIInputStream 来处理输入流,会将所有\r\n序列转换为对应平台的换行符,故在linux平台下所有的\r\n会转换为\n。
为解决上述问题,简单粗暴的方式时,在linux下使用telnet时,将line.separator设置为\r\n
System.setProperty("line.separator", "\r\n");
但这种解法并不安全,运行时改变换行符可能对其他的程序有影响,最后终于在网上发现了这个 bugfix ,就是为了解决\r\n被硬编码转换为\n的问题,也可以参考下其他人post的一些 解决方案 。
看commons-net最新3.3版本的源码,已经fix了上述bug,改了下maven依赖,问题得以解决。
commons-net
commons-net
3.3