Java 在Android应用程序上创建套接字
我用Java制作了一个客户端和服务器程序,通过网络控制我的电脑,并且工作正常。我现在正在将客户端改为Android应用程序,在打开套接字时遇到了一些问题 外部方法:Java 在Android应用程序上创建套接字,java,android,sockets,Java,Android,Sockets,我用Java制作了一个客户端和服务器程序,通过网络控制我的电脑,并且工作正常。我现在正在将客户端改为Android应用程序,在打开套接字时遇到了一些问题 外部方法: private PrintWriter clientMessage; private Socket socket; private int port = 1234; 单击“连接”按钮: try { System.out.println("a"); InetAddress IP = InetAddress.getBy
private PrintWriter clientMessage;
private Socket socket;
private int port = 1234;
单击“连接”按钮:
try {
System.out.println("a");
InetAddress IP = InetAddress.getByName("192.168.0.12");
System.out.println("a");
System.out.println("b");
socket = new Socket(IP, port);
System.out.println("b");
connected = true;
System.out.println("connected");
clientMessage = new PrintWriter(socket.getOutputStream(), true);
}
catch (IOException ex) {
System.out.println("error connecting");
}
控制台返回:
12-07 23:59:50.812 I/System.out: a
12-07 23:59:50.812 D/libc: [NET] android_getaddrinfofornet+,hn 12(0x3139322e313638),sn(),hints(known),family 0,flags 4
12-07 23:59:50.812 D/libc: [NET] android_getaddrinfofornet-, SUCCESS
12-07 23:59:50.812 I/System.out: a
12-07 23:59:50.812 I/System.out: b
12-07 23:59:50.812 I/System.out: error connecting
。。。单击“连接”按钮。从a/b标记中,我可以看到创建套接字时出现了问题
这段代码和我在Java应用程序中使用的客户端代码差不多,所以我不确定这里出了什么问题
非常新的安卓系统,如果这是显而易见的,很抱歉-提前感谢
注意:端口号和IP地址对于服务器是正确的,并且服务器是打开的并且运行正常,所以不是这样
编辑1:
正在引发的IOException的堆栈跟踪:
W/System.err: java.net.SocketException: socket failed: EACCES (Permission denied)
W/System.err: at libcore.io.IoBridge.socket(IoBridge.java:623)
W/System.err: at java.net.PlainSocketImpl.create(PlainSocketImpl.java:198)
W/System.err: at java.net.Socket.startupSocket(Socket.java:582)
W/System.err: at java.net.Socket.<init>(Socket.java:226)
W/System.err: at kaihulme.remoteapplication.MainActivity.onClick(MainActivity.java:80)
W/System.err: at android.view.View.performClick(View.java:4756)
W/System.err: at android.view.View$PerformClick.run(View.java:19749)
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:135)
W/System.err: at android.app.ActivityThread.main(ActivityThread.java:5221)
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:899)
W/System.err: at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:694)
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:608)
W/System.err: ... 14 more
W/System.err:java.net.SocketException:socket失败:EACCES(权限被拒绝)
W/System.err:at libcore.io.IoBridge.socket(IoBridge.java:623)
W/System.err:at java.net.PlainSocketImpl.create(PlainSocketImpl.java:198)
W/System.err:at java.net.Socket.startupSocket(Socket.java:582)
W/System.err:at java.net.Socket.(Socket.java:226)
W/System.err:at kaihulme.remoteapplication.MainActivity.onClick(MainActivity.java:80)
W/System.err:at-android.view.view.performClick(view.java:4756)
W/System.err:at-android.view.view$PerformClick.run(view.java:19749)
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:135)
W/System.err:at-android.app.ActivityThread.main(ActivityThread.java:5221)
W/System.err:at java.lang.reflect.Method.invoke(本机方法)
W/System.err:at java.lang.reflect.Method.invoke(Method.java:372)
W/System.err:com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:899)
W/System.err:com.android.internal.os.ZygoteInit.main(ZygoteInit.java:694)
W/System.err:原因:android.System.ErrnoException:套接字失败:EACCES(权限被拒绝)
W/System.err:at libcore.io.Posix.socket(本机方法)
W/System.err:at libcore.io.BlockGuardOs.socket(BlockGuardOs.java:282)
W/System.err:at libcore.io.IoBridge.socket(IoBridge.java:608)
W/System.err:。。。14多
编辑2:
添加了权限:
<uses-permission android:name="android.permission.INTERNET"/>
。。。查看并收到以下错误后,返回到Android清单:
D/AndroidRuntime: Shutting down VM
E/AndroidRuntime: FATAL EXCEPTION: main
Process: kaihulme.remoteapplication, PID: 24959
android.os.NetworkOnMainThreadException
at android.os.StrictMode$AndroidBlockGuardPolicy.onNetwork(StrictMode.java:1147)
at libcore.io.BlockGuardOs.connect(BlockGuardOs.java:110)
at libcore.io.IoBridge.connectErrno(IoBridge.java:137)
at libcore.io.IoBridge.connect(IoBridge.java:122)
at java.net.PlainSocketImpl.connect(PlainSocketImpl.java:183)
at java.net.PlainSocketImpl.connect(PlainSocketImpl.java:163)
at java.net.Socket.startupSocket(Socket.java:590)
at java.net.Socket.<init>(Socket.java:226)
at kaihulme.remoteapplication.MainActivity.onClick(MainActivity.java:80)
at android.view.View.performClick(View.java:4756)
at android.view.View$PerformClick.run(View.java:19749)
at android.os.Handler.handleCallback(Handler.java:739)
at android.os.Handler.dispatchMessage(Handler.java:95)
at android.os.Looper.loop(Looper.java:135)
at android.app.ActivityThread.main(ActivityThread.java:5221)
at java.lang.reflect.Method.invoke(Native Method)
at java.lang.reflect.Method.invoke(Method.java:372)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:899)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:694)
I/Process: Sending signal. PID: 24959 SIG: 9
D/AndroidRuntime:关闭VM
E/AndroidRuntime:致命异常:主
进程:kaihulme.remoteapplication,PID:24959
android.os.NetworkOnMainThreadException
在android.os.StrictMode$AndroidBlockGuardPolicy.onNetwork(StrictMode.java:1147)
在libcore.io.BlockGuardOs.connect上(BlockGuardOs.java:110)
在libcore.io.IoBridge.ConnecterNo(IoBridge.java:137)中
位于libcore.io.IoBridge.connect(IoBridge.java:122)
位于java.net.PlainSocketImpl.connect(PlainSocketImpl.java:183)
位于java.net.PlainSocketImpl.connect(PlainSocketImpl.java:163)
位于java.net.Socket.startupSocket(Socket.java:590)
位于java.net.Socket(Socket.java:226)
在kaihulme.remoteapplication.MainActivity.onClick(MainActivity.java:80)上
在android.view.view.performClick上(view.java:4756)
在android.view.view$PerformClick.run(view.java:19749)
位于android.os.Handler.handleCallback(Handler.java:739)
位于android.os.Handler.dispatchMessage(Handler.java:95)
位于android.os.Looper.loop(Looper.java:135)
位于android.app.ActivityThread.main(ActivityThread.java:5221)
位于java.lang.reflect.Method.invoke(本机方法)
位于java.lang.reflect.Method.invoke(Method.java:372)
在com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:899)上
位于com.android.internal.os.ZygoteInit.main(ZygoteInit.java:694)
I/进程:发送信号。PID:24959信号:9
编辑3:
AndroidManifest.xml:
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="kaihulme.remoteapplication">
<uses-permission android:name="android.permission.INTERNET"/>
<application
android:allowBackup="true"
android:icon="@mipmap/ic_launcher"
android:label="@string/app_name"
android:supportsRtl="true"
android:theme="@style/AppTheme">
<activity
android:name=".MainActivity"
android:label="@string/app_name">
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
</application>
</manifest>
android与PC是否在同一网络上?路上有防火墙吗?你能从安卓系统ping这台电脑吗?你能提供引发IOException的堆栈跟踪吗?@ScaryWombat是的,他们在网络上(也在同一台电脑上用模拟器进行了尝试,得到了相同的结果)。我还认为没有防火墙问题,因为它是作为Java应用程序而不是Android应用程序工作的(但可能是错误的),请检查编辑中的堆栈跟踪。@novak Edit显示IOException的堆栈跟踪查看您的AndroidManifest.xml