4
我正尝试在我的Android手机和我的Raspberry Pi之间建立一个TCP连接。应该很容易,事实证明它不是? 所以我开始用ServerSocket写一个简单的服务器。 它没有工作,所以我减少了代码,直到我得到这个件,它是不工作:Android - ServerSocket权限被拒绝
try
{
String wifiip = wifiIpAddress(this);
Log.v("SERVER", wifiip);
ServerSocket serverSocket = new ServerSocket();
serverSocket.setReuseAddress(true);
serverSocket.bind(new InetSocketAddress(wifiip, 4117));
}catch (Exception ex)
{
ex.printStackTrace();
}
(代码位于的onCreate方法在我MainActivity这是由AndroidStudio创建)
我也尝试用这种方法创建ServerSocket没有成功。
ServerSocket serverSocket = new ServerSocket(4117);
的方法wifiIpAddress从这里拍摄:https://stackoverflow.com/a/18638588/2394967 和工作得很好。
的AndroidManifest.xml中
<manifest ...>
<uses-sdk android:targetSdkVersion="21"></uses-sdk>
<uses-permission android:name="ANDROID.PERMISSION.INTERNET"></uses-permission>
<uses-permission android:name="android.permission.ACCESS_WIFI_STATE"></uses-permission>
...
</manifest>
也许有用信息:
- 我上的ArchLinux运行AndroidStudio
- 我使用新的,不变的项目
- 尝试我尝试了不同的端口(1024以上)
- 我是一个真正的设备上运行的应用程序(的Xperia Z,安卓5.0.2)
- 我试图在另一个线程
运行的ServerSocket logcat的
java.net.SocketException: socket failed: EACCES (Permission denied)
W/System.err﹕ at libcore.io.IoBridge.socket(IoBridge.java:632)
W/System.err﹕ at java.net.PlainSocketImpl.create(PlainSocketImpl.java:198)
W/System.err﹕ at java.net.PlainServerSocketImpl.create(PlainServerSocketImpl.java:38)
W/System.err﹕ at java.net.ServerSocket.<init>(ServerSocket.java:64)
W/System.err﹕ at eu.therealskynet.socketstest.MainActivity.onBtSendClicked(MainActivity.java:47)
W/System.err﹕ at java.lang.reflect.Method.invoke(Native Method)
W/System.err﹕ at java.lang.reflect.Method.invoke(Method.java:372)
W/System.err﹕ at android.view.View$1.onClick(View.java:4078)
W/System.err﹕ at android.view.View.performClick(View.java:4832)
W/System.err﹕ at android.view.View$PerformClick.run(View.java:19839)
W/System.err﹕ at android.os.Handler.handleCallback(Handler.java:739)
W/System.err﹕ at android.os.Handler.dispatchMessage(Handler.java:95)
W/System.err﹕ at android.os.Looper.loop(Looper.java:211)
W/System.err﹕ at android.app.ActivityThread.main(ActivityThread.java:5333)
W/System.err﹕ at java.lang.reflect.Method.invoke(Native Method)
W/System.err﹕ at java.lang.reflect.Method.invoke(Method.java:372)
W/System.err﹕ at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1016)
W/System.err﹕ at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:811)
W/System.err﹕ Caused by: android.system.ErrnoException: socket failed: EACCES (Permission denied)
W/System.err﹕ at libcore.io.Posix.socket(Native Method)
W/System.err﹕ at libcore.io.BlockGuardOs.socket(BlockGuardOs.java:282)
W/System.err﹕ at libcore.io.IoBridge.socket(IoBridge.java:617)
W/System.err﹕ ... 17 more
我甚至不知道什么“套接字失败:EACCES(Permission denied)”应该告诉我...
请问您的应用程序有'INTERNET'许可? – CommonsWare
尝试 我认为它是区分大小写的。 –
谢谢Daniel Bo!这是问题。 (Android Studio,你可以告诉我,真的:/)你可以发布这个答案,所以我可以接受它吗? – Skynet