日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 >

C#完整的通信代码(点对点,点对多,同步,异步,UDP,TCP)

發布時間:2023/12/18 45 豆豆
生活随笔 收集整理的這篇文章主要介紹了 C#完整的通信代码(点对点,点对多,同步,异步,UDP,TCP) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

C# code

namespace UDPServer

{

??? class Program

??? {

??????? static void Main(string[] args)

??????? {

??????????? int recv;

??????????? byte[] data = new byte[1024];

??????????? //構建TCP 服務器

??????????? //得到本機IP,設置TCP端口號?????????

??????????? IPEndPoint ipep = new IPEndPoint(IPAddress.Any , 8001);

??????????? Socket newsock = new Socket(AddressFamily.InterNetwork, SocketType.Dgram , ProtocolType.Udp);

??????????? //綁定網絡地址

??????????? newsock.Bind(ipep);

??????????? Console.WriteLine("This is a Server, host name is {0}",Dns.GetHostName());

??????????? //等待客戶機連接

??????????? Console.WriteLine("Waiting for a client...");

??????????? //得到客戶機IP

??????????? IPEndPoint sender = new IPEndPoint(IPAddress.Any, 0);

??????????? EndPoint Remote = (EndPoint)(sender);

??????????? recv = newsock.ReceiveFrom(data, ref Remote);

??????????? Console .WriteLine ("Message received from {0}: ", Remote.ToString ());

??????????? Console .WriteLine (Encoding .ASCII .GetString (data ,0,recv ));

??????????? //客戶機連接成功后,發送歡迎信息

??????????? string welcome = "Welcome ! ";

??????????? //字符串與字節數組相互轉換

??????????? data? = Encoding .ASCII .GetBytes (welcome );

??????????? //發送信息

??????????? newsock .SendTo (data ,data.Length ,SocketFlags .None ,Remote );

??????????? while (true )

??????????? {

??????????????? data =new byte [1024];

??????????????? //發送接受信息

??????????????? recv =newsock.ReceiveFrom(data ,ref Remote);

??????????????? Console .WriteLine (Encoding .ASCII .GetString (data ,0,recv));

??????????????? newsock .SendTo (data ,recv ,SocketFlags .None ,Remote );

??????????? }

??????? }

??????? }

??? }

C# code
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Net;
using System.Net.Sockets;
namespace UDPClient
{
??? class Program
??? {
??????? static void Main(string[] args)
??????? {
??????????? byte[] data = new byte[1024];
??????????? string input ,stringData;
??????????? //構建TCP 服務器
??????????? Console.WriteLine("This is a Client, host name is {0}", Dns.GetHostName());
??????????? //設置服務IP,設置TCP端口號
??????????? IPEndPoint ipep = new IPEndPoint(IPAddress .Parse ("127.0.0.1") , 8001);
??????????? //定義網絡類型,數據連接類型和網絡協議UDP
??????????? Socket server = new Socket(AddressFamily.InterNetwork, SocketType.Dgram, ProtocolType.Udp);
??????????? string welcome = "Hello! ";
??????????? data = Encoding.ASCII.GetBytes(welcome);
??????????? server.SendTo(data, data.Length, SocketFlags.None, ipep);
??????????? IPEndPoint sender = new IPEndPoint(IPAddress.Any, 0);
??????????? EndPoint Remote = (EndPoint)sender;
??????????? data = new byte[1024];
??????????? int recv = server.ReceiveFrom(data, ref Remote);
??????????? Console.WriteLine("Message received from {0}: ", Remote.ToString());
??????????? Console.WriteLine(Encoding .ASCII .GetString (data,0,recv));
??????????? while (true)
??????????? {
??????????????? input = Console .ReadLine ();
??????????????? if (input =="exit")
??????????????????? break ;
??????????????? server .SendTo (Encoding .ASCII .GetBytes (input ),Remote );
??????????????? data = new byte [1024];
??????????????? recv = server.ReceiveFrom(data, ref Remote);
??????????????? stringData = Encoding.ASCII.GetString(data, 0, recv);
??????????????? Console.WriteLine(stringData);
??????????? }
??????????? Console .WriteLine ("Stopping Client.");
??????????? server .Close ();????????????
??????? }
??????? }
??? }

C# code
TCPClient
TCPClient 類提供了一種使用 TCP 協議連接到某個端點的簡化方法。它還通過 NetworkStream 對象展現在連接過程中讀取或寫入的數據。請參見下面從 QuickStart 文檔中摘錄的日期/時間客戶機示例。
使用 C# 編寫
using System;
using System.Net;
using System.Net.Sockets;
using System.IO;
using System.Text;
class Client
{
public static void Main(String[] args)
{
TCPClient tcpc = new TCPClient();
Byte[] read = new Byte[32];
if (args.Length != 1)
{
Console.WriteLine(“請在命令行中指定服務器名稱”);
return;
}
String server = args[0];
// 驗證服務器是否存在
if (DNS.GetHostByName(server) == null)
{
Console.WriteLine(“找不到服務器:” + 服務器);
return;
}
// 嘗試連接到服務器
if (tcpc.Connect(server, 13) == -1)
{
Console.WriteLine(“無法連接到服務器:” + 服務器);
return;
}
// 獲取流
Stream s = tcpc.GetStream();
// 讀取流并將它轉換為 ASCII 碼形式
int bytes = s.Read(read, 0, read.Length);
String Time = Encoding.ASCII.GetString(read);
// 顯示數據
Console.WriteLine(“已接收到的” + 字節 + “字節”);
Console.WriteLine(“當前日期和時間是:” + 時間);
tcpc.Close();
}
}
TCPListener
TCPListener 類便于在來自某個客戶機的 TCP 連接的特定套接字上進行偵聽的工作。請參見下面包括在 QuickStart 文檔中的日期/時間服務器示例。
使用 C# 編寫
using System;
using System.Net;
using System.Net.Sockets;
using System.Text;
class Server
{
public static void Main()
{
DateTime now;
String strDateLine;
Encoding ASCII = Encoding.ASCII;
// 在端口 13 進行偵聽
TCPListener tcpl = new TCPListener(13);
tcpl.Start();
Console.WriteLine(“正在等待客戶進行連接”);
Console.WriteLine(“請按 Ctrl+c 退出...”);
while (true)
{
// 接收會阻塞,直到有人連接上
Socket s = tcpl.Accept();
// 獲取當前的日期和時間并將它連接成一個字符串
now = DateTime.Now;
strDateLine = now.ToShortDateString() + " " +
now.ToLongTimeString();
// 將該字符串轉換成一個字節數組并發送它
Byte[] byteDateLine =
ASCII.GetBytes(strDateLine.ToCharArray());
s.Send(byteDateLine, byteDateLine.Length, 0);
Console.WriteLine(“發送” + strDateLine);
}
}
}

#region "Download: File transfer FROM ftp server"?
??????? /// <summary>?
??????? /// Copy a file from FTP server to local?
??????? /// </summary>?
??????? /// <param name="sourceFilename">Target filename, if required </param>?
??????? /// <param name="localFilename">Full path of the local file </param>?
??????? /// <returns> </returns>?
??????? /// <remarks>Target can be blank (use same filename), or just a filename?
??????? /// (assumes current directory) or a full path and filename </remarks>?
??????? public bool Download(string sourceFilename, string localFilename, bool PermitOverwrite)?
??????? {?
??????????? //2. determine target file?
??????????? FileInfo fi = new FileInfo(localFilename);?
??????????? return this.Download(sourceFilename, fi, PermitOverwrite);?
??????? }?
??????? //Version taking an FtpFileInfo?
??????? public bool Download(FtpFileInfo file, string localFilename, bool permitOverwrite)?
??????? {?
??????????? return this.Download(file.FullName, localFilename, permitOverwrite);?
??????? }?
??????? //Another version taking FtpFileInfo and FileInfo?
??????? public bool Download(FtpFileInfo file, FileInfo localFI, bool permitOverwrite)?
??????? {?
??????????? return this.Download(file.FullName, localFI, permitOverwrite);?
??????? }?
??????? //Version taking string/FileInfo?
??????? public bool Download(string sourceFilename, FileInfo targetFI, bool permitOverwrite)?
??????? {?
??????????? //1. check target?
??????????? if (targetFI.Exists && !(permitOverwrite))?
??????????? {?
??????????????? throw (new ApplicationException("Target file already exists"));?
??????????? }?
??????????? //2. check source?
??????????? string target;?
??????????? if (sourceFilename.Trim() == "")?
??????????? {?
??????????????? throw (new ApplicationException("File not specified"));?
??????????? }?
??????????? else if (sourceFilename.Contains("/"))?
??????????? {?
??????????????? //treat as a full path?
??????????????? target = AdjustDir(sourceFilename);?
??????????? }?
??????????? else?
??????????? {?
??????????????? //treat as filename only, use current directory?
??????????????? target = CurrentDirectory + sourceFilename;?
??????????? }?
??????????? string URI = Hostname + target;?
??????????? //3. perform copy?
??????????? System.Net.FtpWebRequest ftp = GetRequest(URI);?
??????????? //Set request to download a file in binary mode?
??????????? ftp.Method = System.Net.WebRequestMethods.Ftp.DownloadFile;?
??????????? ftp.UseBinary = true;?
??????????? //open request and get response stream?
??????????? using (FtpWebResponse response = (FtpWebResponse)ftp.GetResponse())?
??????????? {?
??????????????? using (Stream responseStream = response.GetResponseStream())?
??????????????? {?
??????????????????? //loop to read & write to file?
??????????????????? using (FileStream fs = targetFI.OpenWrite())?
??????????????????? {?
??????????????????????? try?
??????????????????????? {?
??????????????????????????? byte[] buffer = new byte[2048];?
??????????????????????????? int read = 0;?
??????????????????????????? do?
??????????????????????????? {?
??????????????????????????????? read = responseStream.Read(buffer, 0, buffer.Length);?
??????????????????????????????? fs.Write(buffer, 0, read);?
??????????????????????????? } while (!(read == 0));?
??????????????????????????? responseStream.Close();?
??????????????????????????? fs.Flush();?
??????????????????????????? fs.Close();?
??????????????????????? }?
??????????????????????? catch (Exception)?
??????????????????????? {?
??????????????????????????? //catch error and delete file only partially downloaded?
??????????????????????????? fs.Close();?
??????????????????????????? //delete target file as it's incomplete?
??????????????????????????? targetFI.Delete();?
??????????????????????????? throw;?
??????????????????????? }?
??????????????????? }?
??????????????????? responseStream.Close();?
??????????????? }?
??????????????? response.Close();?
??????????? }?
??????????? return true;?
??????? }?
??????? #endregion

