首页 > 代码库 > Android 使用Socket进行通信

Android 使用Socket进行通信

作者 : 卿笃军

原文地址:http://blog.csdn.net/qingdujun/article/details/39274055


客户端通常可以使用Socket的构造器来链接到指定的服务器。

下面演示一下,Android端链接到服务器,同时,用服务器给Android发送一条消息:

1)服务器端

2)Android端


1)服务器端

编写过程中遇到的一个小问题:java.net.BindException: Address already in use: JVM_Bind,分析出现这个问题的原因,一般有如下几种:

①)原因:端口已被占用。  

解决方案:换一个端口。

②)原因:变量定义位置问题(我不知道是不是这个问题,可能是,我开始出现这个问题的时候,换了几个端口还是没解决,后来我将变量定义在外面,就解决了)

解决方案:将变量定义在外部。


package dujun.king.javaee;

import java.io.OutputStream;
import java.net.ServerSocket;
import java.net.Socket;

public class CServer {
	public static void main(String[] args){	
		//创建一个ServerSocket,用于监听客户端Socket的链接请求
		//本机IP: 169.254.49.31
		ServerSocket ss=null;
		Socket s = null;
		OutputStream os = null;
		//采用循环不断的接受来自客户端的请求
		while (true)
		{
			try {
				System.out.println("等待客户端的链接....");
				ss = new ServerSocket(9527);
				//每当接收到客户端Socket的请求,服务器也对应产生一个Socket
				s = ss.accept();
				System.out.println("客户端已链接....");
				os = s.getOutputStream();
				os.write("您好,收到一条信息!".getBytes("utf-8"));
				//关闭输出流,关闭Socket
				os.close();
				s.close();
				ss.close();
			} catch (Exception e) {
				e.printStackTrace();
			}
		}
	}
}
2)Android端

编写过程中遇到的一个小问题,就是(我用真机)一直连接不上服务器,我当时以为不是ip地址的问题,我先后换了好几个都没用(包括我联网后的ip  113.132.174.158,没联网时的ip 169.254.49.31)。

解决方案:添加一个模拟器,不用真机模拟。(使用:169.254.49.31 测试成功,如下图)


a)  xml布局代码:

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:paddingBottom="@dimen/activity_vertical_margin"
    android:paddingLeft="@dimen/activity_horizontal_margin"
    android:paddingRight="@dimen/activity_horizontal_margin"
    android:paddingTop="@dimen/activity_vertical_margin"
    tools:context="client.dujun.king.tcp.MainActivity" >

    <EditText
        android:id="@+id/show"
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:hint="" />

</RelativeLayout>
b)MainActivity.java代码:

package client.dujun.king.tcp;

import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.net.Socket;

import android.app.Activity;
import android.os.Bundle;
import android.view.Menu;
import android.view.MenuItem;
import android.widget.EditText;


public class MainActivity extends Activity {

	EditText show;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        show = (EditText)findViewById(R.id.show);
        new Thread()
        {
        	@Override
        	public void run()
        	{
        		try {
					//建立连接到远程服务器的Socket
        			Socket socket = new Socket("169.254.49.31",9527);
        			//将Socket对应的输入流包装成BufferedReader
        			BufferedReader br = new BufferedReader(new InputStreamReader(socket.getInputStream()));
        			//进行普通的I/O操作
        			String line = br.readLine();
        			show.setText("来自服务器的数据:"+line);
        			br.close();
        			socket.close();
				} catch (Exception e) {
					e.printStackTrace();
				}
        	}
        }.start();
    }


    @Override
    public boolean onCreateOptionsMenu(Menu menu) {
        // Inflate the menu; this adds items to the action bar if it is present.
        getMenuInflater().inflate(R.menu.main, menu);
        return true;
    }

    @Override
    public boolean onOptionsItemSelected(MenuItem item) {
        // Handle action bar item clicks here. The action bar will
        // automatically handle clicks on the Home/Up button, so long
        // as you specify a parent activity in AndroidManifest.xml.
        int id = item.getItemId();
        if (id == R.id.action_settings) {
            return true;
        }
        return super.onOptionsItemSelected(item);
    }
}
c) AndroidMainiFest.xml 权限设置代码:

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="client.dujun.king.tcp"
    android:versionCode="1"
    android:versionName="1.0" >

    <uses-sdk
        android:minSdkVersion="15"
        android:targetSdkVersion="15" />
	<!-- 访问Internet权限 -->
	<uses-permission android:name="android.permission.INTERNET"/>
	
    <application
        android:allowBackup="true"
        android:icon="@drawable/ic_launcher"
        android:label="@string/app_name"
        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讲义(第2版) 李刚 编著

原文地址:http://blog.csdn.net/qingdujun/article/details/39274055

Android 使用Socket进行通信