.Net网络编程——使用TcpClient与TcpListener建立客户端与服务端连接-阿里云开发者社区

开发者社区> soledad_lhc> 正文

.Net网络编程——使用TcpClient与TcpListener建立客户端与服务端连接

简介:               一,.NET中如何实现建立连接                         在网络中,我们可以通过IP地址唯一定位一台主机,而在主机中,我们要确定收到的数据包发给谁,可以通过端口号,端口号的作用简单说就是不至于使你要发给QQ好友的消息数据包被错误发到了你的OC程序上。
+关注继续查看



           

  一,.NET中如何实现建立连接



                        在网络中,我们可以通过IP地址唯一定位一台主机,而在主机中,我们要确定收到的数据包发给谁,可以通过端口号,端口号的作用简单说就是不至于使你要发给QQ好友的消息数据包被错误发到了你的OC程序上。


              通常,我们把发起连接的那一端称为客户端,这是主动的一方;而静默等待连接到来的那一端作为服务端。这个概念是比较相对的。


              在.Net中,我们可以使用TcpClient来建立连接,使用TcpListener来监听连接,从而在客户端和服务端建立连接。



二,服务端建立监听


                   

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Net;
using System.Net.Sockets;

namespace 服务端对端口进行侦听
{
    class Program
    {
        static void Main(string[] args)
        {
            Console.WriteLine("服务端正在运行呀。。。");
            //IPAddress ip = new IPAddress(new byte[] { 127, 0, 0, 1 });
           // IPAddress ip = IPAddress.Parse("127.0.0.1");
            IPAddress ip = Dns.GetHostEntry(Dns.GetHostName()).AddressList[0]; //同上
            TcpListener listener = new TcpListener(ip, 8500);  //选择侦听端口

            listener.Start();//开始侦听

            Console.WriteLine("开始侦听啦。。。");
            Console.WriteLine("\n\n输入\"Q\"键退出。。");
            ConsoleKey key;
            do
            {
                key = Console.ReadKey(true).Key;

            } while (key!=ConsoleKey.Q);
        }
    }
}


   启动程序后,使用netstat -a查看端口情况:





     


   发现端口正在listening....




三,客户端与服务端建立连接



         在服务端侦听端口打开的情况下,就可以与服务端端口进行连接啦:



using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Net;
using System.Net.Sockets;

namespace 服务端与客户端的连接
{
    class Program
    {
        static void Main(string[] args)
        {

            #region 客户端与服务端连接

                //Console.WriteLine("客户端启动啦啦啦。。");
                //TcpClient client = new TcpClient();

                //try
                //{
                //    //与服务器进行连接
                //    client.Connect(IPAddress.Parse("127.0.0.1"), 8500);

                //}
                //catch (Exception ex)
                //{
                //    Console.WriteLine(ex.Message);
                //    return;
                //}

                ////打印连接到服务端的信息
                //Console.WriteLine("服务端连接成功啦。。本地IP端口为:{0}------>服务IP端口为:{1}", client.Client.LocalEndPoint, client.Client.RemoteEndPoint);//client.Client获得到套接字

            #endregion

            #region 多个客户端与服务端的连接

                Console.WriteLine("客户端启动啦啦啦啦。。。。");
                TcpClient client;

                for (int i = 0; i < 2; i++)
                {
                    try
                    {
                        client = new TcpClient();//每创建一个新的TcpClient便相当于创建了一个新的套接字Socket与服务端通信,.Net会自动为这个套接字分配 一个端口号。
                        //与服务器建立连接
                        client.Connect(IPAddress.Parse("127.0.0.1"), 8500);

                    }
                    catch (Exception ex)
                    {

                        Console.WriteLine(ex.Message);
                        Console.WriteLine(ex.StackTrace);
                        return;
                    }
                    Console.WriteLine("服务端连接成功啦。。本地IP端口为:{0}------>服务IP端口为:{1}", client.Client.LocalEndPoint, client.Client.RemoteEndPoint);//client.Client获得到套接字
                }

            #endregion


        }
    }
}



   连接时,主要是使用TcpClient对象,传入要连接的服务端的IP和端口号,就像发邮件那样,只要选择好存在的发件人,就能发送那样。




       


           

                    

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
.NET数据库编程求索之路--10.使用EF实现(划分输入验证层)
10.使用EF实现(划分输入验证层) 注:使用partial类来实现输入验证逻辑的分层。   源码下载: /Files/SummerRain/NetDbDevRoad/a使用EF实现4划分输入验证层.
576 0
服务端编程示例|学习笔记
快速学习服务端编程示例
40 0
.NET数据库编程求索之路--7.使用ADO.NET实现(工厂模式-实现多数据库切换)(2)
7.使用ADO.NET实现(工厂模式-实现多数据库切换)(2)     7.3 数据访问层工厂HomeShop.DALFactory      1 using System; 2 using System.
891 0
asp.net 连接新浪微博
资料收集 1 官方 http://open.weibo.com/sdk/js http://open.weibo.com/widget/js#connect   2 教程 http://zzk.
714 0
【转】ADO.Net连接DBF文件
Shapefile属性表是dbf格式的,开源项目SharpMap提供了二进制读取dbf的方法,但是如果想查询的话,不用数据库还真不好做。ADO.Net的OLE DB和ODBC都可以连接、查询dbf。
904 0
.NET数据库编程求索之路--7.使用ADO.NET实现(工厂模式-实现多数据库切换)(4)
7.使用ADO.NET实现(工厂模式-实现多数据库切换)(4) 7.7 业务逻辑层HomeShop.BLL OrderBiz.cs View Code  1 using System; 2 using System.
776 0
+关注
soledad_lhc
csdn博客:http://blog.csdn.net/lhc1105
508
文章
0
问答
文章排行榜
最热
最新
相关电子书
更多
《2021云上架构与运维峰会演讲合集》
立即下载
《零基础CSS入门教程》
立即下载
《零基础HTML入门教程》
立即下载