簡單的UDP收發.?
發送?
C# code
??????????????????? try
??????????????????? {
??????????????????????? Socket s = new Socket(AddressFamily.InterNetwork, SocketType.Dgram, ProtocolType.Udp);? //向此網段發廣播包
????????????????????????? int UDPListenerPort = 8082;
??????????????????????? IPAddress broadcast = IPAddress.Parse("192.168.0.255"); //此處根據IP及子網掩碼改為相應的廣播IP
??????????????????????? string ts = "This is UPD string for sending";
??????????????????????? byte[] sendbuf = Encoding.ASCII.GetBytes(ts);
??????????????????????? IPEndPoint ep = new IPEndPoint(broadcast, UDPListenerPort);
??????????????????????? s.SendTo(sendbuf, ep);
??????????????????? }
??????????????????? catch (Exception e)
??????????????????? {}
接收?
C# code
?????????? UdpClient listener;
??????????? int UDPListenerPort = 8082;
??????????? IPEndPoint groupEP = new IPEndPoint(IPAddress.Any, UDPListenerPort);
??????????? try
??????????? {
??????????????? while (true)
??????????????? {
??????????????????? byte[] bytes = listener.Receive(ref groupEP);
??????????????????? string RecIP = groupEP.ToString().Substring(0, groupEP.ToString().IndexOf(":"));? //收到發送UPD端的IP
??????????????????? string RecStr = Encoding.ASCII.GetString(bytes, 0, bytes.Length);?? //收到的UPD字符串
??????????????? }
??????????? }
??????????? catch
??????????? {}

