`
遥远的救世主
  • 浏览: 6176 次
  • 性别: Icon_minigender_1
  • 来自: 济南
社区版块
存档分类
最新评论

Android2.2配合Mina时,出现的问题及完美解决方案

阅读更多

1、第三方jar包的使用

这个问题已经不能算是问题了,因为只要使用最新的SDk就可以完美解决此问题。

2、mina包的日志问题

在slf4j的官网已经有专门的android版本的jar包了,所以这也不算什么问题了。

3、Bad address family问题

只要在使用mina之前,设置系统属性: System.setProperty("java.net.preferIPv6Addresses", "false");关闭ipv6就可以了,因为Android2.2不支持ipv6。

4、在通过mina完成android客户端与服务器通信的过程中,我采用直接传输对象的方法来传递消息。当传递的都是一个对象时,是没有任何问题的,但是一旦改变传输的对象,就会出现如下的错误信息。

08-19 14:26:54.170: I/System.out(512): 异常信息:org.apache.mina.filter.codec.ProtocolDecoderException: java.lang.NullPointerException (Hexdump: 00 00 02 EF AC ED 00 05 73 72 01 00 23 6F 72 69 65 6E 74 65 65 72 69 6E 67 2E 6C 6F 67 69 6E 2E 4C 6F 67 69 6E 52 65 73 70 6F 6E 73 65 4D 73 67 78 72 01 00 18 6F 72 69 65 6E 74 65 65 72 69 6E 67 2E 4D 65 73 73 61 67 65 48 65 61 64 78 70 00 00 00 02 74 00 0C 6F 72 69 65 6E 74 65 65 72 69 6E 67 01 00 00 00 05 74 00 08 73 65 63 63 65 65 64 21 75 72 01 00 02 5B 49 78 70 00 00 00 0A 00 00 07 D0 00 00 0B B8 00 00 0F A0 00 00 13 88 00 00 17 70 00 00 07 D0 00 00 07 D0 00 00 07 D0 00 00 07 D0 00 00 07 D0 75 72 01 00 13 5B 4C 6A 61 76 61 2E 6C 61 6E 67 2E 53 74 72 69 6E 67 3B 78 70 00 00 00 0A 74 00 30 E5 9C A8 E6 B4 BB E5 8A A8 E4 B8 AD E6 89 BE E5 9B 9E E8 87 AA E6 88 91 EF BC 8C E4 BA AB E5 8F 97 E6 AF 8F E4 B8 80 E4 BB BD E5 BF AB E4 B9 90 74 00 3C E7 A9 BF E8 B6 8A E5 A4 A7 E8 A1 97 E5 B0 8F E5 B7 B7 EF BC 8C E8 BF BD E5 AF BB E5 9F 8E E9 95 87 E5 8F 91 E5 B1 95 EF BC 8C E5 93 81 E5 91 B3 E5 8F A4 E6 9C B4 E9 A3 8E E6 83 85 74 00 30 E6 A0 B9 E6 8D AE E5 9C B0 E5 9B BE E6 B5 8F E8 A7 88 E5 9B AD E5 8D 9A E5 9B AD EF BC 8C E6 89 BE E5 AF BB E7 A5 9E E7 A7 98 E6 99 AF E7 82 B9 74 00 27 E5 9C A8 E6 B7 B1 E6 9E 97 E4 B8 AD E9 A9 B0 E9 AA 8B EF BC 8C E5 81 9A E5 9B 9E E5 BD 92 E7 9A 84 E7 B2 BE E7 81 B5 74 00 21 E8 B5 B0 E9 81 8D E5 85 AC E5 9B AD E4 B8 8D E4 B8 BA E4 BA BA E7 9F A5 E7 9A 84 E8 A7 92 E8 90 BD 74 00 0C E5 AE 9A E5 90 91 E8 B6 8A E9 87 8E 74 00 06 61 77 61 72 64 20 74 00 04 61 6E 64 20 74 00 04 61 6C 6C 20 74 00 04 61 6E 64 20 75 71 00 7E 00 07 00 00 00 0A 74 00 0F E5 BF AB E4 B9 90 E5 90 91 E5 89 8D E5 86 B2 74 00 0C E6 B7 B1 E5 B7 B7 E8 BF BD E8 B8 AA 74 00 0F E5 9B AD E5 8D 9A E5 9B AD E8 B8 8F E9 9D 92 74 00 0C E8 BF B7 E9 9B BE E9 AC BC E6 9E 97 74 00 0C E5 85 AC E5 9B AD E7 A9 BF E8 A1 8C 74 00 0C E5 AE 9A E5 90 91 E8 BF 90 E5 8A A8 74 00 02 61 6A 74 00 07 41 6A 67 6D 64 6A 20 74 00 03 64 6D 6A 74 00 06 6D 6A 74 77 6D 20 75 71 00 7E 00 07 00 00 00 0A 74 00 04 38 3A 33 30 74 00 04 38 3A 30 30 74 00 04 38 3A 30 30 74 00 04 37 3A 30 30 74 00 04 37 3A 30 30 74 00 04 38 3A 33 30 74 00 04 38 3A 30 38 74 00 04 38 3A 32 31 74 00 04 39 3A 30 38 74 00 04 39 3A 31 37 75 71 00 7E 00 05 00 00 00 0A 00 00 00 14 00 00 00 0A 00 00 00 0F 00 00 00 0F 00 00 00 0A 00 00 00 14 00 00 00 19 00 00 00 19 00 00 00 19 00 00 00 19 74 00 01 34)

经多方查找,最后终于发现原来是android2.2的一个bug,好像是自2.1遗留下来的。自始至终都没有解决这个问题。不过可用一个折中的方案来解决。

解决方案:

将来回写对象,改成来回写字符串。用Gson生成每一个对象的字符串,然后用mina将字符串传到另一端,在另一端用Gson将字符串重新构建成对象。完全不影响原先的构架。简单而强大的json,I服了you。

5、其他异常

除了第四条,比较值得说之外,其他的异常在百度上都可以找到答案,我就不再在这里赘述了。

 

 

在最后,我将我写的android与mina的通信的例子贴出来,供大家把玩。。。。

在这个例子中没有引入Gson,大家可以还原以上的错误,以证明本文章绝对原创。。。。

 

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics