转 mobile Socket连接PC 的类

using  System;
using  System.Collections.Generic;
using  System.Text;
using  System.Net;
using  System.Threading;
using  System.Net.Sockets;
using  System.Windows.Forms;

namespace  MobileSocketCTL
{
    
//Client
    class MobileSocketClient : Control
    
{
        
private IPAddress hostIPAddress;
        
private IPEndPoint Server;
        
private Socket sock;
        
private const int BufferSize = 256;
        
private byte[] buffer = new byte[BufferSize];
        
private static ManualResetEvent connectDone = new ManualResetEvent(false);
        
private static ManualResetEvent sendDone = new ManualResetEvent(false);

        
public string ServerIP, ServerPort;
        
private string ShakeCode;

        
public delegate void RevdataEvent(int DataLength, string DataBuf);
        
public RevdataEvent ClientRevEvent;

        
public MobileSocketClient()
        
{
        }


        
public MobileSocketClient(string SIP, string SPort)
        
{
            ServerIP 
= SIP;
            ServerPort 
= SPort;
        }


        
public bool ClientConnectServer(String SendShakeCode)
        
{
            ShakeCode 
= SendShakeCode.Trim();
            
try
            
{
                hostIPAddress 
= IPAddress.Parse(ServerIP.Trim());
            }

            
catch
            
{
                
return false;
            }

            
try
            
{
                Server 
= new IPEndPoint(hostIPAddress, Int32.Parse(ServerPort));
                sock 
= new Socket(AddressFamily.InterNetwork, SocketType.Stream, ProtocolType.Tcp);
                sock.BeginConnect(Server, 
new AsyncCallback(ConnectCallBack), sock);
            }

            
catch (Exception ee)
            
{
                
return false;
            }

            
return true;
        }

        
private void ConnectCallBack(IAsyncResult ar)
        
{
            
try
            
{
                Socket client 
= (Socket)ar.AsyncState; //获取状态
                client.EndConnect(ar);
                
try
                
{
                    
byte[] byteData = Encoding.ASCII.GetBytes(ShakeCode);
                    sock.BeginSend(byteData, 
0, byteData.Length, 0new AsyncCallback(SendCallBack), sock);
                }

                
catch (Exception ee)
                
{
                }

                Thread thread 
= new Thread(new ThreadStart(ThreadProc));
                thread.Start();   
//开始接收数据线程
                connectDone.Set();  //将指定事件的状态设置为终止。
            }

            
catch
            
{
            }

        }


        
private void SendCallBack(IAsyncResult ar)
        
{
            
try
            
{
                Socket client 
= (Socket)ar.AsyncState;
                sendDone.Set();
            }

            
catch (Exception ee)
            
{
            }

        }


        
private void ThreadProc()
        
{
            
try
            
{
                sock.BeginReceive(buffer, 
0, BufferSize, 0new AsyncCallback(ReceiveCallBack), sock);
            }

            
catch (Exception ee)
            
{
            }

        }


        
private void ReceiveCallBack(IAsyncResult ar)
        
{
            
try
            
{
                Socket client 
= (Socket)ar.AsyncState;
                
int bytesRead = client.EndReceive(ar);//结束挂起的异步读取。返回接收到的字节数。
                StringBuilder sb = new StringBuilder();
                sb.Append(Encoding.ASCII.GetString(buffer, 
0, bytesRead));//储存数据
                string content = sb.ToString(); //转换为字符串
                if (ClientRevEvent != null)
                
{
                    
//RevdataEvent d = new RevdataEvent(ClientRevEvent);
                    this.Invoke(ClientRevEvent, new object[] { bytesRead, content });
                }

                sb.Remove(
0, content.Length);   //清除sb内容
                client.BeginReceive(buffer, 0, BufferSize, 0new AsyncCallback(ReceiveCallBack), client);
            }

            
catch (Exception ee)
            
{
            }

        }


        
public bool ClientSendText(string SendText)
        
{
            
try
            
{
                
string strSend = SendText.Trim();
                Byte[] ByteSend 
= Encoding.ASCII.GetBytes(strSend);
                
//sock.Send(ByteSend);
                sock.BeginSend(ByteSend, 0, ByteSend.Length, 0new AsyncCallback(SendCallBack), sock);
            }

            
catch
            
{
                
return false;
            }


            
return true;
        }


        
public bool ClientStopServer()
        
{
            
try
            
{
                sock.Close();
                ClientRevEvent 
= null;
            }

            
catch
            
{
                
return false;
            }

            
return true;
        }


        
~MobileSocketClient()
        
{
            ClientStopServer();
        }

    }


    
//Server
    class MobileSocketServer : Control
    
{
        
private IPAddress hostIPAddress;
        
private IPEndPoint Server;
        
private Socket listeningSocket;
        
private Socket handler;
        
private Socket mySocket;
        
private static ManualResetEvent Done = new ManualResetEvent(false);
        
private const int BufferSize = 256;
        
private byte[] buffer = new byte[BufferSize];
        
string  IP,port;
        
string SetupOK;
        
public delegate void RevdataEvent(int DataLength, string DataBuf);
        
public RevdataEvent ServerRevEvent;

        
public MobileSocketServer(string ServerIP, string ServerPort)
        
{
            IP 
= ServerIP;
            port 
= ServerPort;
        }


        
public bool SetupServer(string SetupOKStr)
        
{
            SetupOK 
= SetupOKStr;
            
try
            
{
                hostIPAddress 
= IPAddress.Parse(IP);
            }

            
catch {
                
return false;
            }

            
try
            
{  //通过组合服务的主机 IP 地址和端口号,IPEndPoint 类形成到服务的连接点。
                Server = new IPEndPoint(hostIPAddress, Int32.Parse(port));
                
// Create a socket object to establish a connection with the server
                listeningSocket = new Socket(AddressFamily.InterNetwork, SocketType.Stream, ProtocolType.Tcp);
                listeningSocket.Bind(Server); 
//绑定该主机端口
                listeningSocket.Listen(50); //监听端口,等待客户端连接请求。50是队列中最多可容纳的等待接受的传入连接数
                
//Accept 以同步方式从侦听套接字的连接请求队列中提取第一个挂起的连接请求,然后创建并返回新的 Socket。
                
//mySocket=listeningSocket.Accept();
                
//一个进程可以创建一个或多个线程以执行与该进程关联的部分程序代码。使用 ThreadStart 委托指定由线程执行的程序代码。
                Thread thread = new Thread(new ThreadStart(ThreadProc));
                thread.Start();
            }

            
catch (Exception ee) {
                
return false;
            }

            
return true;

        }

        
private void ThreadProc()
        
{
            
while (true)
            
{
                Done.Reset(); 
//将状态设为非终止
                listeningSocket.BeginAccept(new AsyncCallback(AcceptCallBack), listeningSocket);//开始一个异步操作来接受一个传入的连接尝试
                Done.WaitOne(); //阻塞当前线程,直到当前线程收到信号。
            }

        }


        
private void AcceptCallBack(IAsyncResult ar)//ar表示异步操作的状态。
        {
            Done.Set();
//设为终止
            mySocket = (Socket)ar.AsyncState; //获取状态
            handler = mySocket.EndAccept(ar);   //异步接受传入的连接尝试,并创建新的 Socket 来处理远程主机通信,获取结果
            try
            
{
                
byte[] byteData = Encoding.ASCII.GetBytes(SetupOK);
                
//调用SendCallBack异步发送数据,
                handler.BeginSend(byteData, 0, byteData.Length, 0new AsyncCallback(SendCallBack), handler);
            }

            
catch (Exception ee) {
            }


            Thread thread 
= new Thread(new ThreadStart(ThreadRev));
            thread.Start();
        }


        
private void SendCallBack(IAsyncResult ar)
        
{
            
try
            
{
                handler 
= (Socket)ar.AsyncState;  //获取状态
                int bytesSent = handler.EndSend(ar);//结束挂起的异步发送,返回向 Socket 发送的字节数
            }

            
catch { }
        }


        
private void ThreadRev()
        
{
            handler.BeginReceive(buffer, 
0, BufferSize, 0new AsyncCallback(ReadCallBack), handler);
        }


        
public void ReadCallBack(IAsyncResult ar)
        
{
            
try
            
{
                
int bytesRead = handler.EndReceive(ar); //结束挂起的异步读取,返回接收到的字节数。
                StringBuilder sb = new StringBuilder();   //接收数据的可变字符字符串,在通过追加、移除、替换或插入字符而创建它后可以对它进行修改。
                sb.Append(Encoding.ASCII.GetString(buffer, 0, bytesRead));//追加字符串
                string content = sb.ToString();   //转换为字符串
                sb.Remove(0, content.Length);   //清除sb内容
                if (ServerRevEvent != nullthis.Invoke(ServerRevEvent, new object[] { bytesRead, content });
                handler.BeginReceive(buffer, 
0, BufferSize, 0new AsyncCallback(ReadCallBack), handler);
            }

            
catch
            
{

            }

        }


        
public bool ServerSendText(string SendData)
        
{
            
try
            
{
                Byte[] ByteSend 
= Encoding.ASCII.GetBytes(SendData);
                handler.BeginSend(ByteSend, 
0, ByteSend.Length, 0new AsyncCallback(SendCallBack), handler);
            }

            
catch {
                
return false;

            }

            
return true;
        }


        
public bool ServerStopServer()
        
{
            
try
            
{
                listeningSocket.Close();
                ServerRevEvent 
= null;
            }

            
catch
            
{
                
return false;
            }

            
return true;
        }


        
~MobileSocketServer()
        
{
            ServerStopServer();
        }

    }

}

 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
提供的源码资源涵盖了Java应用等多个领域,每个领域都包含了丰富的实例和项目。这些源码都是基于各自平台的最新技术和标准编写,确保了在对应环境下能够无缝运行。同时,源码中配备了详细的注释和文档,帮助用户快速理解代码结构和实现逻辑。 适用人群: 适合毕业设计、课程设计作业。这些源码资源特别适合大学生群体。无论你是计算机相关专业的学生,还是对其他领域编程感兴趣的学生,这些资源都能为你提供宝贵的学习和实践机会。通过学习和运行这些源码,你可以掌握各平台开发的基础知识,提升编程能力和项目实战经验。 使用场景及目标: 在学习阶段,你可以利用这些源码资源进行课程实践、课外项目或毕业设计。通过分析和运行源码,你将深入了解各平台开发的技术细节和最佳实践,逐步培养起自己的项目开发和问题解决能力。此外,在求职或创业过程中,具备跨平台开发能力的大学生将更具竞争力。 其他说明: 为了确保源码资源的可运行性和易用性,特别注意了以下几点:首先,每份源码都提供了详细的运行环境和依赖说明,确保用户能够轻松搭建起开发环境;其次,源码中的注释和文档都非常完善,方便用户快速上手和理解代码;最后,我会定期更新这些源码资源,以适应各平台技术的最新发展和市场需求。 所有源码均经过严格测试,可以直接运行,可以放心下载使用。有任何使用问题欢迎随时与博主沟通,第一时间进行解答!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值