C# code?
TCPClient?
TCPClient 類提供了一種使用 TCP 協議連接到某個端點的簡化方法。它還通過 NetworkStream 對象展現在連接過程中讀取或寫入的數據。請參見下面從 QuickStart 文檔中摘錄的日期/時間客戶機示例。?
使用 C# 編寫?
using System;?
using System.Net;?
using System.Net.Sockets;?
using System.IO;?
using System.Text;?
class Client?
{?
public static void Main(String[] args)?
{?
TCPClient tcpc = new T…

來一個Remoting的:?
C# code
using System;?
namespace Remotable?
{?
??? public class RemotableType : MarshalByRefObject?
??? {?
??????? private string _internalString = "This is the RemotableType.";?
??????? public string StringMethod()?
??????? {?
??????????? return _internalString;?
??????? }?
??? }?
}?
using System;?
using System.Runtime.Remoting;?
namespace RemotingFirst?
{?
??? public class Listener?
??? {?
??????? public static void Main()?
??????? {?
??????????? RemotingConfiguration.Configure("Listener.exe.config");?
??????????? Console.WriteLine("Listening for requests. Press Enter to exit");?
??????????? Console.ReadLine();?
??????? }?
??? }?
}?
using System;?
using System.Runtime.Remoting;?
namespace Client?
{?
??? public class Client?
??? {?
??????? public static void Main()?
??????? {?
??????????? RemotingConfiguration.Configure("Client.exe.config");?
??????????? Remotable.RemotableType remoteObject = new Remotable.RemotableType();?
??????????? Console.WriteLine(remoteObject.StringMethod());?
??????? }?
??? }?
}?
Listener.exe.config?
<?xml version="1.0" encoding="utf-8" ?>?
<configuration>?
??? <system.runtime.remoting>?
????? <application>?
???????? <service>?
??????????? <wellknown??
?????????????? mode="Singleton"??
?????????????? type="Remotable.RemotableType, RemotableType"??
?????????????? objectUri="RemotableType.rem"?
??????????? />?
???????? </service>?
???????? <channels>?
??????????? <channel ref="http" port="8989"/>?
???????? </channels>?
????? </application>?
??? </system.runtime.remoting>?
</configuration>

實只要用到Socket聯接,基本上就得使用Thread,是交叉使用的。?
C#封裝的Socket用法基本上不算很復雜,只是不知道托管之后的Socket有沒有其他性能或者安全上的問題。?
在C#里面能找到的最底層的操作也就是socket了,概念不做解釋。?
程序模型如下:?
WinForm程序 : 啟動端口偵聽;監視Socket聯接情況;定期關閉不活動的聯接;?
Listener:處理Socket的Accept函數,偵聽新鏈接,建立新Thread來處理這些聯接(Connection)。?
Connection:處理具體的每一個聯接的會話。?
1:WinForm如何啟動一個新的線程來啟動Listener:?
????? //start the server?
??????? private void btn_startServer_Click(object sender, EventArgs e)?
??????? {?
??????????? //this.btn_startServer.Enabled = false;?
??????????? Thread _createServer = new Thread(new ThreadStart(WaitForConnect));?
??????????? _createServer.Start();?
??????? }?
??????? //wait all connections?
??????? private void WaitForConnect()?
??????? {?
??????????? SocketListener listener = new SocketListener(Convert.ToInt32(this.txt_port.Text));?
??????????? listener.StartListening();?
??????? }?
因為偵聽聯接是一個循環等待的函數,所以不可能在WinForm的線程里面直接執行,不然Winform也就是無法繼續任何操作了,所以才指定一個新的線程來執行這個函數,啟動偵聽循環。?
這一個新的線程是比較簡單的,基本上沒有啟動的參數,直接指定處理函數就可以了。?
2:Listener如何啟動循環偵聽,并且啟動新的帶有參數的線程來處理Socket聯接會話。?
先看如何建立偵聽:(StartListening函數)?
IPEndPoint localEndPoint = new IPEndPoint(_ipAddress, _port);?
??????? // Create a TCP/IP socket.?
??????? Socket listener = new Socket(AddressFamily.InterNetwork, SocketType.Stream, ProtocolType.Tcp);?
??????????? // Bind the socket to the local endpoint and? listen for incoming connections.?
??????????? try?
??????????? {?
??????????????? listener.Bind(localEndPoint);?
??????????????? listener.Listen(20);//20 trucks?
??????????????? // Start listening for connections.?
??????????????? while (true)?
??????????????? {?
????????????????? // here will be suspended while waiting for a new connection.?
??????????????????? Socket connection = listener.Accept();?
??????????????????? Logger.Log("Connect", connection.RemoteEndPoint.ToString());//log it, new connection?
??????????????? ……?
????????? }?
??????? }……?
基本步驟比較簡單:?
建立本機的IPEndPoint對象,表示以本機為服務器,在指定端口偵聽;?
然后綁定到一個偵聽Socket上;?
進入while循環,等待新的聯接;?
如果有新的聯接,那么建立新的socket來對應這個聯接的會話。?
? 值得注意的就是這一句聯接代碼:listener.Accept()。執行這一句的時候,程序就在這個地方等待,直到有新的聯檢請求的時候程序才會執行下一句。這是同步執行,當然也可以異步執行。?
? 新的聯接Socket建立了(Accept之后),對于這些新的socket該怎么辦呢?他們依然是一個循環等待,所以依然需要建立新的Thread給這些Socket去處理會話(接收/發送消息),而這個Thread就要接收參數了。?
? Thread本身是不能接收參數的,為了讓它可以接收參數,可以采用定義新類,添加參數作為屬性的方法來解決。?
? 因為每一個Socket是一個Connection周期,所以我定義了這么一個類public class Connection。這個類至少有這樣一個構造函數public Connection(Socket socket); 之所以這么做,就是為了把Socket參數傳給這個Connection對象,然后好讓Listener啟動這個Thread的時候,Thread可以知道他正在處理哪一個Socket。?
??? 具體處理的方法:(在Listener的StartListening函數,ocket connection = listener.Accept();之后)?
??? Connection gpsCn = new Connection(connection);?
??????????????????? //each socket will be wait for data. keep the connection.?
??????????????????? Thread thread = new Thread(new ThreadStart(gpsCn.WaitForSendData));?
??????????????????? thread.Name = connection.RemoteEndPoint.ToString();?
??????????????????? thread.Start();?
如此一來,這個新的socket在Accept之后就在新的Thread中運行了。?
? 3:Connection的會話處理?
? 建立了新的Connection(也就是socket),遠程就可以和這個socket進行會話了,無非就是send和receive。?
? 現在先看看怎么寫的這個線程運行的Connection. WaitForSendData函數?
??? while (true)?
??????????? {?
??????????????? bytes = new byte[1024];?
??????????????? string data = "";?
??????????????? //systm will be waiting the msg of receive envet. like Accept();?
??????????????? //here will be suspended while waiting for socket income msg.?
??????????????? int bytesRec = this._connection.Receive(bytes);?
??????????????? _lastConnectTime = DateTime.Now;?
??????????????? if (bytesRec == 0)//close envent?
??????????????? {?
??????????????????? Logger.Log("Close Connection", _connection.RemoteEndPoint.ToString());?
??????????????????? break;?
??????????????? }?
??????????????? data += Encoding.ASCII.GetString(bytes, 0, bytesRec);?
??????????????? //…….handle your data.?
??????????? }?
可以看到這個處理的基本步驟如下:?
? 執行Receive函數,接收遠程socket發送的信息;?
? 把信息從字節轉換到string;?
? 處理該信息,然后進入下一個循環,繼續等待socket發送新的信息。?
值得注意的有幾個:?
? 1:Receive函數。這個函數和Listener的Accept函數類似。在這個地方等待執行,如果沒有新的消息,這個函數就不會執行下一句,一直等待。?
? 2:接收的是字節流,需要轉化成字符串?
? 3:判斷遠程關閉聯接的方式?
? 4:如果對方的消息非常大,還得循環接收這個data。?
4:如何管理這些聯接(thread)?
通過上邊的程序,基本上可以建立一個偵聽,并且處理聯接會話。但是如何管理這些thread呢?不然大量產生thread可是一個災難。?
管理的方法比較簡單,在Listener里面我定義了一個靜態的哈希表(static public Hashtable Connections=new Hashtable();),存儲Connection實例和它對應的Thread實例。而connection中也加入了一個最后聯接時間的定義(private DateTime _lastConnectTime;)。在新鏈接建立的時候(Listener的Accept()之后)就把Connection實例和Thread實例存到哈希表中;在Connection的Receive的時候修改最后聯接時間。這樣我們就可以知道該Connection在哪里,并且會話是否活躍。?
然后在Winform程序里頭可以管理這些會話了,設置設置超時。

在網絡環境下,我們最感興趣的兩個命名空間是System.Net和 System.Net.Sockets。System.Net命名空間通常與較高程的操作有關,例如download或upload,試用HTTP和其他協議進行Web請求等等,而System.Net.Sockets命名空間所包含的類通常與較低程的操作有關。如果要直接使用Sockets或者 TCP/IP之類的協議,這個命名空間的類是非常有用的。?
  在.Net中,System.Net.Sockets 命名空間為需要嚴密控制網絡訪問的開發人員提供了 Windows Sockets (Winsock) 接口的托管實現。System.Net 命名空間中的所有其他網絡訪問類都建立在該套接字Socket實現之上,如TCPClient、TCPListener 和 UDPClient 類封裝有關創建到 Internet 的 TCP 和 UDP 連接的詳細信息;NetworkStream類則提供用于網絡訪問的基礎數據流等,常見的許多Internet服務都可以見到Socket的蹤影,如 Telnet、Http、Email、Echo等,這些服務盡管通訊協議Protocol的定義不同,但是其基礎的傳輸都是采用的Socket。?
  其實,Socket可以象流Stream一樣被視為一個數據通道,這個通道架設在應用程序端(客戶端)和遠程服務器端之間,而后,數據的讀取(接收)和寫入(發送)均針對這個通道來進行。?
  可見,在應用程序端或者服務器端創建了Socket對象之后,就可以使用Send/SentTo方法將數據發送到連接的Socket,或者使用Receive/ReceiveFrom方法接收來自連接Socket的數據。?
  針對Socket編程,.NET 框架的 Socket 類是 Winsock32 API 提供的套接字服務的托管代碼版本。其中為實現網絡編程提供了大量的方法,大多數情況下,Socket 類方法只是將數據封送到它們的本機 Win32 副本中并處理任何必要的安全檢查。如果你熟悉Winsock API函數,那么用Socket類編寫網絡程序會非常容易,當然,如果你不曾接觸過,也不會太困難,跟隨下面的解說,你會發覺使用Socket類開發 windows 網絡應用程序原來有規可尋,它們在大多數情況下遵循大致相同的步驟。?
  在使用之前,你需要首先創建Socket對象的實例,這可以通過Socket類的構造方法來實現:?
public Socket(AddressFamily addressFamily,SocketType socketType,ProtocolType protocolType);?
  其中,addressFamily 參數指定 Socket 使用的尋址方案,socketType 參數指定 Socket 的類型,protocolType 參數指定 Socket 使用的協議。?
  下面的示例語句創建一個 Socket,它可用于在基于 TCP/IP 的網絡(如 Internet)上通訊。?
Socket temp = new Socket(AddressFamily.InterNetwork, SocketType.Stream, ProtocolType.Tcp);?
  若要使用 UDP 而不是 TCP,需要更改協議類型,如下面的示例所示:?
Socket temp = new Socket(AddressFamily.InterNetwork, SocketType.Dgram, ProtocolType.Udp);?
  一旦創建 Socket,在客戶端,你將可以通過Connect方法連接到指定的服務器,并通過Send/SendTo方法向遠程服務器發送數據,而后可以通過 Receive/ReceiveFrom從服務端接收數據;而在服務器端,你需要使用Bind方法綁定所指定的接口使Socket與一個本地終結點相聯,并通過Listen方法偵聽該接口上的請求,當偵聽到用戶端的連接時,調用Accept完成連接的操作,創建新的Socket以處理傳入的連接請求。使用完 Socket 后,記住使用 Shutdown 方法禁用 Socket,并使用 Close 方法關閉 Socket。?
  可以看出,以上許多方法包含EndPoint類型的參數,在Internet中,TCP/IP 使用一個網絡地址和一個服務端口號來唯一標識設備。網絡地址標識網絡上的特定設備;端口號標識要連接到的該設備上的特定服務。網絡地址和服務端口的組合稱為終結點,在 .NET 框架中正是由 EndPoint 類表示這個終結點,它提供表示網絡資源或服務的抽象,用以標志網絡地址等信息。.Net同時也為每個受支持的地址族定義了 EndPoint 的子代;對于 IP 地址族,該類為 IPEndPoint。IPEndPoint 類包含應用程序連接到主機上的服務所需的主機和端口信息,通過組合服務的主機IP地址和端口號,IPEndPoint 類形成到服務的連接點。?
  用到IPEndPoint類的時候就不可避免地涉及到計算機IP地址,System.Net命名空間中有兩種類可以得到IP地址實例:?
  IPAddress類:IPAddress 類包含計算機在 IP 網絡上的地址。其Parse方法可將 IP 地址字符串轉換為 IPAddress 實例。下面的語句創建一個 IPAddress 實例:?
IPAddress myIP = IPAddress.Parse("192.168.0.1");?
  Dns 類:向使用 TCP/IP Internet 服務的應用程序提供域名服務。其Resolve 方法查詢 DNS 服務器以將用戶友好的域名(如"host.mydomain.com")映射到數字形式的 Internet 地址(如 192.168.0.1)。Resolve方法 返回一個 IPHostEnty 實例,該實例包含所請求名稱的地址和別名的列表。大多數情況下,可以使用 AddressList 數組中返回的第一個地址。下面的代碼獲取一個 IPAddress 實例,該實例包含服務器 host.mydomain.com 的 IP 地址。?
IPHostEntry ipHostInfo = Dns.Resolve("host.mydomain.com ");?
IPAddress ipAddress = ipHostInfo.AddressList[0];?
  你也可以使用GetHostName方法得到IPHostEntry實例:?
IPHosntEntry hostInfo=Dns.GetHostByName("host.mydomain.com ")?
  在使用以上方法時,你將可能需要處理以下幾種異常:?
  SocketException異常:訪問Socket時操作系統發生錯誤引發?
  ArgumentNullException異常:參數為空引用引發?
  ObjectDisposedException異常:Socket已經關閉引發?
  在掌握上面得知識后,下面的代碼將該服務器主機( host.mydomain.com的 IP 地址與端口號組合,以便為連接創建遠程終結點:?
IPEndPoint ipe = new IPEndPoint(ipAddress,11000);?
  確定了遠程設備的地址并選擇了用于連接的端口后,應用程序可以嘗試建立與遠程設備的連接。下面的示例使用現有的 IPEndPoint 實例與遠程設備連接,并捕獲可能引發的異常:?
try?
{?
temp.Connect(ipe);//嘗試連接?
}?
//處理參數為空引用異常?
catch(ArgumentNullException ae)?
{?
Console.WriteLine("ArgumentNullException : {0}", ae.ToString());?
}?
//處理操作系統異常?
catch(SocketException se)?
{?
Console.WriteLine("SocketException : {0}", se.ToString());?
}?
  需要知道的是:Socket 類支持兩種基本模式:同步和異步。其區別在于:在同步模式中,對執行網絡操作的函數(如 Send 和 Receive)的調用一直等到操作完成后才將控制返回給調用程序。在異步模式中,這些調用立即返回。?
綜合運用以上闡述的使用Visual C#進行Socket網絡程序開發的知識,下面的程序是一個簡單的Socket通訊實例,client向server發送一段測試字符串,server接收并顯示出來,給予client成功相應。?
//client端?
using System;?
using System.Text;?
using System.IO;?
using System.Net;?
using System.Net.Sockets;?
namespace socketsample?
{?
 class Class1?
 {?
  static void Main()?
  {?
   try?
   {?
    int port = 2000;?
    string host = "127.0.0.1";?
    IPAddress ip = IPAddress.Parse(host);?
    IPEndPoint ipe = new IPEndPoint(ip, port);?
    Socket c = new Socket(AddressFamily.InterNetwork, SocketType.Stream, ProtocolType.Tcp);?
    c.Connect(ipe);?
    string sendStr = "hello!This is a socket test";?
    byte[] bs = Encoding.ASCII.GetBytes(sendStr);?
    c.Send(bs, bs.Length, 0);?
    string recvStr = "";?
    byte[] recvBytes = new byte[1024];?
    int bytes;?
    bytes = c.Receive(recvBytes, recvBytes.Length, 0);?
    recvStr += Encoding.ASCII.GetString(recvBytes, 0, bytes);?
    Console.WriteLine(recvStr);?
    c.Close();?
   }?
   catch (ArgumentNullException e)?
   {?
    Console.WriteLine("ArgumentNullException: {0}", e);?
   }?
   catch (SocketException e)?
   {?
    Console.WriteLine("SocketException: {0}", e);?
   }?
   Console.ReadLine();?
  }?
 }?
}?
//server端?
using System;?
using System.Text;?
using System.IO;?
using System.Net;?
using System.Net.Sockets;?
namespace Project1?
{?
 class Class2?
 {?
  static void Main()?
  {?
   try?
   {?
    int port = 2000;?
    string host = "127.0.0.1";?
    IPAddress ip = IPAddress.Parse(host);?
    IPEndPoint ipe = new IPEndPoint(ip, port);?
    Socket s = new Socket(AddressFamily.InterNetwork, SocketType.Stream, ProtocolType.Tcp);?
    s.Bind(ipe);?
    s.Listen(0);?
    Socket temp = s.Accept();?
    string recvStr = "";?
    byte[] recvBytes = new byte[1024];?
    int bytes;?
    bytes = temp.Receive(recvBytes, recvBytes.Length, 0);?
    recvStr += Encoding.ASCII.GetString(recvBytes, 0, bytes);?
    Console.WriteLine(recvStr);?
    string sendStr = "Ok!Sucess!";?
    byte[] bs = Encoding.ASCII.GetBytes(sendStr);?
    temp.Send(bs, bs.Length, 0);?
    temp.Shutdown(SocketShutdown.Both);?
    temp.Close();?
    s.Shutdown(SocketShutdown.Both);?
    s.Close();?
   }?
   catch (ArgumentNullException e)?
   {?
    Console.WriteLine("ArgumentNullException: {0}", e);?
   }?
   catch (SocketException e)?
   {?
    Console.WriteLine("SocketException: {0}", e);?
   }?
   Console.ReadLine();?
  }?
 }?
}?
  以上程序在VS Express 2005 .Net2.0環境下測試通過。

C#UDP的多路廣播組的發送和接收?
下列范例使用 UdpClient,在通訊端口11000傳送UDP 資料包至多點傳送位址群組 224.268.100.2。它傳送命令列上指定的信息字串。??
C# code?
using System;??
using System.Net;??
using System.Net.Sockets;??
using System.Text;??
public class UDPMulticastSender {??
private static IPAddress GroupAddress =??
IPAddress.Parse("224.168.100.2");??
private static int GroupPort = 11000;??
private static void Send( String message) {??
UdpClient sender = new UdpClient();??
IPEndPoint groupEP = new IPEndPoint(GroupAddress,GroupPort);??
try {??
Console.WriteLine("Sending datagram : {0}", message);??
byte[] bytes = Encoding.ASCII.GetBytes(message);??
sender.Send(bytes, bytes.Length, groupEP);??
sender.Close();??
} catch (Exception e) {??
Console.WriteLine(e.ToString());??
}??
}??
public static int Main(String[] args) {??
Send(args[0]);??
return 0;??
}??
}??

下列范例使用 UdpClient,在通訊端口? 11000? 監聽廣播到多點傳送位址群組 224.168.100.2 的 UDP? 資料包。它接收信息字串,并將信息寫入主控臺 (Console)。??

C# code

using System;??

using System.Net;??

using System.Net.Sockets;??

using System.Text;??

public class UDPMulticastListener {??

private static readonly IPAddress GroupAddress =??

IPAddress.Parse("224.168.100.2");??

private const int GroupPort = 11000;??

private static void StartListener() {??

bool done = false;??

UdpClient listener = new UdpClient();??

IPEndPoint groupEP = new IPEndPoint(GroupAddress,GroupPort);??

try {??

listener.JoinMulticastGroup(GroupAddress);??

listener.Connect(groupEP);??

while (!done) {??

Console.WriteLine("Waiting for broadcast");??

byte[] bytes = listener.Receive( ref groupEP);??

Console.WriteLine("Received broadcast from {0} :/n {1}/n",??

groupEP.ToString(),??

Encoding.ASCII.GetString(bytes,0,bytes.Length));??

}??

listener.Close();??

} catch (Exception e) {??

Console.WriteLine(e.ToString());??

}??

}??

public static int Main(String[] args) {??

StartListener();??

return 0;??

}??

}

using System;??

using System.Net;??

using System.Net.Sockets;??

using System.Text;??

public class UDPMulticastSender {??

private static IPAddress GroupAddress =??

IPAddress.Parse("224.168.100.2");??

private static int GroupPort = 11000;??

private static void Send( String message) {??

UdpClient sender = new UdpClient();??

IPEndPoint groupEP = new IPEndPoint(GroupAddress,GroupPort);??

try {??

Console.WriteLine("Sending datagram : {0}", message);??

byte[] bytes = Encoding.ASCII.GetBytes(message);??

sender.Send(bytes, bytes.Length, groupEP);??

sender.Close();??

} catch (Exception e) {??

Console.WriteLine(e.ToString());??

}??

}??

public static int Main(String[] args) {??

Send(args[0]);??

return 0;??

}??

}

C# code

try

??????????????? {

??????????????????? UdpClient udp=new UdpClient(new IPEndPoint(ipAddress,startPort+i));

??????????????????? udp.Close();????????????????????

??????????????????? unUsedPort=startPort+i;

??????????????????? break;

??????????????? }

??????????????? catch

??????????????? {

??????????????? }

using System;

using System.Collections.Generic;

using System.ComponentModel;

using System.Data;

using System.Drawing;

using System.Text;

using System.Windows.Forms;

using System.Collections;

using System.Collections.Specialized;

using System.Threading;

using System.Net.Sockets;

using System.Net;

using System.Runtime.Serialization;

using System.Runtime.Serialization.Formatters.Binary;

using System.IO;

namespace 聊天工具服務器

{

??? public partial class FormMain : Form

??? {

??????? public FormMain()

??????? {

??????????? InitializeComponent();

??????? }

??????? #region 字段定義

??????? /// <summary>

??????? /// 服務器程序使用的端口,默認為8888

??????? /// </summary>

??????? private int _port = 8888;

??????? /// <summary>

??????? /// 接收數據緩沖區大小2K

??????? /// </summary>

??????? private const int _maxPacket =2 * 1024;

??????? /// <summary>

??????? /// 服務器端的監聽器

??????? /// </summary>

??????? private TcpListener _tcpl = null;

??????? Thread _receiveThread;

??????? /// <summary>

??????? /// 保存所有客戶端會話的哈希表

??????? /// </summary>

??????? private Hashtable _transmit_tb = new Hashtable();

??????? /// <summary>

??????? /// 當前文件路徑

??????? /// </summary>

??????? string MyPath = null;

??????? /// <summary>

??????? /// 用戶基本信息表,包括UserName,UserPwd,UserNich,UserImg,ZX,UserIp

??????? /// </summary>

??????? DataTable TabUser = new DataTable();

??????? /// <summary>

??????? /// 用戶消息表,保存用戶不在線時的消息

??????? /// </summary>

??????? DataTable TabUserMessage = new DataTable();

??????? #endregion

??????? /// <summary>

??????? /// 序列化在線列表,向客戶端返回序列化后的字節數組

??????? /// </summary>

??????? /// <returns>序列化后的字節數組 </returns>

??????? private byte[] SerializeOnlineList()

??????? {

??????????? StringCollection onlineList = new StringCollection();

??????????? foreach (object o in _transmit_tb.Keys)

??????????? {

??????????????? onlineList.Add(o as string);

??????????? }

??????????? IFormatter format = new BinaryFormatter();

??????????? MemoryStream stream = new MemoryStream();

??????????? format.Serialize(stream, onlineList);

??????????? byte[] ret = stream.ToArray();

??????????? stream.Close();

??????????? return ret;

??????? }

??????? /// <summary>

??????? /// 序列化好友列表,向客戶端返回序列化后的datatable

??????? /// </summary>

??????? /// <returns>序列化后的字節數組 </returns>

??????? private bool SerializeFriendList(object obj, Socket clientSkt)

??????? {

??????????? DataTable TabmyFriend = new DataTable();

??????????? TabmyFriend.TableName = obj as string;

??????????? try {

??????????????? TabmyFriend.ReadXml(MyPath + "//UserFriend//" + TabmyFriend.TableName + ".xml");

??????????????? TabmyFriend.Columns.Add("UserImg", typeof(String));

??????????????? TabmyFriend.Columns.Add("UserNich", typeof(String));

??????????????? TabmyFriend.Columns.Add("ZX", typeof(Boolean));

??????????????? TabmyFriend.Columns.Add("UserIp", typeof(String));

??????????????? foreach (DataRow myrow in TabmyFriend.Rows)

??????????????? {

??????????????????? DataRow[] DataRows = TabUser.Select(" UserName = '" + myrow["UserName"].ToString() + "'");

??????????????????? if (DataRows.Length > 0)

??????????????????? {

??????????????????????? myrow["UserImg"] = DataRows[0]["UserImg"].ToString();

??????????????????????? myrow["UserNich"] = DataRows[0]["UserNich"].ToString();

????????????????????? try

????????????????????? {

??????????????????????????? myrow["ZX"] = (bool)DataRows[0]["ZX"];

??????????????????????????? myrow["UserIp"] = DataRows[0]["UserIp"].ToString();

????????????????????? }???

????????????????????? catch

??????????????????????? {

??????????????????????????? myrow["ZX"] = false;

??????????????????????????? myrow["UserIp"] = "";

??????????????????????? }

??????????????????? }

??????????????? }

??????????? }

??????????? catch

??????????? {

??????????????? TabmyFriend.Columns.Add("UserName", typeof(String));

??????????????? TabmyFriend.Columns.Add("UserImg", typeof(String));

??????????????? TabmyFriend.Columns.Add("ZX", typeof(Boolean));

??????????????? TabmyFriend.Columns.Add("UserIp", typeof(String));

??????????? }

??????????? IFormatter format = new BinaryFormatter();

??????????? MemoryStream stream = new MemoryStream();

??????????? format.Serialize(stream, TabmyFriend);

??????????? stream.Position = 0;

??????????? byte[] ret = new byte[_maxPacket];

??????????? int count = 0;

??????????? count = stream.Read(ret, 0, _maxPacket);

??????????? //先發送響應信號,用戶客戶機的判斷

??????????? clientSkt.Send(Encoding.Unicode.GetBytes("cmd::RequestFriendList"));

??????????? while (count >0)

??????????? {

??????????????? clientSkt.Send(ret);

??????????????? count =? stream.Read(ret, 0, _maxPacket);

????????????? }

??????????? //發送結束信號

????????????? clientSkt.Send(Encoding.Unicode.GetBytes("Find::RequestFriendListEnd"));??

????????????? stream.Close();

??????????? return true ;

??????? }

??????? private void FormMain_Load(object sender, EventArgs e)

??????? {

??????????? MyPath = Application.StartupPath;

??????????? Read_User();

??????????? ReadTabUserMessage();

??????????? _receiveThread = new Thread(new ThreadStart(StartUp));

??????????? _receiveThread.Start();

??????? }

??????? /// <summary>

??????? /// 讀取所有用戶信息

??????? /// </summary>

??????? private void Read_User()

??????? {

??????????? try

??????????? {

??????????????? TabUser.ReadXml(MyPath + "//User.xml");

??????????? }

??????????? catch

??????????? {

??????????????? TabUser.TableName = "User";

??????????????? TabUser.Columns.Add("UserName", typeof(String));

??????????????? TabUser.Columns.Add("UserPwd", typeof(String));

??????????????? TabUser.Columns.Add("UserNich", typeof(String));

??????????????? TabUser.Columns.Add("UserImg", typeof(String));

??????????? }

??????????? TabUser.Columns.Add("ZX", typeof(Boolean));

??????????? TabUser.Columns.Add("UserIp", typeof(String));

??????? }

??????? /// <summary>

??????? /// 新用戶上/下線后,更新其好友的(好友列表)

??????? /// </summary>

??????? /// <param name="UserName"> </param>

??????? /// <param name="OnLine"> </param>

??????? /// <param name="IpAddress"> </param>

??????? private void UpdateFriendList(string UserName, bool OnLine, string IpAddress)

??????? {

??????????? DataTable TabmyFriend = new DataTable();

??????????? TabmyFriend.TableName = UserName;

??????????? string svrlog = null;

??????????? string []UserInformation = new string[2];//UserName + "$" + IpAddress;

??????????? UserInformation[0] = UserName;

??????????? UserInformation[1] = IpAddress;

??????????? IFormatter format = new BinaryFormatter();

??????????? MemoryStream stream = new MemoryStream();

??????????? format.Serialize(stream, UserInformation);

??????????? byte[] ret = stream.ToArray();

??????????? stream.Close();

??????????? if (OnLine)

??????????? {

??????????????? svrlog = "cmd::RequestAddFriendList";

??????????? }

??????????? else

??????????? {

??????????????? svrlog = "cmd::RequestRemoveFriendList";

??????????????? DataRow[] DataRows = TabUser.Select(" UserName = '" + UserName + "'");

??????????????? if (DataRows.Length > 0)

??????????????? {

??????????????????? DataRows[0]["ZX"] = false;

??????????????????? DataRows[0]["UserIp"] = "";

??????????????? }

??????????? }

??????????? try

??????????? {

??????????????? TabmyFriend.ReadXml(MyPath + "//UserFriend//" + TabmyFriend.TableName + ".xml");

??????????????? foreach (DataRow myrow in TabmyFriend.Rows)

??????????????? {

??????????????????? if(_transmit_tb.ContainsKey(myrow["UserName"].ToString()))

??????????????????? {

??????????????????????? Socket _clientSkt = _transmit_tb[myrow["UserName"].ToString()] as Socket;

????????????????????? _clientSkt.Send(Encoding.Unicode.GetBytes(svrlog));

????????????????????? _clientSkt.Send(ret);

??????????????????? }

??????????????? }

??????????? }

??????????? catch

??????????? { }

??????? }

[code=C#][/code /// <summary>

??????? /// 線程執行體,轉發消息

??????? /// </summary>

??????? /// <param name="obj">傳遞給線程執行體的用戶名,用以與用戶通信 </param>

??????? private void ThreadFunc(object obj)

??????? {

??????????? //通過轉發表得到當前用戶套接字

??????????? Socket clientSkt = _transmit_tb[obj] as Socket;

????????? //主循環

??????????? while (true)

??????????? {

??????????????? try

??????????????? {

??????????????????? //接受第一個數據包。

??????????????????? //由于程序邏輯結構簡單,所以在這里對客戶機發送的第一個包內容作逐一判斷,

??????????????????? //這里的實現不夠優雅,但不失為此簡單模型的一個解決之道。

??????????????????? byte[] packetBuff = new byte[_maxPacket];

??????????????????? clientSkt.Receive(packetBuff);

??????????????????? string _str = Encoding.Unicode.GetString(packetBuff).TrimEnd('/0');

??????????????????? //如果是發給不在線好友的信息

??????????????????? if (_str.StartsWith("cmd::FriendMessage"))

??????????????????? {

??????????????????????? string UserName = _str.Substring("cmd::FriendMessage".Length, 20).Trim();

??????????????????????? string MessageS = _str.Substring("cmd::FriendMessage".Length + 20, _str.Length - "cmd::FriendMessage".Length - 20);

??????????????????????? SaveMessage(obj as string, UserName, MessageS);

??????????????????????? continue;

??????????????????? }

??????????????????? //如果是離線請求

??????????????????? if (_str.StartsWith("cmd::RequestLogout"))

??????????????????? {

??????????????????????? _transmit_tb.Remove(obj);

??????????????????????? UpdateFriendList((string)obj, false, "");

????????????????????? //? string svrlog = string.Format("[系統消息]用戶 {0} 在 {1} 已斷開... 當前在線人數: {2}/r/n/r/n", obj, DateTime.Now, _transmit_tb.Count);

????????????????????? //? Console.WriteLine(svrlog);

??????????????????????? //向所有客戶機發送系統消息

??????????????????????? //foreach (DictionaryEntry de in _transmit_tb)

??????????????????????? //{

??????????????????????? //??? string _clientName = de.Key as string;

??????????????????????? //??? Socket _clientSkt = de.Value as Socket;

??????????????????????? //??? _clientSkt.Send(Encoding.Unicode.GetBytes(svrlog));

??????????????????????? //}

??????????????????????? Thread.CurrentThread.Abort();

??????????????????? }

??????????????????? //如果是請求好友列表

??????????????????? if (_str.StartsWith("cmd::RequestFriendList"))

??????????????????? {

??????????????????????? SerializeFriendList(obj, clientSkt);?????????????????????

??????????????????????? // 將該用戶不在線時的信息發送給用戶

??????????????????????? DataTable TabMessage = ReadMessage(obj as string);

??????????????????????? if (TabMessage != null)

??????????????????????? {

??????????????????????????? foreach (DataRow myrow in TabMessage.Rows)

??????????????????????????? {

??????????????????????????????? if (myrow["SendUserName"].ToString() == "System::Message")

??????????????????????????????? {

??????????????????????????????????? clientSkt.Send(Encoding.Unicode.GetBytes(myrow["Message"].ToString()));

??????????????????????????????? }

??????????????????????????????? else

??????????????????????????????? {

??????????????????????????????????? clientSkt.Send(Encoding.Unicode.GetBytes("cmd::FriendMessage" + myrow["SendUserName"].ToString().PadRight(20, ' ') + myrow["Message"].ToString()));

??????????????????????????????? }

??????????????????????????? }

??????????????????????? }

??????????????????????? //這里不需要再繼續接受后繼數據包了,跳出當前循環體。

??????????????????????? continue;

??????????????????? }

??????????????????? 如果是請求好友列表

??????????????????? //if (_str.StartsWith("cmd::RequestOnLineList"))

??????????????????? //{

??????????????????? //??? byte[] onlineBuff = SerializeOnlineList();

??????????????????? //??? //先發送響應信號,用戶客戶機的判斷

??????????????????? //??? clientSkt.Send(Encoding.Unicode.GetBytes("cmd::RequestOnLineList"));

??????????????????? //??? clientSkt.Send(onlineBuff);

??????????????????? //??? //這里不需要再繼續接受后繼數據包了,跳出當前循環體。

??????????????????? //??? continue;

??????????????????? //}

??????????????????? //查找用戶

??????????????????? if (_str.StartsWith("Find::FindFriend"))

??????????????????? {

??????????????????????? DataTable TabFind = TabUser.Clone();

??????????????????????? DataRow [] FindRow =null? ;

??????????????????????? string UserName = _str.Substring("Find::FindFriend".Length, _str.Length - "Find::FindFriend".Length);

??????????????????????? if (UserName.Equals("Find::WhoOnLine"))

??????????????????????? { //看誰在線

??????????????????????????? FindRow = TabUser.Select(" ZX = 1");

??????????????????????? }

??????????????????????? else//精確查找

??????????????????????? {

??????????????????????????? FindRow = TabUser.Select("UserName = '" + UserName + "'");

??????????????????????? }

??????????????????????? foreach (DataRow myrow in FindRow)

??????????????????????? {

??????????????????????????? TabFind.ImportRow(myrow);

??????????????????????? }

??????????????????????? clientSkt.Send(Encoding.Unicode.GetBytes("Find::FindFriend"));

??????????????????????? IFormatter format = new BinaryFormatter();

??????????????????????? MemoryStream stream = new MemoryStream();

??????????????????????? format.Serialize(stream, TabFind);

??????????????????????? stream.Position = 0;

??????????????????????? byte[] ret = new byte[_maxPacket];

??????????????????????? int count = 0;

??????????????????????? count = stream.Read(ret, 0, _maxPacket);

??????????????????????? while (count >0)

??????????????????????? {

??????????????????????????? clientSkt.Send(ret);

????????????????????????? count =? stream.Read(ret, 0, _maxPacket);

??????????????????????? }

??????????????????????? clientSkt.Send(Encoding.Unicode.GetBytes("Find::FindFriendEnd"));??

??????????????????????? stream.Close();

??????????????????????? TabFind = null;

??????????????????????? FindRow = null;

//這里不需要再繼續接受后繼數據包了,跳出當前循環體。

??????????????????????? continue;

??????????????????? }

??????????????????? //請求添加好友

??????????????????? if (_str.StartsWith("Find::AddFriendAsk"))

??????????????????? {

??????????????????????? string UserName = _str.Substring("Find::AddFriendAsk".Length, _str.Length - "Find::AddFriendAsk".Length);

??????????????????????? //通過轉發表查找接收方的套接字

??????????????????????? if (_transmit_tb.Count != 0 && _transmit_tb.ContainsKey(UserName))

??????????????????????? {

??????????????????????????? Socket receiverSkt = _transmit_tb[UserName] as Socket;

??????????????????????????? receiverSkt.Send(Encoding.Unicode.GetBytes("Find::AddFriendAsk" + obj as string));

??????????????????????? }

??????????????????????? //這里不需要再繼續接受后繼數據包了,跳出當前循環體。

??????????????????????? continue;

??????????????????? }

??????????????????? //回復答應添加好友

??????????????????? if (_str.StartsWith("Find::AddFriendYes"))

??????????????????? {

??????????????????????? string UserName = _str.Substring("Find::AddFriendYes".Length, _str.Length - "Find::AddFriendYes".Length);

????????????????????? 保存數據

??????????????????????? DataTable TabmyFriend = new DataTable() ;

??????????????????????? //保存該用戶

??????????????????????? TabmyFriend.ReadXml(MyPath + "//UserFriend//" +? obj as string + ".xml");

??????????????????????? DataRow newRow = TabmyFriend.NewRow();

??????????????????????? newRow["UserName"] = UserName;

??????????????????????? TabmyFriend.Rows.Add(newRow);

??????????????????????? TabmyFriend.WriteXml(MyPath + "//UserFriend//" + obj as string + ".xml", XmlWriteMode.WriteSchema, false);

??????????????????????? //保存其好友

??????????????????????? TabmyFriend = new DataTable();

??????????????????????? TabmyFriend.ReadXml(MyPath + "//UserFriend//" + UserName + ".xml");

??????????????????????? DataRow newRow1 = TabmyFriend.NewRow();

??????????????????????? newRow1["UserName"] = obj as string;

??????????????????????? TabmyFriend.Rows.Add(newRow1);

??????????????????????? TabmyFriend.WriteXml(MyPath + "//UserFriend//" + UserName + ".xml", XmlWriteMode.WriteSchema, false);

??????????????????????? TabmyFriend = null;

????????????? //更新好友列表

??????????????????????? SerializeFriendList(obj, clientSkt);

上面發了服務器端,沒發客戶端,現在補上!不知道寫的好不好,見笑了

C# code

public partial class Form1 : Form

??? {

??????? private TcpClient client;

??????? private bool isExit = false;

??????? private NetworkStream networkStream;

??????? private EventWaitHandle allDone = new EventWaitHandle(false, EventResetMode.ManualReset);

??????? #region 用于一個線程操作另一個線程的控件

??????? private delegate void SetListBoxCallback(string str);

??????? private SetListBoxCallback setListBoxCallBack;

??????? private delegate void SetRichTextBoxCallback(string str);

??????? private SetRichTextBoxCallback setRichTextBoxCallBack;

??????? #endregion

??????? public Form1()

??????? {

??????????? InitializeComponent();

??????????? listBoxStatus.HorizontalScrollbar = true;

??????????? setListBoxCallBack = new SetListBoxCallback(SetListBox);

??????????? setRichTextBoxCallBack = new SetRichTextBoxCallback(SetReceiveText);

??????? }

??????? //狀態顯示

??????? private void SetListBox(string str)

??????? {

??????????? listBoxStatus.Items.Add(str);

??????????? listBoxStatus.SelectedIndex = listBoxStatus.Items.Count - 1;

??????????? listBoxStatus.ClearSelected();

??????? }

??????? //接收客戶端信息

??????? private void SetReceiveText(string str)

??????? {

??????????? richTextBoxReceive.AppendText(str);

??????? }

??????? //連接服務器....

??????? private void buttonConnet_Click(object sender, EventArgs e)

??????? {

??????????? client = new TcpClient(AddressFamily.InterNetwork);

??????????? //得到服務器IP

??????????? IPAddress ip= IPAddress.Parse("127.0.0.1");

??????????? //創建一個委托,并知名在異步操作完成時執行的方法

??????????? AsyncCallback callback = new AsyncCallback(RequestCallBack);

??????????? allDone.Reset();

??????????? client.BeginConnect(ip, 7100, RequestCallBack, client);

??????? }

??????? private void RequestCallBack(IAsyncResult ar)

??????? {

??????????? allDone.Set();

??????????? try

??????????? {

??????????????? client = (TcpClient)ar.AsyncState;

??????????????? client.EndConnect(ar);

??????????????? listBoxStatus.Invoke(setListBoxCallBack, string.Format("與服務器{0}連接成功", client.Client.RemoteEndPoint));

??????????????? networkStream = client.GetStream();

??????????????? ReadObject readObject = new ReadObject(networkStream, client.ReceiveBufferSize);

??????????????? networkStream.BeginRead(readObject.bytes, 0, readObject.bytes.Length, ReadCallBack, readObject);

??????????? }

??????????? catch (Exception e1)

??????????? {

??????????????? listBoxStatus.Invoke(setListBoxCallBack, e1.Message);

??????????????? return;

??????????? }

??????? }

??????? //異步操作完成時執行的回調調用的方法

??????? private void ReadCallBack(IAsyncResult ar)

??????? {

??????????? try

??????????? {

??????????????? ReadObject ro = (ReadObject)ar.AsyncState;

??????????????? int count = ro.netStream.EndRead(ar);

??????????????? richTextBoxReceive.Invoke(setRichTextBoxCallBack, System.Text.Encoding.UTF8.GetString(ro.bytes, 0, count));

??????????????? if (isExit == false)

??????????????? {

??????????????????? ro = new ReadObject(networkStream, client.ReceiveBufferSize);

??????????????????? networkStream.BeginRead(ro.bytes, 0, ro.bytes.Length, ReadCallBack, ro);

??????????????? }

??????????? }

??????????? catch (Exception e2)

??????????? {

??????????????? listBoxStatus.Invoke(setListBoxCallBack, e2.Message);

??????????????? return;

??????????? }

??????? }

??????? //發送數據

??????? private void SendString(string str)

??????? {

??????????? try

??????????? {

??????????????? byte[] by = System.Text.Encoding.UTF8.GetBytes(str+"/r/n");

??????????????? networkStream.BeginWrite(by, 0, by.Length, new AsyncCallback(SendCallBack), networkStream);

??????????????? networkStream.Flush();

??????????? }catch(Exception e3){

??????????????? listBoxStatus.Invoke(setListBoxCallBack, e3.Message);

??????????????? return;

??????????? }

??????? }

??????? //發送數據回調的方法

??????? private void SendCallBack(IAsyncResult ar)

??????? {

??????????? try

??????????? {

??????????????? networkStream.EndWrite(ar);

??????????? }

??????????? catch (Exception e4)

??????????? {

??????????????? listBoxStatus.Invoke(setListBoxCallBack, e4.Message);

??????????????? return;

??????????? }

??????? }

??????? private void buttonSend_Click(object sender, EventArgs e)

??????? {

??????????? SendString(richTextBoxSend.Text);

??????????? richTextBoxSend.Clear();

??????? }

??????? private void Form1_FormClosing(object sender, FormClosingEventArgs e)

??????? {

??????????? isExit = true;

??????????? allDone.Set();

??????? }

??? }

aliyun活動 https://www.aliyun.com/acts/limit-buy?userCode=re2o7acl

總結

以上是生活随笔為你收集整理的C#完整的通信代码(点对点,点对多,同步,异步,UDP,TCP)的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

三级免费黄色 | 亚洲精品无 | 在线免费观看麻豆视频 | 天天狠狠操 | 天天操天天干天天爽 | 亚洲精品999 | 成人激情开心网 | 欧美资源| 日日夜夜天天操 | 一区二区三区日韩精品 | 91在线播| 国产成人精品久久二区二区 | 91亚洲在线观看 | 黄色高清视频在线观看 | 久久免费看a级毛毛片 | 99热国产在线 | 欧美成人影音 | 日韩视频1区 | 亚洲色综合 | 不卡的av片 | 国产黄色理论片 | 91久久偷偷做嫩草影院 | 午夜av免费在线观看 | 日本xxxx.com | 欧美va天堂va视频va在线 | 欧美午夜视频在线 | 操少妇视频| 欧洲亚洲女同hd | 97av影院| 日韩精品免费一区二区 | 欧美激情视频在线免费观看 | 日韩精品久久一区二区三区 | 国产精品 中文在线 | 在线视频观看成人 | 91久久奴性调教 | 狠狠狠狠狠狠狠狠 | 国产精品无av码在线观看 | 久视频在线播放 | 在线国产小视频 | 91在线观看高清 | 欧美一区二区日韩一区二区 | 色久综合| 国产 精品 资源 | 亚洲自拍av在线 | 国产91精品久久久久 | 黄色在线免费观看网址 | 国内丰满少妇猛烈精品播 | 69久久久 | 丁香五香天综合情 | 久草在线视频免费资源观看 | 国产91精品看黄网站在线观看动漫 | 99热在线观看免费 | 一本一本久久a久久精品牛牛影视 | 亚洲国产精久久久久久久 | 久爱综合 | a午夜电影 | 久久九九精品久久 | 麻豆一区在线观看 | 成人一区二区在线观看 | 亚洲精品国产高清 | 国产精品18久久久久vr手机版特色 | 午夜精品一区二区三区可下载 | 久久成人亚洲欧美电影 | 国产福利91精品一区 | 久久久久在线观看 | 国内成人精品2018免费看 | 精品国产一区二 | www国产精品com | 五月婷亚洲 | 久久久久久久久毛片精品 | 国产欧美三级 | 91视频久久久 | 色婷婷在线观看视频 | 热久久在线视频 | 五月天色网站 | 久久少妇免费视频 | 特级西西444www大胆高清无视频 | 中文字幕日韩精品有码视频 | 97国产电影 | 色婷婷视频在线 | 毛片视频电影 | 丰满少妇在线观看网站 | 毛片精品免费在线观看 | 国产 av 日韩 | 亚州精品天堂中文字幕 | 成人午夜剧场在线观看 | 成人午夜精品福利免费 | 91精品国产网站 | 免费v片 | 国产午夜在线 | av蜜桃在线 | 又爽又黄又无遮挡网站动态图 | 91麻豆精品国产 | 特级西西www44高清大胆图片 | 中文字幕国内精品 | 久久久久久久久福利 | 国产精品国产三级在线专区 | 97人人看 | 国产精美视频 | 亚洲一区二区三区在线看 | a天堂中文在线 | 国产麻豆果冻传媒在线观看 | 99这里只有久久精品视频 | 成人黄色小视频 | 欧美激情在线网站 | 国产亚洲精品成人av久久ww | 三级动图 | 精品国产一区二区三区久久久蜜月 | 日韩精品一区二区三区在线视频 | 日韩毛片在线播放 | 精品视频久久久久久 | 亚洲成免费 | 美女视频免费精品 | 日韩免费不卡视频 | 欧美激情视频一区二区三区 | 欧美日韩精品在线观看视频 | 久久毛片网站 | 日本乱码在线 | 国产中文字幕一区二区 | 成人黄色片免费看 | 97人人模人人爽人人少妇 | 日本在线视频一区二区三区 | 欧美一区二区三区在线播放 | 夜夜躁日日躁 | 在线观看成人福利 | 天天插日日插 | 久久色视频 | 五月婷婷中文 | 国产精品久久久久久妇 | 91激情在线视频 | 欧美日韩三级在线观看 | 香蕉视频免费在线播放 | 免费观看www小视频的软件 | 国产999精品久久久影片官网 | 成人在线视频免费观看 | 亚洲91中文字幕无线码三区 | 黄色一级大片在线观看 | 99色在线视频 | 麻豆免费在线播放 | 久久免费福利视频 | 国产伦理久久精品久久久久_ | 97国产情侣爱久久免费观看 | 日韩高清在线一区二区三区 | 婷婷久久综合九色综合 | 国产成人精品一区二三区 | 黄色免费观看网址 | 精品国产一区二区久久 | 黄色毛片一级片 | 久热免费在线观看 | 午夜精品视频一区 | 国产精品一区二区免费 | 在线观看视频日韩 | 国产精品久久久久av免费 | 亚洲综合激情小说 | 久久a v视频| 亚洲精选久久 | 九色免费视频 | www看片网站 | 久久久www成人免费毛片麻豆 | 成人综合婷婷国产精品久久免费 | 亚洲草视频 | 国产精品久久久久久久久久东京 | 在线观看日韩视频 | 在线观看麻豆av | 中文字幕久久久精品 | 一区二区 不卡 | 中文字幕在线观看免费高清完整版 | 免费h在线观看 | 伊人狠狠色丁香婷婷综合 | 国产精品成人久久久久 | 日日摸日日碰 | 国产免费久久精品 | 成年人电影免费看 | 国产成人精品av在线观 | 国产在线观看 | 精品91在线| 色播五月婷婷 | 天天天天色射综合 | 视频二区在线视频 | 国产精品18久久久久久久久久久久 | 亚洲人成综合 | 免费a视频| 国产精品久久久久久久久免费 | 国产精品美乳一区二区免费 | 日本久久免费视频 | 日韩国产精品久久久久久亚洲 | 精一区二区 | 91精品久久香蕉国产线看观看 | 亚洲国产中文字幕在线 | 成人av动漫在线 | 一区二区精品久久 | 久久99视频 | 人人玩人人添人人澡97 | 中文字幕一区二区三区四区视频 | 玖玖视频网 | 天天操天天曰 | www.天天射 | 久久成人国产 | 亚洲欧洲成人精品av97 | 免费看黄视频 | 在线成人短视频 | 久久久在线免费观看 | 国产精品一二 | av电影免费在线看 | 国产精品久久久久久久久久妇女 | 亚洲精品国产区 | 韩日三级av| 特级毛片在线 | 色网站中文字幕 | 色的网站在线观看 | 国产伦精品一区二区三区免费 | 国产短视频在线播放 | 色a综合| 国产一区高清在线观看 | 99热在线免费观看 | 亚洲视频www| 国产精品精品久久久久久 | 伊人婷婷综合 | 亚洲精品色视频 | 天天操天天干天天干 | 99色婷婷| 在线中文字母电影观看 | 免费看一级特黄a大片 | 亚洲一区久久 | 亚洲女同videos | 99在线精品视频观看 | 精品国产综合区久久久久久 | 久久er99热精品一区二区三区 | www.五月激情.com| 国产在线p | 亚洲精品成人免费 | 91精品国产福利在线观看 | 亚洲精品中文在线观看 | 国产资源站 | 五月婷婷六月丁香激情 | 精品国产区 | 亚洲精品456在线播放第一页 | 欧美国产日韩中文 | 国产精品视频区 | 久久久99久久 | 在线免费观看涩涩 | 久久午夜电影院 | 一级a性色生活片久久毛片波多野 | 在线观看的av | 中文字幕亚洲在线观看 | 天天干天天操人体 | 久久涩涩网站 | 岛国av在线 | 精品国产伦一区二区三区观看体验 | 玖操 | 国产成人福利 | 日本公妇在线观看 | 亚洲国产精品一区二区尤物区 | 欧美在线aaa | 久久草在线免费 | 国产精品一区二区三区视频免费 | 国产精品成| 最近最新最好看中文视频 | 欧美a免费 | 成人动漫一区二区 | 欧美男男激情videos | 黄色视屏在线免费观看 | 最新av免费 | 在线观看视频日韩 | 国产精品久久久久久欧美 | 国产1级视频 | 最近免费中文字幕mv在线视频3 | 五月天久久精品 | 亚洲欧美成人 | 久久精品国产99 | www.狠狠操.com| 亚洲精品www. | 在线观看免费福利 | 久久99久国产精品黄毛片入口 | 亚洲午夜电影网 | 香蕉97视频观看在线观看 | 九九热视频在线免费观看 | 天天综合91| 欧美人牲 | 91精品久久久久久 | 亚洲精品一区二区18漫画 | 特级毛片网 | 1000部国产精品成人观看 | 色网站中文字幕 | 久久99在线| 探花视频免费观看高清视频 | 1区2区视频 | 亚一亚二国产专区 | 国产中文字幕一区二区 | 中文字幕在线观看播放 | 国产xvideos免费视频播放 | 综合久色| 中文字幕电影在线 | 成人在线免费视频观看 | av激情五月 | 丁香九月激情 | www九九热 | 999电影免费在线观看 | 亚洲激情综合网 | 国产在线观看中文字幕 | 国际精品久久久久 | 久久久受www免费人成 | 亚洲免费永久精品国产 | 9999国产| 亚洲影院国产 | 久草网在线观看 | 久久躁日日躁aaaaxxxx | 精品久久久久国产免费第一页 | 免费黄a大片 | 色婷婷综合久久久久中文字幕1 | 久久久国产成人 | 一区二区三区在线观看免费视频 | 97在线观看视频国产 | 91三级视频 | 成人免费影院 | 天天干天天射天天插 | 99久久精品国产毛片 | 69av视频在线 | 亚洲欧美国产精品va在线观看 | 久久 精品一区 | 操老逼免费视频 | 黄色影院在线播放 | 日日夜夜91 | 国产一区视频在线观看免费 | 曰本免费av | 亚洲精品视频免费在线观看 | 天天摸天天舔 | 国产三级午夜理伦三级 | 亚洲精品国产精品国自 | 午夜精品久久久99热福利 | 色资源中文字幕 | 在线观看免费成人av | 久久国内精品99久久6app | 三级av小说 | 国产精品99久久久精品 | 99久国产| 手机在线黄色网址 | 在线免费高清视频 | 欧美久久久久久久久久久久 | 欧美日韩高清免费 | 97操碰 | 中日韩免费视频 | 亚洲乱码在线 | 一级久久精品 | 日韩国产精品一区 | 欧美日韩视频在线一区 | 在线精品视频免费播放 | 色婷婷国产在线 | 欧美日韩啪啪 | 香蕉视频在线观看免费 | 97成人免费视频 | 亚洲国产精品va在线看黑人 | 久久九九久久 | 伊人电影在线观看 | 一区二区三区免费在线观看 | 久久五月情影视 | 色a在线观看 | 日韩精品欧美视频 | 色综合久久久久综合体桃花网 | 久久国产亚洲 | 玖玖视频免费在线 | 国产精品免费视频观看 | 国产一区在线播放 | 国产视频精品在线 | 日日夜夜精品 | 91精品久久久久久粉嫩 | 中文字幕在线日 | 免费在线播放视频 | 欧美一区日韩精品 | 国产亚洲综合精品 | 狠狠色丁香婷婷综合橹88 | 干干夜夜 | 五月婷婷久 | 久久久久久久久艹 | 欧洲精品久久久久毛片完整版 | 91福利视频免费观看 | 欧美精品一区在线 | 在线成人免费 | 在线看成人 | 国产在线91精品 | 国产精品久久久久影院 | 亚洲欧洲国产精品 | 五月天久久综合网 | 在线精品国产 | 国产午夜在线观看 | 天天天射 | 国产精品一区二区三区四区在线观看 | 国产一区91| 久久视屏网 | 在线视频 91 | 不卡国产在线 | 欧美午夜理伦三级在线观看 | 日韩中文字幕电影 | 日韩欧美国产视频 | 欧美在线观看视频一区二区 | 日本 在线 视频 中文 有码 | 国产成人精品久久久久蜜臀 | www.色com| 91精品久久久久久久91蜜桃 | av线上看 | 日韩三级一区 | av动图| 久久精品免视看 | 久久99精品国产99久久 | 日韩资源视频 | 亚洲免费一级 | 亚洲视频精品在线 | 国产视频在线观看免费 | 91亚洲精品久久久蜜桃网站 | 欧美日韩精品国产 | 香蕉视频在线网站 | 国产a视频免费观看 | 黄色国产在线 | www.午夜色.com | 91av手机在线 | 国产高清综合 | 亚洲午夜精品一区 | 国产喷水在线 | 中文成人字幕 | 91福利在线观看 | 毛片精品免费在线观看 | 九九精品毛片 | 日韩免费二区 | 亚洲乱亚洲乱妇 | 99久久精品国产一区二区三区 | 少妇视频一区 | 亚洲成av人片一区二区梦乃 | 久久久久国产精品厨房 | 日韩一区正在播放 | 丁香婷婷激情五月 | 国产精品一区二区美女视频免费看 | 国产一级久久 | 日韩激情在线视频 | 亚洲欧美精品在线 | 午夜性盈盈 | 亚洲最大激情中文字幕 | 99久久精品无码一区二区毛片 | 久久久wwww | 人人操日日干 | 91久久人澡人人添人人爽欧美 | 国产毛片久久 | 国内精品视频一区二区三区八戒 | 国产一区在线不卡 | 日本久久久久久久久久久 | 国产激情免费 | 国产精品99在线观看 | 精品视频网站 | 久久精品日产第一区二区三区乱码 | 国产精品欧美久久 | 天堂在线成人 | 天天综合色 | 久久综合久久综合久久 | 中文字幕亚洲欧美 | 久久久91精品国产 | 欧美超碰在线 | 91免费观看 | 粉嫩av一区二区三区四区五区 | 国产精品1000 | 九色视频网址 | a级黄色片视频 | 91粉色视频 | www.久草.com| 欧美韩国日本在线 | 国产成人高清在线 | 久久成人麻豆午夜电影 | 国产伦精品一区二区三区无广告 | 香蕉在线影院 | 亚洲国产成人久久 | 国产最顶级的黄色片在线免费观看 | 91在线免费观看国产 | 婷婷色中文 | 亚洲国产丝袜在线观看 | 国产成人三级在线观看 | 一级α片免费看 | 婷婷亚洲激情 | 久久手机免费视频 | 午夜精品久久久久久久99 | 中文字幕乱在线伦视频中文字幕乱码在线 | 欧美日韩网站 | 97视频免费看 | 狠狠干免费 | 国产h片在线观看 | 欧美日韩99 | 国产一区在线免费 | 热久久免费视频精品 | 免费三级在线 | 免费a网 | 婷婷色av| 国产麻豆电影在线观看 | 三级在线国产 | 久久免费激情视频 | 久久天天躁狠狠躁亚洲综合公司 | 久久综合9988久久爱 | 在线免费观看国产视频 | 日韩高清免费电影 | 国产无遮挡又黄又爽馒头漫画 | 国产韩国精品一区二区三区 | 色五月成人 | 国产涩涩在线观看 | 麻豆传媒一区二区 | 亚洲传媒在线 | 国产精品一区二区av麻豆 | 在线视频麻豆 | 免费在线观看av片 | 美州a亚洲一视本频v色道 | 亚洲闷骚少妇在线观看网站 | 日韩欧美视频免费观看 | 成年人毛片在线观看 | 久久99久久99精品免费看小说 | 国产精品福利无圣光在线一区 | 国产a精品 | 国产成人久久av977小说 | 国产不卡在线播放 | 99久热在线精品视频观看 | 狠狠网 | 在线激情小视频 | 午夜精品久久久久久久久久久久久久 | 国产日产精品久久久久快鸭 | 中国一级片免费看 | 99超碰在线观看 | 天天躁天天狠天天透 | 色综合天天视频在线观看 | 久青草电影 | 一区二区三区在线视频观看58 | 亚洲天堂网在线视频 | 夜夜爱av| 精品亚洲免费视频 | 在线日韩视频 | 91福利社在线观看 | 亚洲日本精品 | 国产精品一区二区久久精品 | 久草在线99 | 日韩动漫免费观看高清完整版在线观看 | 天天射综合 | 久久久久久久久久久久久久免费看 | 精品一区精品二区高清 | 亚洲一区美女视频在线观看免费 | 天天干天天操天天做 | 国产视频精品免费播放 | 国产精品久久电影观看 | 丁香六月中文字幕 | 欧美一级特黄高清视频 | 亚洲视频专区在线 | 日韩三级在线 | 999精品视频| 性色av免费观看 | 成人视屏免费看 | 国产三级国产精品国产专区50 | 最近中文字幕完整视频高清1 | 欧美日韩在线精品 | 91精品一区国产高清在线gif | 超碰97免费在线 | 国产精品久久久久久久av电影 | 亚洲欧美视频一区二区三区 | 国产va精品免费观看 | 91免费观看视频在线 | 国产免费视频在线 | 国产中文字幕视频在线观看 | 国产又粗又猛又爽又黄的视频先 | 00av视频| 一区二区三区国 | 色婷婷九月 | 久久久久久久免费观看 | av在线网站大全 | 亚洲精品在线资源 | 国产午夜剧场 | 久久久91精品国产一区二区精品 | 福利一区二区三区四区 | 婷婷色资源 | 日韩电影中文,亚洲精品乱码 | 亚洲欧美国内爽妇网 | 500部大龄熟乱视频 欧美日本三级 | 久久久久久久综合色一本 | 美女网站视频久久 | 精品国模一区二区三区 | 麻豆果冻剧传媒在线播放 | 亚洲激情av| 国产精品18久久久久久不卡孕妇 | 国产亚洲一区 | 天天色天天色天天色 | 亚洲综合五月天 | 国产成人一区三区 | 91色网址 | 91精品国产一区二区在线观看 | 九九热在线播放 | 国产精品av一区二区 | 亚洲成人黄色在线观看 | 国产视频 亚洲视频 | 日韩手机在线 | 亚洲国产美女久久久久 | 午夜精品久久久久久久久久久久 | 久久国产精品99久久人人澡 | 色婷五月天| 亚洲九九九在线观看 | 国产在线91精品 | 精品国产乱码一区二区三区在线 | 激情欧美在线观看 | 精品国产1区2区 | 国产69精品久久app免费版 | 中文在线免费视频 | av高清不卡 | 国产手机精品视频 | 久久国产三级 | 久久激情五月丁香伊人 | av电影在线观看 | 精品二区久久 | 99这里只有精品99 | 国产成人亚洲精品自产在线 | 天天艹天天干天天 | 国产亚洲婷婷免费 | 天天色中文 | 免费福利视频导航 | 久久视频这里只有精品 | 黄色网在线免费观看 | 久久久99精品免费观看乱色 | 成人午夜影院在线观看 | 亚洲资源| 国产一级片毛片 | 免费看污污视频的网站 | 在线观看黄色小视频 | 亚洲另类视频在线 | 免费av大全 | 中文字幕在线观看你懂的 | 中文字幕日本在线 | 久久首页 | 天天综合网在线观看 | 成人av网站在线播放 | 91伊人久久大香线蕉蜜芽人口 | 国产黄色成人 | 在线视频欧美精品 | 欧美精品被 | 久久99深爱久久99精品 | 菠萝菠萝在线精品视频 | av色影院| 国产一区在线看 | 91精品一区二区三区蜜臀 | 欧美精品久久久久性色 | 久久久www成人免费精品张筱雨 | 在线免费视频 你懂得 | 视频一区二区三区视频 | 国产一级特黄毛片在线毛片 | 精品高清美女精品国产区 | 免费在线观看不卡av | 热精品| 国产精品美女www爽爽爽视频 | 亚洲精品高清一区二区三区四区 | 精品国产乱码久久久久久浪潮 | 日韩在线观看三区 | 天天干天天干天天 | 午夜视频亚洲 | 国产区网址 | 蜜臀久久99精品久久久酒店新书 | 日日干日日操 | 久久久wwww| 免费看片在线观看 | 国产夫妻自拍av | 成人97人人超碰人人99 | 免费看黄色大全 | 亚洲精品在线网站 | 久久激情五月婷婷 | 一二三久久久 | 在线观看小视频 | 91中文字幕在线 | 黄色片免费在线 | 日韩中文字幕在线看 | 国产高清在线免费 | 免费日韩 精品中文字幕视频在线 | 国产中文字幕视频在线观看 | 久久精品视频国产 | 亚洲人成免费 | 色网站在线观看 | 久久久久www | 在线精品视频免费播放 | 开心色激情网 | 女人魂免费观看 | 99在线热播精品免费99热 | 国产成人精品午夜在线播放 | 国产一区二区三区免费在线 | 亚洲午夜小视频 | 91字幕 | av网站播放 | 久久福利综合 | 亚洲综合精品在线 | 亚洲欧美视频网站 | 在线观看国产 | 日韩欧美高清一区二区 | 日韩欧美在线综合网 | 超碰九九| 日本高清中文字幕有码在线 | 国产99久久久国产精品成人免费 | 中文字幕日韩一区二区三区不卡 | 国产精品入口a级 | 最近日本中文字幕 | 久久99精品国产麻豆宅宅 | 国产成人在线综合 | 国产伦精品一区二区三区免费 | 免费在线观看国产黄 | 免费a级毛片在线看 | 欧美福利片在线观看 | 成人久久免费视频 | 午夜精品久久久久久 | 欧美另类高潮 | 激情综合五月 | 天天干天天操天天做 | av中文字幕亚洲 | 国产精品成人国产乱一区 | 国产精品久久久久久久久久妇女 | 99视频偷窥在线精品国自产拍 | 久草视频资源 | 国产成人精品一区二区三区网站观看 | 亚洲一区二区天堂 | 欧洲亚洲女同hd | 欧美激情视频一区二区三区免费 | 狠狠干美女 | 日韩中文三级 | 久久久精品久久 | 国产 中文 日韩 欧美 | 亚洲精品午夜一区人人爽 | 四虎小视频 | 久草在线高清视频 | 亚洲精品久久久久久国 | av成人免费在线看 | 91成人黄色| 激情一区二区三区欧美 | 欧美一区二区三区在线视频观看 | 国产精品女人久久久 | 欧美性一级观看 | 69亚洲视频 | 亚洲精品99久久久久中文字幕 | 色99导航 | 免费在线观看视频一区 | 成人9ⅰ免费影视网站 | 日韩一区二区免费在线观看 | 中文字幕在线观看视频网站 | 亚洲91精品在线观看 | 久久人人爽人人爽人人片av免费 | 国产成人精品电影久久久 | 欧美日韩一区二区三区在线观看视频 | 97人人添人澡人人爽超碰动图 | 欧美日韩一区二区在线观看 | 香蕉视频在线播放 | 日本精品午夜 | 国产偷v国产偷∨精品视频 在线草 | 人人爱人人舔 | 亚洲精品女人久久久 | 色爽网站 | 精精国产xxxx视频在线播放 | 激情 一区二区 | 人人看人人做人人澡 | 国产一级做a爱片久久毛片a | 久久视精品 | 成人影片免费 | 992tv人人草| 啪啪动态视频 | 国产一级黄色电影 | 制服丝袜一区二区 | 欧美性成人 | 欧美激情另类文学 | 欧美性久久久久久 | 精品国产一区二区三区男人吃奶 | 欧美日韩免费视频 | 99电影 | 亚洲激情视频在线观看 | 久久99久久99精品免费看小说 | 亚洲精品男人的天堂 | 欧美日韩在线观看一区二区三区 | 久久久在线视频 | 人人天天夜夜 | 亚洲资源在线观看 | 97综合在线| 91影视成人 | 99色视频在线 | 亚洲黄色在线免费观看 | 亚洲精品系列 | 久久免费av电影 | 日韩精品一区二区在线观看 | 中文字幕欧美三区 | 欧美日韩国产精品一区二区亚洲 | 国产一二三精品 | 国产综合91 | 精品久久免费 | 国产小视频免费在线网址 | 99re中文字幕 | 国产精品99久久99久久久二8 | 国产一区在线免费 | 西西444www | 亚洲精品成人av在线 | 不卡的av在线播放 | 夜夜骑天天操 | 伊色综合久久之综合久久 | 99久久99久久精品国产片果冰 | 色播五月激情综合网 | 国产精品99久久久久久大便 | 国产精品久久久久av | 日本色小说视频 | 天天操天天操天天操天天操天天操 | 久久久久久久综合色一本 | 国产精品嫩草影视久久久 | 午夜电影中文字幕 | 中文字幕人成乱码在线观看 | 国产成人精品免费在线观看 | 在线成人小视频 | 性色av免费观看 | 久草视频视频在线播放 | 国产成人777777 | 美女视频黄频 | 婷婷丁香六月 | 丁香五月亚洲综合在线 | 欧美日韩高清不卡 | 日韩欧美一区二区三区黑寡妇 | 国产a视频免费观看 | 日韩av网站在线播放 | 中文区中文字幕免费看 | 9在线观看免费高清完整版在线观看明 | 亚洲一区二区三区精品在线观看 | 国产啊v在线观看 | 成人免费看黄 | av日韩国产 | 91人人澡人人爽 | 婷婷激情五月 | 国产黄色免费在线观看 | 国产精品白浆 | 精品国产欧美一区二区 | 中文字幕在线观看完整版 | 亚洲一区二区三区四区精品 | 六月激情网 | 亚洲日本激情 | 久久综合五月婷婷 | 激情视频一区二区三区 | 四虎成人免费影院 | 99精品免费久久久久久久久 | 97色狠狠| 色综合天天综合网国产成人网 | 久久精品一区二区三区视频 | 成人免费视频视频在线观看 免费 | av一本久道久久波多野结衣 | 亚洲夜夜网 | 久久综合九九 | 91桃色免费视频 | 成人精品在线 | 成人国产精品av | 婷婷精品视频 | 99精品视频在线观看免费 | 国产资源精品 | 男女视频91 | 激情久久影院 | 欧美精品一区在线发布 | 日韩一级成人av | 国产高清网站 | www黄色com| 最近中文字幕高清字幕免费mv | 黄在线免费观看 | 最近中文字幕完整视频高清1 | 在线免费观看一区二区三区 | 欧美aaaxxxx做受视频 | 日韩精品免费一区二区三区 | 六月激情 | 久久99免费| 欧美一区二区三区免费观看 | 极品久久久久 | 日韩另类在线 | 日韩一级成人av | 国产午夜精品理论片在线 | 久久久久在线视频 | 热久久免费视频 | 精品在线不卡 | 播五月综合 | 国产精品久久一区二区三区不卡 | av中文字幕在线免费观看 | 国内小视频在线观看 | 狠狠狠狠狠狠 | 91免费日韩 | 免费在线观看毛片网站 | 日韩欧美一区二区三区视频 | 国产一区二区三区免费在线 | 日韩在线视频网址 | 五月婷社区 | 丁香五月亚洲综合在线 | 国产精品一区二区久久精品爱涩 | 天天干,夜夜爽 | 日韩视频免费观看高清完整版在线 | 波多野结衣在线视频一区 | 亚洲免费在线观看视频 | 视频一区在线播放 | 深爱激情av | 国产精品免费久久久久 | 91大神精品视频在线观看 | 国产精品白浆 | 少妇视频在线播放 | 黄色小说免费在线观看 | 亚洲精品在线一区二区三区 | 成人av免费播放 | 久久久久国产精品免费免费搜索 | 亚洲japanese制服美女 | 成人免费看片98欧美 | 日本公妇色中文字幕 | 午夜精品久久久久久久久久久久 | 国产不卡在线观看 | 97av视频| av在线超碰 | 麻花天美星空视频 | 午夜视频免费播放 | 在线播放精品一区二区三区 | 免费av视屏| 99久久婷婷国产综合亚洲 | 91香蕉国产在线观看软件 | 国产午夜精品福利视频 | 天天天在线综合网 | 久久久www免费电影网 | 久久精品免费看 | 九九免费在线观看视频 | 色偷偷88欧美精品久久久 | 国产成在线观看免费视频 | 国产免费观看高清完整版 | 久久亚洲私人国产精品va | 18女毛片| 99视频这里只有 | 日本精品一区二区三区在线播放视频 | 亚洲永久精品一区 | 伊人国产在线观看 | 友田真希av | 伊人天堂av | 97视频在线观看免费 | 国产美女视频黄a视频免费 久久综合九色欧美综合狠狠 | 国产精品视频不卡 | 韩国在线一区二区 | 国产精品久久久久久av | 国产一区播放 | 最近免费中文字幕大全高清10 | 欧美一级免费黄色片 | 国产精品久久久久久一区二区三区 | 亚洲闷骚少妇在线观看网站 | 美女黄网久久 | 日本黄色大片免费 | 97麻豆视频| 久久久精品 | 91九色蝌蚪国产 | 久艹在线观看视频 | 在线综合 亚洲 欧美在线视频 | 久久一区二区三区超碰国产精品 | 一区二区 精品 | 亚洲天堂网在线视频 | 国产成人一区二区三区在线观看 | 人人澡av| 日本精品视频在线 | 成人午夜黄色影院 | 四虎国产免费 | 精品一区二区三区电影 | 天天插综合 | 99久久99视频只有精品 | 日韩激情三级 | 久久综合给合久久狠狠色 | 日日躁夜夜躁aaaaxxxx | 91精品一区国产高清在线gif | 免费日韩 精品中文字幕视频在线 | 中文字幕日韩在线播放 | 天天舔天天射天天操 | 日日久视频| 91精品国产高清自在线观看 | 免费在线激情电影 | 亚洲精品看片 | 欧美久久久久久久久久久 | 国产一区二区在线免费视频 | 色偷偷av男人天堂 | 精品久久免费看 | 久久精品视频中文字幕 | 日本视频精品 | 亚洲欧美视频 | 久久国产99 | av中文字幕网址 | 久久久久久高潮国产精品视 | 在线视频一二区 | 国产精品久久婷婷六月丁香 | 成人午夜性影院 | 免费色av | 91av电影在线 | 狠狠躁夜夜躁人人爽超碰97香蕉 | 黄色软件在线观看免费 | 免费观看日韩 | 二区三区av | 久久精品老司机 | 精品亚洲国产视频 | 亚洲国产三级在线 | 久草网免费 | 特黄特色特刺激视频免费播放 | 一区二区三区日韩精品 | 天天综合网入口 | 九色porny真实丨国产18 | www.色综合.com| 久久免视频 | 国内精品久久久久影院一蜜桃 | 97视频在线免费 | 日韩黄色一区 | 婷婷六月综合亚洲 | 日韩av不卡播放 | 久久精品影片 | 亚洲成人午夜在线 | 麻豆久久久 |