資源簡介
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.IO;
using System.Linq;
using System.Net;
using System.Net.Sockets;
using System.Text;
using System.Threading;
using System.Threading.Tasks;
using System.Windows.Forms;
namespace SocketTCP
{
//聲明委托
delegate void AddOnLineDelegate(string str, bool bl);
//聲明委托
delegate void RecMsgDelegate(string str);
public partial class FrmTCPServer : Form
{
public FrmTCPServer()
{
InitializeComponent();
myAddOnline = AddOnline;
myRcvMsg = RecMsg;
myFileSave = FileSave;
}
//創建套接字
Socket sock = null;
//創建負責監聽客戶端連接的線程
Thread threadListen = null;
//創建URL與Socket的字典集合
Dictionary<string, Socket> DicSocket = new Dictionary<string, Socket>();
AddOnLineDelegate myAddOnline;
RecMsgDelegate myRcvMsg;
FileSaveDelegate myFileSave;
#region 開始監聽
/// <summary>
/// 開始監聽
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void btn_StartServer_Click(object sender, EventArgs e)
{
//創建負責監聽的套接字,注意其中參數:IPV4 字節流 TCP
sock = new Socket(AddressFamily.InterNetwork, SocketType.Stream, ProtocolType.Tcp);
IPAddress address = IPAddress.Parse(this.txt_IP.Text.Trim());
//根據IPAddress以及端口號創建IPE對象
IPEndPoint endpoint = new IPEndPoint(address, int.Parse(this.txt_Port.Text.Trim()));
try
{
sock.Bind(endpoint);
Invoke(myRcvMsg, "服務器開啟成功!");
MessageBox.Show("開啟服務成功!", "打開服務");
}
catch (Exception ex)
{
MessageBox.Show("開啟服務失敗" ex.Message, "打開服務");
return;
}
sock.Listen(10);
threadListen = new Thread(ListenConnecting);
threadListen.IsBackground = true;
threadListen.Start();
this.btn_StartServer.Enabled = false;
}
#endregion
#region 監聽線程
/// <summary>
/// 監聽線程
/// </summary>
private void ListenConnecting()
{
while (true)
{
//一旦監聽到一個客戶端的連接,將會創建一個與該客戶端連接的套接字
Socket sockClient = sock.Accept();
string client = sockClient.RemoteEndPoint.ToString();
DicSocket.Add(client, sockClient);
Invoke(myAddOnline, client, true);
Invoke(myRcvMsg, client "上線了!");
//開啟接受線程
Thread thr = new Thread(ReceiveMsg);
thr.IsBackground = true;
thr.Start(sockClient);
}
}
#endregion
#region 接收線程
/// <summary>
/// 接收線程
/// </summary>
/// <param name="sockClient"></param>
private void ReceiveMsg(object sockClient)
{
Socket sckclient = sockClient as Socket;
while (true)
{
//定義一個2M緩沖區
byte[] arrMsgRec = new byte[1024 * 1024 * 2];
int length = -1;
try
{
length = sckclient.Receive(arrMsgRec);
}
catch (Exception)
{
string str = sckclient.RemoteEndPoint.ToString();
Invoke(myRcvMsg, str "下線了!");
//從列表中移除URL
Invoke(myAddOnline, str, false);
DicSocket.Remove(str);
break;
}
if (length == 0)
{
string str = sckclient.RemoteEndPoint.ToString();
Invoke(myRcvMsg, str "下線了!");
//從列表中移除URL
Invoke(myAddOnline, str, false);
DicSocket.Remove(str);
break;
}
else
{
if (arrMsgRec[0] == 0)
{
string strMsg = Encoding.UTF8.GetString(arrMsgRec, 1, length-1);
string Msg = "[接收] " sckclient.RemoteEndPoint.ToString() " " strMsg;
Invoke(myRcvMsg, Msg);
}
if (arrMsgRec[0] == 1)
{
Invoke(myFileSave, arrMsgRec,length);
}
}
}
}
#endregion
#region 委托方法體
private void AddOnline(string url, bool bl)
{
if (bl)
{
this.lbOnline.Items.Add(url);
}
else
{
this.lbOnline.Items.Remove(url);
}
}
private void RecMsg(string str)
{
this.txt_Rcv.AppendText(str Environment.NewLine);
}
private void FileSave(byte[] bt, int length)
{
try
{
SaveFileDialog sfd = new SaveFileDialog();
sfd.Filter = "word files(*.docx)|*.docx|txt files(*.txt)|*.txt|xls files(*.xls)|*.xls|All files(*.*)|*.*";
if (sfd.ShowDialog() == DialogResult.OK)
{
string fileSavePath = sfd.FileName;
using (FileStream fs = new FileStream(fileSavePath, FileMode.Create))
{
fs.Write(bt, 1, length - 1);
Invoke(new Action(() => this.txt_Rcv.AppendText("[保存] 保存文件成功" fileSavePath Environment.NewLine)));
}
}
}
catch (Exception ex)
{
MessageBox.Show("保存異常" ex.Message, "保存文件出現異常");
}
}
#endregion
#region 發送消息
/// <summary>
/// 發送消息
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void btn_SendToSingle_Click(object sender, EventArgs e)
{
string StrMsg = this.txt_Send.Text.Trim();
byte[] arrMsg = Encoding.UTF8.GetBytes(StrMsg);
byte[] arrSend = new byte[arrMsg.Length 1];
arrSend[0] = 0;
Buffer.BlockCopy(arrMsg, 0, arrSend, 1, arrMsg.Length);
if (this.lbOnline.SelectedItems.Count == 0)
{
MessageBox.Show("請選擇你要發送的對象!", "發送提示");
return;
}
else
{
foreach (string item in this.lbOnline.SelectedItems)
{
DicSocket[item].Send(arrSend);
string Msg = "[發送] " item " " StrMsg;
Invoke(myRcvMsg, Msg);
}
}
}
#endregion
#region 群發消息
/// <summary>
/// 群發消息
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void btn_SendToAll_Click(object sender, EventArgs e)
{
string StrMsg = this.txt_Send.Text.Trim();
byte[] arrMsg = Encoding.UTF8.GetBytes(StrMsg);
byte[] arrSend = new byte[arrMsg.Length 1];
arrSend[0] = 0;
Buffer.BlockCopy(arrMsg, 0, arrSend, 1, arrMsg.Length);
foreach (string item in this.DicSocket.Keys)
{
DicSocket[item].Send(arrSend);
string Msg = "[發送] " item " " StrMsg;
Invoke(myRcvMsg, Msg);
}
Invoke(myRcvMsg, "[群發] 群發完畢!");
}
#endregion
#region 打開客戶端
/// <summary>
/// 打開客戶端
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void btn_Client_Click(object sender, EventArgs e)
{
FrmTCPClient objFrm = new FrmTCPClient();
objFrm.Show();
}
#endregion
#region 選擇文件
/// <summary>
/// 選擇文件
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void btn_SelectFile_Click(object sender, EventArgs e)
{
OpenFileDialog ofd = new OpenFileDialog();
ofd.InitialDirectory = "D:\\";
if (ofd.ShowDialog() == DialogResult.OK)
{
this.txt_SelectFile.Text = ofd.FileName;
}
}
#endregion
#region 發送文件
/// <summary>
/// 發送文件
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void btn_SendFile_Click(object sender, EventArgs e)
{
if (string.IsNullOrEmpty(txt_SelectFile.Text))
{
MessageBox.Show("請選擇您要發送的文件!", "發送文件提示");
return;
}
string online = this.lbOnline.Text.Trim();
if (string.IsNullOrEmpty(online))
{
MessageBox.Show("請選擇您要發送的對象!", "發送文件提示");
return;
}
using (FileStream fs = new FileStream(txt_SelectFile.Text, FileMode.Open))
{
string filename = Path.GetFileName(txt_SelectFile.Text);
string StrMsg = "發送文件為:" filename;
byte[] arrMsg = Encoding.UTF8.GetBytes(StrMsg);
byte[] arrSend= new byte[arrMsg.Length 1];
arrSend[0] =0;
Buffer.BlockCopy(arrMsg, 0, arrSend, 1, arrMsg.Length);
DicSocket[online].Send(arrSend);
byte[] arrfileSend = new byte[1024 * 1024 * 2];
int length = fs.Read(arrfileSend, 0, arrfileSend.Length);
byte[] arrfile = new byte[length 1];
arrfile[0] = 1;
Buffer.BlockCopy(arrfileSend, 0, arrfile, 1, length);
DicSocket[online].Send(arrfile);
}
}
#endregion
}
}
代碼片段和文件信息
using?System;
using?System.Collections.Generic;
using?System.ComponentModel;
using?System.Data;
using?System.Drawing;
using?System.IO;
using?System.Linq;
using?System.Net;
using?System.Net.Sockets;
using?System.Text;
using?System.Threading;
using?System.Threading.Tasks;
using?System.Windows.Forms;
namespace?SocketTCP
{
????delegate?void?FileSaveDelegate(byte[]?btint?length);
????public?partial?class?FrmTCPClient?:?Form
????{
????????public?FrmTCPClient()
????????{
????????????InitializeComponent();
????????????MyFileSave?=?FileSave;
????????}
????????//Socket對象
????????Socket?sockClient?=?null;
????????//接收線程
????????Thread?thrClient?=?null;
????????//運行標志位
????????private?bool?IsRunning?=?true;
????????//文件保存委托對象
????????FileSaveDelegate?MyFileSave
?屬性????????????大小?????日期????時間???名稱
-----------?---------??----------?-----??----
?????目錄???????????0??2018-11-13?21:56??Socket\.vs\
?????目錄???????????0??2018-11-13?21:46??Socket\.vs\Socket\
?????目錄???????????0??2018-11-13?21:56??Socket\.vs\Socket\v15\
?????目錄???????????0??2018-11-13?21:46??Socket\.vs\Socket\v15\Server\
?????目錄???????????0??2018-11-13?21:56??Socket\.vs\Socket\v15\Server\sqlite3\
?????目錄???????????0??2018-11-13?21:56??Socket\.vs\SocketTCP\
?????目錄???????????0??2018-11-13?21:56??Socket\.vs\SocketTCP\v15\
?????文件???????53248??2020-04-09?21:29??Socket\.vs\SocketTCP\v15\.suo
?????目錄???????????0??2018-11-13?21:56??Socket\.vs\SocketTCP\v15\Server\
?????目錄???????????0??2018-11-13?21:56??Socket\.vs\SocketTCP\v15\Server\sqlite3\
?????文件???????????0??2018-11-13?21:56??Socket\.vs\SocketTCP\v15\Server\sqlite3\db.lock
?????文件??????598016??2018-11-18?01:07??Socket\.vs\SocketTCP\v15\Server\sqlite3\storage.ide
?????文件???????32768??2020-04-09?21:28??Socket\.vs\SocketTCP\v15\Server\sqlite3\storage.ide-shm
?????文件?????4136512??2020-03-30?20:55??Socket\.vs\SocketTCP\v15\Server\sqlite3\storage.ide-wal
?????目錄???????????0??2020-04-11?22:34??Socket\Socket\
?????文件?????????189??2018-11-13?21:46??Socket\Socket\App.config
?????目錄???????????0??2020-04-11?22:34??Socket\Socket\bin\
?????目錄???????????0??2020-04-11?22:34??Socket\Socket\bin\Debug\
?????文件???????22016??2020-04-05?23:11??Socket\Socket\bin\Debug\SocketTCP.exe
?????文件?????????189??2018-11-13?21:46??Socket\Socket\bin\Debug\SocketTCP.exe.config
?????文件???????50688??2020-04-05?23:11??Socket\Socket\bin\Debug\SocketTCP.pdb
?????目錄???????????0??2018-11-13?21:46??Socket\Socket\bin\Release\
?????文件????????7712??2018-11-18?01:27??Socket\Socket\FrmTCPClient.cs
?????文件????????9972??2018-11-18?00:16??Socket\Socket\FrmTCPClient.Designer.cs
?????文件????????5817??2018-11-18?00:16??Socket\Socket\FrmTCPClient.resx
?????文件???????11255??2018-11-18?01:27??Socket\Socket\FrmTCPServer.cs
?????文件???????11514??2018-11-17?23:31??Socket\Socket\FrmTCPServer.Designer.cs
?????文件????????5817??2018-11-17?23:31??Socket\Socket\FrmTCPServer.resx
?????目錄???????????0??2018-11-13?21:46??Socket\Socket\obj\
?????目錄???????????0??2020-04-11?22:34??Socket\Socket\obj\Debug\
?????文件????????1443??2018-11-13?22:52??Socket\Socket\obj\Debug\DesignTimeResolveAssemblyReferences.cache
............此處省略26個文件信息
- 上一篇:C#高級編程 第11版 源碼
- 下一篇:創建文檔,刪除文檔案例程序
評論
共有 條評論
相關資源
- C#編成Modbus TCP連接PLC寄存器讀取、寫
- C#調用VLC 多窗體播放功能
- Modbus_TCP .net C# 通信
- DotNetty系列六:將服務端和客戶端改為
- 基于TCP的 modbus , C#源碼
- c# 實現pcap格式解析,方便Wireshark抓包
- C#版海康客戶端API封裝
- C#通信TCP/IP server client 簡單
- c# TCPServer 源代碼
- C#的DNS協議完整實現代碼
- C# TCP助手異步通訊
- C# Socket多客戶端異步通信
- C# 一個完整的客戶端和服務器端
- TCP/IP通信c#例程
- TCP多個客戶端與服務端數據傳輸源碼
- C#簡單TCP
- C#窗體基于TCP的Socket多線程通信
- FTP客戶端C#實現
- 工業OPC客戶端讀取,并存SQL
- C# tcp 多線程聊天室
- C# 異步 SOCKET 服務和客戶端
- FTP課程設計(服務端+客戶端) 源碼
- C# 2015最新版NMODBUS4.0源碼支持TCP/IPRT
- 遠程控制服務端/客戶端
- C#寫的控制臺NTP服務端以及winform的N
- modbus tcp源碼(C#)
- C#ModbusTCP客戶端
- 通過MODBUS TCP讀寫PLC源碼
- C#開發的網絡調試助手包括TCP和UDP客戶
- C# 利用Renci庫來實現ssh客戶端,可以執