①报Java.lang.NoclassDefFoundError:org.apache.mina.transport.socket.NioSocketConnector错误.即使用Add External JARS方式运行时报找不到类.
解决方案:
在项目新建lib文件夹,把需要的Jar复制进去,使用Add JARS 选择项目下 Lib文件中发布APK会自动打包进去
②日志包
Mina中使用slf4j做日志框架,slf4j只是框架,没有具体实现.因此Mina引入slf4j 实现包.但Android中有实现包了,就会起冲突.
解决方案:
Android中值添加slf4j-android.jar日志包,Mina中要引入的日志包一律不要.
③权限
以上两个问题解决后,连接服务器,获取的通信渠道(Mina的IoSession)总是NULL,无法传递数据,经调试发现有Java.net.SocketExcetion:Socket failed:
EACCES(Permission denied) ,也就是没有网络访问权限.
解决方案:
在AndroidManifest.xml中添加如下代码:<uses-permission android:name="android.permission.INTERNET" />
④报android.os.NetworkOnMainThreadException异常
抛出此错误在于网络访问在主程序中运行.是网络访问不在主程序进行就可以
解决方案:
一:使用Thread、Runnable:
既然不能在主程序,那么我从新开启一个线程.
二:使用AsyTask(网友说的,没用过,不知道能不能解决)
⑤数据量庞大
不太清楚Android网络访问时一次行传递数据能多大,传输数据量很大时,数据分隔为1990个字节多次传递,但发现传递过去后,服务器第一次只接受1435,之后再接受465个,所以报错.最后为了不改动代码,将1990改为1000