Android 客户端连接到 pc 上的服务器,使用 Java 套接字

Android client connecting to server on pc, using Java sockets

我想将一个简单的字符串发送到台式电脑上的服务器。这是我电脑上的内容:

public static void main(String[] args) {
System.out.println("Server Started");
    Server server = new Server();
    server.start();
}

public void start(){
    try {
    ServerSocket SRVSOCK = new ServerSocket(333);
    Socket SOCK = SRVSOCK.accept();
    InputStreamReader ir = new InputStreamReader(SOCK.getInputStream());
    BufferedReader bf = new BufferedReader(ir);

    String MESSAGE = bf.readLine();
        System.out.println(MESSAGE);
    } catch (IOException e) {
        // TODO Auto-generated catch block
        e.printStackTrace();    
    }
}   

对于我的 android 平板电脑,我在 onCreate() 中有这个:

@Override
protected void onCreate(Bundle savedInstanceState) {
   super.onCreate(savedInstanceState);  
   setContentView(R.layout.activity_main);
   Thread tthread = new Thread(new Runnable(){
       @Override
            public void run() {
                Connect();
            }});
    }

public void Connect(){      
    try {
        Socket SOCK = new Socket("10.0.0.3", 333);
        PrintWriter pw = new PrintWriter(SOCK.getOutputStream());
        pw.println("FROM ANDROID!");
     } catch (UnknownHostException e) {
        // TODO Auto-generated catch block
        e.printStackTrace();
     } catch (IOException e) {
        // TODO Auto-generated catch block
        e.printStackTrace();
    }                   
}

我看到你可以创建一个你需要的新线程(否则应用程序 UI 冻结),但它仍然没有将文本发送到我的服务器,我已经添加了传入和传出端口我的 windows 防火墙,甚至试图关闭防火墙,但仍然没有成功..

android 代码是 运行 在真实的物理平板电脑 (Nexus 7 2013) 而不是模拟器上。

这里有什么问题?

打开应用程序时我的日志猫中的内容

03-24 13:43:59.695: I/ActivityManager(768): START u0 {act=android.intent.action.MAIN cat=[android.intent.category.LAUNCHER] flg=0x10200000 cmp=com.hashimo.mcpeworldconverter/.MainActivity bnds=[200,1314]  [400,1590] (has extras)} from uid 10022 on display 0
03-24 13:43:59.780: I/ActivityManager(768): Start proc com.hashimo.mcpeworldconverter for activity com.hashimo.mcpeworldconverter/.MainActivity: pid=6724 uid=10140 gids={50140,    9997, 1028, 1015, 3003} abi=armeabi-v7a
03-24 13:44:00.338: I/ActivityManager(768): Displayed com.hashimo.mcpeworldconverter/.MainActivity: +592ms

您正在声明一个线程,但您忘记了 .start() 它。所以你的代码没有执行。