Java学习总结--040网络编程

2023-10-07 18:50

本文主要是介绍Java学习总结--040网络编程,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1 计算机网络
是指将地理位置不同的具有独立功能的多台计算机及其外部设备,通过通信线路连接起来,在网络操作系统,网络管理软件及网络通信协议的管理和协调下,实现资源共享和信息传递的计算机系统。

2 网络编程
就是用来实现网络互连的不同计算机上运行的程序间可以进行数据交换。

3 网络编程三要素
IP
每个设备在网络中的唯一标识
每台网络终端在网络中都有一个独立的地址,我们在网络中传输数据就是使用这个地址。
IP地址的分类:IPv4 & IPv6
IPv4
IPv4:4个字节组成,4个0-255。大概42亿,30亿都在北美,亚洲4亿。2011年初已经用尽,IP格式: 192.168.1.168。
测试网络连接 ping 192.168.1.68
本地回路地址:ping 127.0.0.1(测试网卡有没插好)
广播地址:255.255.255.255
IP地址也分公网地址(万维网使用)和私有地址(局域网使用),192.168.开头的就是私有址址
IPv6:8组,每组4个16进制数。1a2b:0000:aaaa:0000:0000:0000:aabb:1f2f(IPv6暂先不用掌握)

Port端口
端口号是每个程序在设备上的唯一标识
每个网络程序都需要绑定一个端口号,传输数据的时候除了确定发到哪台机器上,还要明确发到哪个程序,端口号范围从0-65535
编写网络应用就需要绑定一个端口号,尽量使用1024以上的,1024以下的基本都被系统程序占用了。
常用端口,面试会问
mysql: 3306
oracle: 1521
web: 80
tomcat: 8080

协议
协议是为计算机网络中进行数据交换而建立的规则、标准或约定的集合。
网络传输方式协议有TCP&UDP

TCP(传输控制协议)
面向连接(三次握手),数据安全,速度略低。分为客户端和服务端。
三次握手: 客户端先向服务端发起请求, 服务端响应请求, 传输数据

UDP(数据报传输协议)
面向无连接,数据不安全,速度快。不区分客户端与服务端。

4 Socket概述
Socket翻译过来就是套接字
网络上具有唯一标识的IP地址和端口号组合在一起才能构成唯一能识别的标识符套接字。
通信的两端都有Socket,网络通信其实就是Socket间的通信。
数据在两个Socket间通过IO流传输。Socket就是用来建立通信管道
Socket在应用程序中创建,通过一种绑定机制与驱动程序建立关系,告诉自己所对应的IP和port。

在这里插入图片描述

5 TCP通信原理图解
在这里插入图片描述

2.6 UDP通信原理图解
在这里插入图片描述

2.7 案例:UDP数据传输
实现步骤:
发送Send
创建DatagramSocket, 随机端口号
创建DatagramPacket, 指定数据, 长度, 地址, 端口
使用DatagramSocket发送DatagramPacket
关闭DatagramSocket

接收Receive
创建DatagramSocket, 指定端口号
创建DatagramPacket, 指定数组, 长度
使用DatagramSocket接收DatagramPacket
关闭DatagramSocket
从DatagramPacket中获取数据

案例:实现UDP的发送和接收

public static void main(String[] args) throws Exception {

// 1.发送Send
// 创建DatagramSocket, 随机端口号
DatagramSocket sender = new DatagramSocket();

// 创建DatagramPacket【数据包】, 指定数据, 长度, 地址, 端口
String s = “你好吗?最近很想你”;
byte[] bs = s.getBytes(“UTF-8”);
DatagramPacket packet = new DatagramPacket(bs, bs.length, Inet4Address.getByName(“192.168.1.125”), 5288);

// 使用DatagramSocket发送DatagramPacket
sender.send(packet);

// 关闭DatagramSockets
sender.close();
}
public static void main(String[] args) throws IOException {
// 2.接收Receive
// 创建DatagramSocket, 指定端口号
DatagramSocket receiver = new DatagramSocket(5288);

// 创建DatagramPacket, 指定数组, 长度
byte[] buf = new byte[1024];
DatagramPacket packet = new DatagramPacket(buf, 1024);

// 使用DatagramSocket接收DatagramPacket
receiver.receive(packet);

// 关闭DatagramSocket
receiver.close();

// 从PackeDatagramt中获取数据
String s = new String(buf, 0, packet.getLength(), “UTF-8”);
System.out.println(“接收到数据:” + s);
}

