欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Android實(shí)現(xiàn)簡(jiǎn)單C/S聊天室應(yīng)用

 更新時(shí)間:2019年01月09日 15:04:23   作者:IT_xiao小巫  
這篇文章主要為大家詳細(xì)介紹了Android實(shí)現(xiàn)簡(jiǎn)單C/S聊天室應(yīng)用,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

Android的網(wǎng)絡(luò)應(yīng)用:簡(jiǎn)單的C/S聊天室,供大家參考,具體內(nèi)容如下

服務(wù)器端:提供兩個(gè)類

創(chuàng)建ServerSocket監(jiān)聽的主類:MyServer.java

負(fù)責(zé)處理每個(gè)Socket通信的線程類:ServerThread.java

客戶端:是一個(gè)Android應(yīng)用程序

==>MultiThreadClient

界面提供兩個(gè)文本框和一個(gè)發(fā)送按鈕

Activity通過Handler來處理來自子線程的消息

客戶端需要一個(gè)子線程負(fù)責(zé)讀取來自網(wǎng)絡(luò)的數(shù)據(jù)

項(xiàng)目效果:

服務(wù)器端代碼:

MyServer.java

import java.io.IOException;
import java.net.ServerSocket;
import java.net.Socket;
import java.util.ArrayList;
 
 
public class MyServer
{
 //定義保存所有Socket的ArrayList
 public static ArrayList<Socket> socketList 
 = new ArrayList<Socket>();
  public static void main(String[] args) 
 throws IOException
  {
    ServerSocket ss = new ServerSocket(8000);
 while(true)
 {
  //此行代碼會(huì)阻塞,將一直等待別人的連接
  Socket s = ss.accept();
  socketList.add(s);
  //每當(dāng)客戶端連接后啟動(dòng)一條ServerThread線程為該客戶端服務(wù)
  new Thread(new ServerThread(s)).start();
}

ServerThrad.java

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.OutputStream;
import java.net.Socket;
 
 
 
//負(fù)責(zé)處理每個(gè)線程通信的線程類
public class ServerThread implements Runnable 
{
 //定義當(dāng)前線程所處理的Socket
 Socket s = null;
 //該線程所處理的Socket所對(duì)應(yīng)的輸入流
 BufferedReader br = null;
 public ServerThread(Socket s)
 throws IOException
 {
 this.s = s;
 //初始化該Socket對(duì)應(yīng)的輸入流
 br = new BufferedReader(new InputStreamReader(
  s.getInputStream() , "utf-8"));  //②
 }
 public void run()
 {
 try
 {
  String content = null;
  //采用循環(huán)不斷從Socket中讀取客戶端發(fā)送過來的數(shù)據(jù)
  while ((content = readFromClient()) != null)
  {
  //遍歷socketList中的每個(gè)Socket,
  //將讀到的內(nèi)容向每個(gè)Socket發(fā)送一次
  for (Socket s : MyServer.socketList)
  {
   OutputStream os = s.getOutputStream();
   os.write((content + "\n").getBytes("utf-8"));
  }
  }
 }
 catch (IOException e)
 {
  e.printStackTrace();
 }
 }
 //定義讀取客戶端數(shù)據(jù)的方法
 private String readFromClient()
 {
 try
 {
  return br.readLine(); 
 }
 //如果捕捉到異常,表明該Socket對(duì)應(yīng)的客戶端已經(jīng)關(guān)閉
 catch (IOException e)
 {
  //刪除該Socket。
  MyServer.socketList.remove(s);  //①
 }
 return null;
 }
}

客戶端代碼:

布局文件:main.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
 android:orientation="vertical"
 android:layout_width="fill_parent"
 android:layout_height="fill_parent"
 >
<LinearLayout 
 android:orientation="horizontal"
 android:layout_width="fill_parent"
 android:layout_height="wrap_content"
 >
<!-- 定義一個(gè)文本框,它用于接受用戶的輸入 -->
<EditText
 android:id="@+id/input" 
 android:layout_width="240px" 
 android:layout_height="wrap_content" 
 />
<Button
 android:id="@+id/send" 
 android:layout_width="fill_parent" 
 android:layout_height="wrap_content" 
 android:paddingLeft="8px"
 android:text="@string/send"
 />
</LinearLayout>
<!-- 定義一個(gè)文本框,它用于顯示來自服務(wù)器的信息 -->
<EditText
 android:id="@+id/show" 
 android:layout_width="fill_parent" 
 android:layout_height="fill_parent" 
 android:gravity="top"
 android:editable="false" 
 android:cursorVisible="false" 
 />
</LinearLayout>

Activity文件:MultiThreadClient.java

package org.wwj.net;
 
import java.io.OutputStream;
import java.net.Socket;
 
import android.app.Activity;
import android.os.Bundle;
import android.os.Handler;
import android.os.Message;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.EditText;
 
public class MultiThreadClient extends Activity
{
 // 定義界面上的兩個(gè)文本框
 EditText input, show;
 // 定義界面上的一個(gè)按鈕
 Button send;
 OutputStream os;
 Handler handler;
 
 @Override
 public void onCreate(Bundle savedInstanceState)
 {
 super.onCreate(savedInstanceState);
 setContentView(R.layout.main);
 input = (EditText) findViewById(R.id.input);
 send = (Button) findViewById(R.id.send);
 show = (EditText) findViewById(R.id.show);
 Socket s;
 handler = new Handler()
 {
  @Override
  public void handleMessage(Message msg)
  {
  // 如果消息來自于子線程
  if (msg.what == 0x123)
  {
   // 將讀取的內(nèi)容追加顯示在文本框中
   show.append("\n" + msg.obj.toString());
  }
  }
 };
 try
 {
  s = new Socket("183.30.181.228 ", 8000);
  // 客戶端啟動(dòng)ClientThread線程不斷讀取來自服務(wù)器的數(shù)據(jù)
  new Thread(new ClientThread(s, handler)).start(); // ①
  os = s.getOutputStream();
 }
 catch (Exception e)
 {
  e.printStackTrace();
 }
 send.setOnClickListener(new OnClickListener()
 {
  @Override
  public void onClick(View v)
  {
  try
  {
   // 將用戶在文本框內(nèi)輸入的內(nèi)容寫入網(wǎng)絡(luò)
   os.write((input.getText().toString() + "\r\n")
   .getBytes("utf-8"));
   // 清空input文本框
   input.setText("");
  }
  catch (Exception e)
  {
   e.printStackTrace();
  }
  }
 });
 }
}

子線程類:ClientThread.java

package org.wwj.net;
 
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.net.Socket;
 
import android.os.Handler;
import android.os.Message;
 
public class ClientThread implements Runnable
{
 //該線程負(fù)責(zé)處理的Socket
 private Socket s;
 private Handler handler;
 //該線程所處理的Socket所對(duì)應(yīng)的輸入流
 BufferedReader br = null;
 public ClientThread(Socket s , Handler handler)
 throws IOException
 {
 this.s = s;
 this.handler = handler;
 br = new BufferedReader(
  new InputStreamReader(s.getInputStream()));
 }
 public void run()
 {
 try
 {
  String content = null;
  //不斷讀取Socket輸入流中的內(nèi)容。
  while ((content = br.readLine()) != null)
  {
  // 每當(dāng)讀到來自服務(wù)器的數(shù)據(jù)之后,發(fā)送消息通知程序界面顯示該數(shù)據(jù)
  Message msg = new Message();
  msg.what = 0x123;
  msg.obj = content;
  handler.sendMessage(msg);
  }
 }
 catch (Exception e)
 {
  e.printStackTrace();
 }
 }
}

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Android實(shí)現(xiàn)友好崩潰界面

    Android實(shí)現(xiàn)友好崩潰界面

    這篇文章主要為大家詳細(xì)介紹了Android實(shí)現(xiàn)友好崩潰界面,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-11-11
  • 解決Android 沉浸式狀態(tài)欄和華為虛擬按鍵沖突問題

    解決Android 沉浸式狀態(tài)欄和華為虛擬按鍵沖突問題

    對(duì)于現(xiàn)在的 App 來說,布局頁(yè)面基本都會(huì)用到沉浸式狀態(tài)欄,單純的沉浸式狀態(tài)欄很容易解決,但是在華為手機(jī)上存在一個(gè)底部虛擬按鍵的問題,會(huì)導(dǎo)致頁(yè)面底部和頂部出現(xiàn)很大的問題,下面通過本文給大家分享Android 沉浸式狀態(tài)欄和華為虛擬按鍵沖突問題,一起看看吧
    2017-07-07
  • Android實(shí)現(xiàn)手勢(shì)滑動(dòng)多點(diǎn)觸摸縮放平移圖片效果(二)

    Android實(shí)現(xiàn)手勢(shì)滑動(dòng)多點(diǎn)觸摸縮放平移圖片效果(二)

    這篇文章主要介紹了Android實(shí)現(xiàn)手勢(shì)滑動(dòng)多點(diǎn)觸摸縮放平移圖片效果,實(shí)現(xiàn)圖片支持多點(diǎn)觸控,自由的進(jìn)行縮放、平移的注意事項(xiàng),感興趣的小伙伴們可以參考一下
    2016-02-02
  • Android數(shù)字華容道小游戲開發(fā)

    Android數(shù)字華容道小游戲開發(fā)

    這篇文章主要為大家詳細(xì)介紹了Android數(shù)字華容道小游戲開發(fā)的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-01-01
  • Android中使用自定義ViewGroup的總結(jié)

    Android中使用自定義ViewGroup的總結(jié)

    本篇文章主要介紹了Android中使用自定義ViewGroup的總結(jié),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-01-01
  • 深入理解Android手勢(shì)識(shí)別

    深入理解Android手勢(shì)識(shí)別

    這篇文章主要幫助大家深入理解Android手勢(shì)識(shí)別,創(chuàng)建手勢(shì)偵聽對(duì)象,設(shè)置手勢(shì)識(shí)別,感興趣的小伙伴們可以參考一下
    2016-09-09
  • Android實(shí)現(xiàn)記住賬號(hào)密碼功能

    Android實(shí)現(xiàn)記住賬號(hào)密碼功能

    這篇文章主要為大家詳細(xì)介紹了Android實(shí)現(xiàn)記住賬號(hào)密碼功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-10-10
  • Android ListView中動(dòng)態(tài)添加RaidoButton的實(shí)例詳解

    Android ListView中動(dòng)態(tài)添加RaidoButton的實(shí)例詳解

    這篇文章主要介紹了Android ListView中動(dòng)態(tài)添加RaidoButton的實(shí)例詳解的相關(guān)資料,需要的朋友可以參考下
    2017-08-08
  • Android實(shí)現(xiàn)返回鍵功能

    Android實(shí)現(xiàn)返回鍵功能

    本文給大家介紹android實(shí)現(xiàn)返回鍵功能,返回鍵的操作方法,非常不錯(cuò),具有參考借鑒價(jià)值,感興趣的朋友一起學(xué)習(xí)吧
    2016-06-06
  • java實(shí)現(xiàn)靜默安裝apk

    java實(shí)現(xiàn)靜默安裝apk

    本文給大家分享的是如何實(shí)現(xiàn)偷偷的把一個(gè)安卓apk應(yīng)用安裝到手機(jī)上,而且不顯示確認(rèn)框,主要是通過反射來實(shí)現(xiàn),好了,小伙伴們仔細(xì)看下代碼吧,有需要的小伙伴可以參考下。
    2015-04-04

最新評(píng)論