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

时间:2015-03-24 17:53:58

标签: java android sockets network-programming

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

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

1 个答案:

答案 0 :(得分:2)

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