案例:添加键盘和死循环功能
public class Demo_Sender {

public static void main(String[] args) throws Exception {

// 1.发送Send
// 创建DatagramSocket, 随机端口号
DatagramSocket sender = new DatagramSocket();

	//2 ScannerScanner scanner = new Scanner(System.in);while(true){

// 创建DatagramPacket【数据包】, 指定数据, 长度, 地址, 端口
System.out.println(“输入内容:”);
String s = scanner.nextLine();
byte[] bs = s.getBytes(“UTF-8”);
DatagramPacket packet = new DatagramPacket(bs, bs.length, Inet4Address.getByName(“192.168.1.125”), 5288);

// 使用DatagramSocket发送DatagramPacket
sender.send(packet);
}

// 关闭DatagramSockets
//sender.close();
}
}

package lesson05;
public class Demo_Receiver {

public static void main(String[] args) throws IOException {

// 2.接收Receive
// 创建DatagramSocket, 指定端口号
DatagramSocket receiver = new DatagramSocket(5288);

	while(true){

// 创建DatagramPacket, 指定数组, 长度
byte[] buf = new byte[1024];
DatagramPacket packet = new DatagramPacket(buf, 1024);

// 使用DatagramSocket接收DatagramPacket
receiver.receive(packet);

// 关闭DatagramSocket
//receiver.close();

// 从PackeDatagramt中获取数据
String s = new String(buf, 0, packet.getLength(), “UTF-8”);
System.out.println(new Date() + “接收到数据:” + s);
}
}
}

案例:使用双线程来收发数据
public class Demo {

public static void main(String[] args) {// 案例:UDP数据传输+键盘和循环+双线程实现(了解)new Receiver().start();new Sender().start();
}

}

class Receiver extends Thread {
@Override
public void run() {
// TODO Auto-generated method stub
try {

		// 创建DatagramSocket, 指定端口号DatagramSocket receiver = new DatagramSocket(5288);while (true) {// 创建DatagramPacket, 指定数组, 长度byte[] buf = new byte[1024];DatagramPacket packet = new DatagramPacket(buf, 1024);// 使用DatagramSocket接收DatagramPacketreceiver.receive(packet);// 关闭DatagramSocket// receiver.close();// 从PackeDatagramt中获取数据String s = new String(buf, 0, packet.getLength(), "UTF-8");System.out.println(new Date() + "接收到数据:" + s);}} catch (Exception e) {// TODO: handle exception}
}

}

class Sender extends Thread {
@Override
public void run() {
try {
// 创建DatagramSocket, 随机端口号
DatagramSocket sender = new DatagramSocket();

		//2 ScannerScanner scanner = new Scanner(System.in);while(true){

// 创建DatagramPacket【数据包】, 指定数据, 长度, 地址, 端口
System.out.println(“输入内容:”);
String s = scanner.nextLine();
byte[] bs = s.getBytes(“UTF-8”);
DatagramPacket packet = new DatagramPacket(bs, bs.length, Inet4Address.getByName(“192.168.1.125”), 5288);

// 使用DatagramSocket发送DatagramPacket
sender.send(packet);
}
} catch (Exception e) {
// TODO: handle exception
}
}
}

2.8 案例:TCP数据传输【多练】
》客户端用键盘+死循环实现
public class Demo_Client {

public static void main(String[] args) throws IOException {//1.创建Socket对象Socket socket = new Socket("192.168.1.125", 9999);//2.获取输入流出InputStream is = socket.getInputStream();OutputStream os = socket.getOutputStream();BufferedReader br = new BufferedReader(new InputStreamReader(is));PrintWriter pw = new PrintWriter(os);//3.发送数据给服务端面pw.write("Java 还是不错的...\r\n");pw.flush();//4.读服务响应的数据System.out.println("读取响应数据:" + br.readLine());//关流br.close();socket.close();
}

}
public class Demo_Server {

public static void main(String[] args) throws Exception {//1.创建个服务端Socket对象,绑定端口ServerSocket serverSocket = new ServerSocket(9999);//2.监听客户端面连接while(true){Socket clientSocket = serverSocket.accept();//3.接收客户端面发送的数据new Thread(){public void run() {try {//读写数据都是通过IOInputStream is = clientSocket.getInputStream();OutputStream os = clientSocket.getOutputStream();BufferedReader br = new BufferedReader(new InputStreamReader(is));PrintWriter pw = new PrintWriter(os);while(true){//读取客户端的数据String line = br.readLine();if(line != null){System.out.println(clientSocket + ":" + new Date() +  "接收到客户端发送的数据:" + line);//响应客户端面pw.write("receiver success\r\n");pw.flush();}	}} catch (Exception e) {// TODO: handle exception}};}.start();}
}

}

