android TCP 客戶端(僅接收數據)


配合log4net使用,用來接收調試信息。因此,此客戶端只管通過TCP接收字符串數據,然后顯示在界面上。

接收TCP數據

try {
	Socket s = new Socket("192.168.1.5", 8240);
	InputStream inputStream = s.getInputStream();
	DataInputStream input = new DataInputStream(inputStream);
	byte[] b = new byte[10000];
	while(true)
	{
		int length = input.read(b);
		String Msg = new String(b, 0, length, "gb2312");
		Log.v("data",Msg);
	}
}catch(Exception ex)
{
	ex.printStackTrace();
}

開線程執行接收操作  

 但是,如果接收代碼直接放UI按鈕處理事件中,將直接引發NetworkOnMainThreadException,這是因為不能在主線程中執行Socket操作。這里使用AsyncTask開另一個線程執行socket操作。

// Activity按鈕事件中
GetLogTask task = new GetLogTask();
task.execute(null);
// Activity類中嵌套類
public class GetLogTask extends AsyncTask<Void,Void,String>
{
	@Override
	protected String doInBackground(Void...param){
    		try {
			Socket s = new Socket("192.168.1.5", 8240);
			InputStream inputStream = s.getInputStream();
			DataInputStream input = new DataInputStream(inputStream);
			byte[] b = new byte[10000];
			while(true)
			{
				int length = input.read(b);
				String Msg = new String(b, 0, length, "gb2312");
				Log.v("data",Msg);
			}
			
		}catch(Exception ex)
		{
			ex.printStackTrace();
		}
		return "";
	}
}

  AsyncTask與界面線程通信

1、界面需要啟動和暫停TCP接收操作。
界面線程使用AsyncTask.cancel()通知接收線程結束接收操作。
接收線程在doInBackground中調用isCancelled()來檢查是否出現結束接收要求。

 

2、AsyncTask接收到數據之后,傳遞給界面顯示。

接收線程使用Handler將數據傳遞給界面
使用Handler的話,數據作為“消息”傳遞給界面處理。
Handler包括了處理消息功能和發布消息功能。在這里,處理消息就是在界面上顯示log文本,界面線程來干。發布消息就是將log文本作為參數,調用postmessage功能,接收線程來干。

主線程中的處理消息

    Handler handler = new Handler(){
    	@Override
    	public void handleMessage(Message msg){
    		text.setText(text.getText().toString()+(String)msg.obj);
    	}
    };

接收線程中的發布消息

Message msg = new Message();
msg.obj = msgstring;
(MainActivity.this).handler.postMessage();

以上就構成了一個簡單,但可用的TCP方式的log接收端。拿個360wifi或者小米wifi,就可以使用手機接收pc應用程序發出來的log了。

很久沒有登陸自己的賬號了,還好自己的賬號還在,慶幸之余,發一篇今天的隨筆,感謝園子一直保留着這份記憶。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM