Android客户端和服务器端编程

时间:2013-08-07 20:13:23

标签: android sockets android-networking

我正在尝试运行我在网上找到的服务器端和客户端示例。 这是服务器:

public class ServerActivity extends Activity {  

    private TextView serverStatus;  
    private TextView serverStatus2;  

    // DEFAULT IP  
    public static String SERVERIP = "10.100.102.15";  

    // DESIGNATE A PORT  
    public static final int SERVERPORT = 8080;  

    private Handler handler = new Handler();  

    private ServerSocket serverSocket;  

    @Override  
    protected void onCreate(Bundle savedInstanceState) {  
        super.onCreate(savedInstanceState);  
        setContentView(R.layout.activity_server);  
        serverStatus = (TextView) findViewById(R.id.server_status);  
        serverStatus2 = (TextView) findViewById(R.id.server_status2);  

        SERVERIP = getLocalIpAddress();  

        Thread fst = new Thread(new ServerThread());  
        fst.start();  
    }  

    public class ServerThread implements Runnable {  

        public void run() {  
            try {  
                if (SERVERIP != null) {  
                    handler.post(new Runnable() {  
                        @Override  
                        public void run() {  
                            serverStatus  
                                    .setText("Listening on IP: " + SERVERIP);  
                        }  
                    });  
                    serverSocket = new ServerSocket(SERVERPORT);  
                    while (true) {  
                        // LISTEN FOR INCOMING CLIENTS  
                        Socket client = serverSocket.accept();  
                        handler.post(new Runnable() {  
                            @Override  
                            public void run() {  
                                serverStatus2.setText("Connected.");  
                            }  
                        });  

                        try {  
                            BufferedReader in = new BufferedReader(  
                                    new InputStreamReader(  
                                            client.getInputStream()));  
                            String line = null;  
                            while ((line = in.readLine()) != null) {  
                                Log.d("ServerActivity", line);  
                                handler.post(new Runnable() {  
                                    @Override  
                                    public void run() {  
                                        // DO WHATEVER YOU WANT TO THE FRONT END  
                                        // THIS IS WHERE YOU CAN BE CREATIVE  
                                    }  
                                });  
                            }  
                            break;  
                        } catch (Exception e) {  
                            handler.post(new Runnable() {  
                                @Override  
                                public void run() {  
                                    serverStatus  
                                            .setText("Oops. Connection interrupted. Please reconnect your phones.");  
                                }  
                            });  
                            e.printStackTrace();  
                        }  
                    }  
                } else {  
                    handler.post(new Runnable() {  
                        @Override  
                        public void run() {  
                            serverStatus  
                                    .setText("Couldn't detect internet connection.");  
                        }  
                    });  
                }  
            } catch (final Exception e) {  
                handler.post(new Runnable() {  
                    @Override  
                    public void run() {  
                        serverStatus.setText("Error" + e.getMessage());  
                    }  
                });  
                e.printStackTrace();  
            }  
        }  
    }  

    // GETS THE IP ADDRESS OF YOUR PHONE'S NETWORK  
    private String getLocalIpAddress() {  
        try {  
            for (Enumeration<NetworkInterface> en = NetworkInterface  
                    .getNetworkInterfaces(); en.hasMoreElements();) {  
                NetworkInterface intf = en.nextElement();  
                for (Enumeration<InetAddress> enumIpAddr = intf  
                        .getInetAddresses(); enumIpAddr.hasMoreElements();) {  
                    InetAddress inetAddress = enumIpAddr.nextElement();  
                    if (!inetAddress.isLoopbackAddress()) {  
                        return inetAddress.getHostAddress().toString();  
                    }  
                }  
            }  
        } catch (SocketException ex) {  
            Log.e("ServerActivity", ex.toString());  
        }  
        return null;  
    }  

    @Override  
    protected void onStop() {  
        super.onStop();  
        try {  
            // MAKE SURE YOU CLOSE THE SOCKET UPON EXITING  
            serverSocket.close();  
        } catch (IOException e) {  
            e.printStackTrace();  
        }  
    }  

}

这是客户的代码:

public class ClientActivity extends Activity {  

        private EditText serverIp;  

        private Button connectPhones;  

        private String serverIpAddress = "";  

        private boolean connected = false;  

        //private Handler handler = new Handler();  

        @Override  
        protected void onCreate(Bundle savedInstanceState) {  
            super.onCreate(savedInstanceState);  
            setContentView(R.layout.activity_client);  

            serverIp = (EditText) findViewById(R.id.server_ip);  
            connectPhones = (Button) findViewById(R.id.connect_phones);  
            connectPhones.setOnClickListener(connectListener);  
        }  

