• 学习笔记之网络编程


    学习笔记之网络编程

    网络编程入门

    网络

    • 计算机网络:
      • 指将地理位置不同的具有独立功能的多台计算机及其外部设备,通过通信线路连接起来,在网络操作系统,网络管理软件及网络通信协议的管理和协调下,实现资源共享和信息传递的计算机系统。
    • 网络编程:
      • 在网络通信协议下,实现网络互联的不同计算机上运行的程序间可以进行数据交换

    网络编程三要素

    • IP地址:
      • 要想让网络中的计算机能够互相通信,必须为每台计算机指定一个标识,通过这个表示好来指定要接收数据的计算机和识别发送到计算机,而IP地址就是标识号,也就是设备的表示
    • 端口:
      • 网络的通信,本质上是两个应用程序的通信。每台计算机都有很多的应用程序,那么就在网络信时,如何区分这些应用程序呢?如果说IP地址可以唯一标识网络中的设备,那么端口号就可以唯一标识设备中的应用程序了。也就是应用程序的标识。
    • 协议
      • 通过计算机网络可以使多台计算机实现连接,位于同一个网络中的计算机在进行连接和通信时需要遵守一定的规则,这就像汽车一定要遵守交通规则一样。在计算机网络中,这些连接和通信的规则被称为网络通信协议,它对数据的传输格式、传输速率、传输步骤等做了统一规定,通信双方必须同时遵守才能完成数据交换。常见的协议又UDP协议和TCP协议。

    IP地址

    • IPv4:是给每个连接在网络上的主机分配一个32bit地址。按照TCP/IP规定,IP地址用二进制来表示,每个IP地址长32bit,也就是4个字节。例如一个采用二进制形式的IP地址时"11000000 10101000 00000001 01000010",这么长的地址,处理起来太费劲。为了方便实验,IP地址经常被写成十进制的形式,中间使用符号“.”分隔不同的字节。于是,上面的IP地址可以表示为"192.168.1.66"。IP地址的这种表示法叫做"点分十进制表示法",这显然比1和0容易记忆得多。
    • IPv6:由于互联网的蓬勃发展,IP地址的需求量愈来愈大,但是网络地址资源有限,使得IP的分配越发紧张。为了扩大地址空间,通过IPv6重新定义地址空间,采用128位地址长度,每16个字节一组,分成8组十六进制数,这样就解决了网络地址资源数量不够的问题。

    InetAddress的使用:

    为了方便对IP地址的获取和操作,JAVA提供了一个类InetAddress供我们使用
    InetAddress:此类表示Internet协议(IP)地址
    方法:

    • static InetAddress getByName(String host) 确定主机名称的IP地址。主机名称可以是机器名称,也可以是IP地址
    • String getHostName() 获取此IP地址的主机名
    • String getHostAddress() 返回文本显示中的IP地址字符串
    import java.net.InetAddress;
    import java.net.UnknownHostException;
    
    public class Demo {
        public static void main(String[] args) throws UnknownHostException {
        InetAddress ia = InetAddress.getByName("localHost");
            String hostName = ia.getHostName();
    
            String hostAddress = ia.getHostAddress();
    
            System.out.println("主机名"+hostName);
            System.out.println("ip地址:"+hostAddress);
        }
    }
    

    端口

    • 端口:设备上应用的唯一标识
    • 端口号:两个字节表示的整数,它的取值范围是0-65535。其中,0-1023之间的端口好用于一些知名网络服务和应用,普通的应用程序需要使用1024以上的端口号,如果端口号呗另外一个服务或应用所占用,会导致当前程序启动失败。

    协议

    • 协议:计算机网络,连接和通信的规则呗称为网络通信协议
    • UDP协议
      • 用户数据报协议(User Datagram Protocol)
      • UDP是无连接通信协议,即在数据传输时,数据的发送端和接收端不建立逻辑连接。简单来说,当一台计算机向另外一台计算机发送数据时,发送端不会确认接收端是否存在,就会发出数据,同样接收端在收到数据时,也不会翔发送端反馈是否接收到数据
      • 由于使用UDP协议消耗资源小,通信效率高,所以通信都会用于音频,视频和数据的传输。传输重要信息时不建议使用UDP协议。
    • TCP协议
      • 传输控制协议(Transmission Control Protocol)
      • TCP协议是面向连接的通信协议,即传输数据前,在发送端和连接段建立逻辑连接,然后再传输数据他提供了两台计算机间可靠无差错的数据传输。在TCP连接中必须要明确客户端与服务器端,由客户端向服务端发出连接请求,每次连接的创建都需要经过“三次握手”
      • 三次握手:TCP协议中,在发送数据的准备阶段,客户端与服务器端之间的三次交互,以保证连接的可靠
        1. 第一次握手,客户端向服务器端发出连接请求,等待服务器确认
        2. 第二次握手,服务器端向客户端回送一个相应,通知客户端收到连接请求
        3. 第三次握手,客户端再次向服务器端发送确认信息,确认连接
      • 完成三次握手,连接jianli以后,客户端和服务器就可以开始进行数据传输了。由于这种面向连接的特性,TCP协议可以保证传输数据的安全,所以应用十分广泛。例如上传文件、下载文件、浏览网页等。

    UDP通信程序

    UDP通信原理

    UDP协议是一种不可靠的网络协议,它在通信的两端各建立一个Socket对象,但是这两个Socket只发送,接收数据的对象因此对于基于UDP协议的通信双方而言,没有所谓的客户端和服务器的概念,JAVA提供了DatagramSocket类作为基于UDP协议的Socket

    UDP发送数据

    • 发送数据的步骤
      1. 创建发送端的Socket对象
      2. 创建数据,并把数据打包
      3. 调用DatagramSocket对象的方法发送数据
      4. 关闭发送端
    import java.io.IOException;
    import java.net.DatagramPacket;
    import java.net.DatagramSocket;
    import java.net.InetAddress;
    
    public class SendDemo {
        public static void main(String[] args) throws IOException {
            //1. 创建发送端的Socket对象(DatagramSocket)
            //构造数据报套接字并将其绑定到本地主机上的任何可用端口。
            DatagramSocket ds = new DatagramSocket();
    
            //2. 创建数据,并把数据打包
            //DatagramPacket​(byte[] buf, int length, InetAddress address, int port) 构造一个数据包,
            // 发送长度为 length的数据包到指定主机上的指定端口号。
    
            byte [] b = "hello,UDP".getBytes();
            DatagramPacket dp = new DatagramPacket(b,b.length, InetAddress.getByName("127.0.0.1"),10086);   
    
            //. 调用DatagramSocket对象的方法发送数据
            //void send​(DatagramPacket p) 从此套接字发送数据报包。
            ds.send(dp);
    
            //4. 关闭发送端
            //void close​() 关闭此数据报套接字。
            ds.close();
        }
    }
    

    UDP接收数据

    • 接收数据的步骤
      1. 创建接收端的Socket对象(DatagramSocket)
      2. 创建一个数据包,用于接收数据
      3. 调用DatagramSocket对象的方法接收数据
      4. 解析数据包,并把数据在控制台显示
      5. 关闭接收端
    import java.io.IOException;
    import java.net.DatagramPacket;
    import java.net.DatagramSocket;
    public class ReceiveDemo {
        public static void main(String[] args) throws IOException {
            //1. 创建接收端的Socket对象(DatagramSocket)
            //DatagramSocket​(int port) 构造数据报套接字并将其绑定到本地主机上的指定端口。
            DatagramSocket ds = new DatagramSocket(10086);
    
            //2. 创建一个数据包,用于接收数据
            //DatagramPacket​(byte[] buf, int length) 构造一个 DatagramPacket用于接收长度为 length数据包。
            byte [] b = new byte[1024];
            DatagramPacket dp = new DatagramPacket(b,b.length);
    
            //3. 调用DatagramSocket对象的方法接收数据
            //void receive​(DatagramPacket p) 从此套接字接收数据报包。
            ds.receive(dp);
    
            //4. 解析数据包,并把数据在控制台显示
            //byte[] getData​() 返回数据缓冲区。
            byte[] data = dp.getData();
            int len = dp.getLength();
            String s = new String(data,0,len);
            System.out.println("数据:"+s);
    
            //5. 关闭接收端
            ds.close();
        }
    }
    

    TCP通信程序

    TCP通信原理

    TCP通信协议是一种可靠的网络协议,它在通信的两端各建立一个Socket对象,从而在通信的两端形成网络虚拟链路,一旦建立了虚拟的网络链路,两端的程序就可以通过虚拟链路进行通信。

    JAVA对基于TCP协议的网络提供了良好的封装,使用Socket对象来代表两端的通信端口,并通过Socket产生IO流来进行网络通信。
    JAVA为客户端提供了Socket类,为服务器提供了ServerSocket类。

    TCP发送数据

    步骤
    1. 创建客户端的Socket对象(Socket)
      • Socket​(String host, int port)
    2. 获取输出流,写数据
      • OutputStream getOutputStream​()
    3. 释放资源
    import java.io.IOException;
    import java.io.OutputStream;
    import java.net.InetAddress;
    import java.net.Socket;
    public class SendDeom {
        public static void main(String[] args) throws IOException {
            //1. 创建客户端的Socket对象(Socket)
            //Socket​(InetAddress address, int port) 创建流套接字并将其连接到指定IP地址的指定端口号。
    //        Socket s = new Socket(InetAddress.getByName("172.0.0.1"),12345);
    
            //Socket​(String host, int port) 创建流套接字并将其连接到指定主机上的指定端口号。
            Socket s = new Socket("172.0.0.1",12345);
    
            //2. 获取输出流,写数据
            //OutputStream getOutputStream​() 返回此套接字的输出流。
            OutputStream os = s.getOutputStream();
            os.write("hello,TCP,你好".getBytes());
    
            //3. 释放资源
            s.close();
        }
    }
    

    TCP接收数据

    步骤
    1. 创建服务器端的Socket对象(ServerSocket)
      • ServerSocket​(int port)
    2. 监听客户端连接,返回一个Socket对象
      • Socket accept​()
    3. 获取输入流,读数据,并把数据显示在控制台
      • InputStream getInputStream​()
    4. 释放资源
    import java.io.IOException;
    import java.io.InputStream;
    import java.net.ServerSocket;
    import java.net.Socket;
    public class ReciveDemo {
        public static void main(String[] args) throws IOException {
            //1. 创建服务器端的Socket对象(ServerSocket)
            //ServerSocket​(int port) 创建绑定到指定端口的服务器套接字。
            ServerSocket ss = new ServerSocket(10010);
    
            //2. 监听客户端连接,返回一个Socket对象
            Socket s = ss.accept();
            //3. 获取输入流,读数据,并把数据显示在控制台
            //InputStream getInputStream​() 返回此套接字的输入流。
            
            InputStream is = s.getInputStream();
            byte [] b = new byte[1024];
            int len = is.read(b);
            String data = new String(b,0,len);
            System.out.println("数据是:"+data);
    //        while ((len = is.read(b))!= -1){
    //            System.out.println("数据:"+new String(b,0,len));
    //        }
            //4. 释放资源
            ss.close();
    
        }
    }
    

  • 相关阅读:
    Android App上架流程
    php字符串操作
    SpringBoot配置MongoDB多数剧源
    Spring boot使用influxDB总结
    Spring boot配置MongoDB以及Morphia踩坑记录
    使用Kubernetes的java-client实现Deployment的部署及更新操作
    Golang循环中调用go func参数异常分析
    git tag本地删除以及远程删除
    SpringBoot之GZip压缩,HTTP/2,文件上传,缓存配置
    Java服务使用Redis实现分布式全局唯一标识
  • 原文地址:https://www.cnblogs.com/Hz-z/p/13025900.html
Copyright © 2020-2023  润新知