这篇关于Java学习总结--040网络编程的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/159749

相关文章

Maven中引入 springboot 相关依赖的方式(最新推荐)

《Maven中引入springboot相关依赖的方式(最新推荐)》:本文主要介绍Maven中引入springboot相关依赖的方式(最新推荐),本文给大家介绍的非常详细,对大家的学习或工作具有... 目录Maven中引入 springboot 相关依赖的方式1. 不使用版本管理(不推荐)2、使用版本管理(推

Java 中的 @SneakyThrows 注解使用方法(简化异常处理的利与弊)

《Java中的@SneakyThrows注解使用方法(简化异常处理的利与弊)》为了简化异常处理,Lombok提供了一个强大的注解@SneakyThrows,本文将详细介绍@SneakyThro... 目录1. @SneakyThrows 简介 1.1 什么是 Lombok?2. @SneakyThrows

在 Spring Boot 中实现异常处理最佳实践

《在SpringBoot中实现异常处理最佳实践》本文介绍如何在SpringBoot中实现异常处理,涵盖核心概念、实现方法、与先前查询的集成、性能分析、常见问题和最佳实践,感兴趣的朋友一起看看吧... 目录一、Spring Boot 异常处理的背景与核心概念1.1 为什么需要异常处理?1.2 Spring B

如何在 Spring Boot 中实现 FreeMarker 模板

《如何在SpringBoot中实现FreeMarker模板》FreeMarker是一种功能强大、轻量级的模板引擎,用于在Java应用中生成动态文本输出(如HTML、XML、邮件内容等),本文... 目录什么是 FreeMarker 模板?在 Spring Boot 中实现 FreeMarker 模板1. 环

Qt实现网络数据解析的方法总结

《Qt实现网络数据解析的方法总结》在Qt中解析网络数据通常涉及接收原始字节流,并将其转换为有意义的应用层数据,这篇文章为大家介绍了详细步骤和示例,感兴趣的小伙伴可以了解下... 目录1. 网络数据接收2. 缓冲区管理(处理粘包/拆包)3. 常见数据格式解析3.1 jsON解析3.2 XML解析3.3 自定义

SpringMVC 通过ajax 前后端数据交互的实现方法

《SpringMVC通过ajax前后端数据交互的实现方法》:本文主要介绍SpringMVC通过ajax前后端数据交互的实现方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价... 在前端的开发过程中,经常在html页面通过AJAX进行前后端数据的交互,SpringMVC的controll

Java中的工具类命名方法

《Java中的工具类命名方法》:本文主要介绍Java中的工具类究竟如何命名,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录Java中的工具类究竟如何命名?先来几个例子几种命名方式的比较到底如何命名 ?总结Java中的工具类究竟如何命名?先来几个例子JD

Java Stream流使用案例深入详解

《JavaStream流使用案例深入详解》:本文主要介绍JavaStream流使用案例详解,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录前言1. Lambda1.1 语法1.2 没参数只有一条语句或者多条语句1.3 一个参数只有一条语句或者多

Spring Security自定义身份认证的实现方法

《SpringSecurity自定义身份认证的实现方法》:本文主要介绍SpringSecurity自定义身份认证的实现方法,下面对SpringSecurity的这三种自定义身份认证进行详细讲解,... 目录1.内存身份认证(1)创建配置类(2)验证内存身份认证2.JDBC身份认证(1)数据准备 (2)配置依

SpringBoot整合OpenFeign的完整指南

《SpringBoot整合OpenFeign的完整指南》OpenFeign是由Netflix开发的一个声明式Web服务客户端,它使得编写HTTP客户端变得更加简单,本文为大家介绍了SpringBoot... 目录什么是OpenFeign环境准备创建 Spring Boot 项目添加依赖启用 OpenFeig