Android - ServerSocket权限被拒绝

Sky*_*net 7 java android

我正在尝试在我的Android手机和我的Raspberry Pi之间建立TCP连接.应该很容易,事实证明不是吗?所以我开始用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();
    }
Run Code Online (Sandbox Code Playgroud)

(代码位于我的MainActivity中的onCreate方法,该方法由AndroidStudio创建)

我也尝试用这种方法创建ServerSocket但没有成功.

ServerSocket serverSocket = new ServerSocket(4117);
Run Code Online (Sandbox Code Playgroud)

方法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>
Run Code Online (Sandbox Code Playgroud)

也许有用的信息:

  • 我在ArchLinux上运行AndroidStudio
  • 我尝试使用一个新的未触动项目
  • 我尝试了不同的端口(1024以上)
  • 我在真实设备上运行应用程序(Xperia Z,Android 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
Run Code Online (Sandbox Code Playgroud)

我甚至不知道"套接字失败了:EACCES(Permission denied)"应该告诉我......

Sky*_*net 5

我将自己发布答案。

问题在于,这是区分大小写的

ANDROID.PERMISSION.INTERNET
Run Code Online (Sandbox Code Playgroud)

并且必须这样写:

android.permission.INTERNET
Run Code Online (Sandbox Code Playgroud)