        private OnClickListener connectListener = new OnClickListener() {  

            @Override  
            public void onClick(View v) {  
                if (!connected) {  
                    serverIpserverIpAddress = serverIp.getText().toString();  
                    if (!serverIpAddress.equals("")) {  
                        Thread cThread = new Thread(new ClientThread());  
                        cThread.start();  
                    }  
                }  
            }  
        };  

        public class ClientThread implements Runnable {  

            public void run() {  
                try {  
                    InetAddress serverAddr = InetAddress.getByName(serverIpAddress);  
                    Log.d("ClientActivity", "C: Connecting...");  
                    Socket socket = new Socket(serverAddr,  
                            8080);  
                    connected = true;  
                    while (connected) {  
                        try {  
                            Log.d("ClientActivity", "C: Sending command.");  
                            PrintWriter out = new PrintWriter(  
                                    new BufferedWriter(new OutputStreamWriter(  
                                            socket.getOutputStream())), true);  
                            // WHERE YOU ISSUE THE COMMANDS  
                            out.println("Hey Server!");  
                            Log.d("ClientActivity", "C: Sent.");  
                        } catch (Exception e) {  
                            Log.e("ClientActivity", "S: Error", e);  
                        }  
                    }  
                    socket.close();  
                    Log.d("ClientActivity", "C: Closed.");  
                } catch (Exception e) {  
                    Log.e("ClientActivity", "C: Error", e);  
                    connected = false;  
                }  
            }  
        }  
    }

当在同一个eclipse仿真器上运行上面的命令时,服务器抛出异常“Socket Closed”,甚至没有达到while循环“while(true)”。有人知道为什么吗?

这是控制台的输出:

Android Launch!
adb is running normally.
Performing com.example.server.ServerActivity activity launch
Automatic Target Mode: using existing emulator 'emulator-5554' running compatible AVD 'android2.3'
Uploading server.apk onto device 'emulator-5554'
Installing server.apk...
Success!
Starting activity com.example.server.ServerActivity on device emulator-5554
ActivityManager: Starting: Intent { act=android.intent.action.MAIN cat=[android.intent.category.LAUNCHER] cmp=com.example.server/.ServerActivity }
------------------------------
Android Launch!
adb is running normally.
Performing com.example.client.ClientActivity activity launch
Automatic Target Mode: using existing emulator 'emulator-5554' running compatible AVD 'android2.3'
Application already deployed. No need to reinstall.
Starting activity com.example.client.ClientActivity on device emulator-5554
ActivityManager: Starting: Intent { act=android.intent.action.MAIN cat=[android.intent.category.LAUNCHER] cmp=com.example.client/.ClientActivity }

这是LogCat输出:

08-08 13:04:38.165: D/ClientActivity(360): C: Connecting...
08-08 13:04:38.176: E/ClientActivity(360): C: Error
08-08 13:04:38.176: E/ClientActivity(360): java.net.ConnectException: /10.0.2.15:50907 - Connection refused
08-08 13:04:38.176: E/ClientActivity(360):  at org.apache.harmony.luni.net.PlainSocketImpl.connect(PlainSocketImpl.java:207)
08-08 13:04:38.176: E/ClientActivity(360):  at org.apache.harmony.luni.net.PlainSocketImpl.connect(PlainSocketImpl.java:183)
08-08 13:04:38.176: E/ClientActivity(360):  at java.net.Socket.startupSocket(Socket.java:705)
08-08 13:04:38.176: E/ClientActivity(360):  at java.net.Socket.<init>(Socket.java:263)
08-08 13:04:38.176: E/ClientActivity(360):  at com.example.client.ClientActivity$ClientThread.run(ClientActivity.java:58)
08-08 13:04:38.176: E/ClientActivity(360):  at java.lang.Thread.run(Thread.java:1019)
08-08 13:04:40.456: W/IInputConnectionWrapper(360): showStatusIcon on inactive > > > InputConnection

2 个答案:

答案 0 :(得分:4)

解决了IT问题,http://developer.android.com/tools/devices/emulator.html 问题是默认的android模拟器实例只能与自身和以太网交互,因此不同的实例无法相互联网。
如果要这样做,首先必须在实例中设置重定向 阅读本页它有助于...很多:D

答案 1 :(得分:1)

这有两点:

  • 如果您在模拟器上运行应用程序,请使用IP地址作为您的机器IP地址,不要选择自己为“10.100.102.15”。
  • 关于端口,请选择50907之类的其他端口或类似的东西(远离像8080这样的KNOWN-PORT,通常作为INTERNET端口使用)。

再试一次,希望这有帮助。