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