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

相关文章

Java实现删除文件中的指定内容

《Java实现删除文件中的指定内容》在日常开发中,经常需要对文本文件进行批量处理,其中,删除文件中指定内容是最常见的需求之一,下面我们就来看看如何使用java实现删除文件中的指定内容吧... 目录1. 项目背景详细介绍2. 项目需求详细介绍2.1 功能需求2.2 非功能需求3. 相关技术详细介绍3.1 Ja

springboot项目中整合高德地图的实践

《springboot项目中整合高德地图的实践》:本文主要介绍springboot项目中整合高德地图的实践,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一:高德开放平台的使用二:创建数据库(我是用的是mysql)三:Springboot所需的依赖(根据你的需求再

spring中的ImportSelector接口示例详解

《spring中的ImportSelector接口示例详解》Spring的ImportSelector接口用于动态选择配置类,实现条件化和模块化配置,关键方法selectImports根据注解信息返回... 目录一、核心作用二、关键方法三、扩展功能四、使用示例五、工作原理六、应用场景七、自定义实现Impor

SpringBoot3应用中集成和使用Spring Retry的实践记录

《SpringBoot3应用中集成和使用SpringRetry的实践记录》SpringRetry为SpringBoot3提供重试机制,支持注解和编程式两种方式,可配置重试策略与监听器,适用于临时性故... 目录1. 简介2. 环境准备3. 使用方式3.1 注解方式 基础使用自定义重试策略失败恢复机制注意事项

SpringBoot整合Flowable实现工作流的详细流程

《SpringBoot整合Flowable实现工作流的详细流程》Flowable是一个使用Java编写的轻量级业务流程引擎,Flowable流程引擎可用于部署BPMN2.0流程定义,创建这些流程定义的... 目录1、流程引擎介绍2、创建项目3、画流程图4、开发接口4.1 Java 类梳理4.2 查看流程图4

一文详解如何在idea中快速搭建一个Spring Boot项目

《一文详解如何在idea中快速搭建一个SpringBoot项目》IntelliJIDEA作为Java开发者的‌首选IDE‌,深度集成SpringBoot支持,可一键生成项目骨架、智能配置依赖,这篇文... 目录前言1、创建项目名称2、勾选需要的依赖3、在setting中检查maven4、编写数据源5、开启热

Java对异常的认识与异常的处理小结

《Java对异常的认识与异常的处理小结》Java程序在运行时可能出现的错误或非正常情况称为异常,下面给大家介绍Java对异常的认识与异常的处理,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参... 目录一、认识异常与异常类型。二、异常的处理三、总结 一、认识异常与异常类型。(1)简单定义-什么是

SpringBoot项目配置logback-spring.xml屏蔽特定路径的日志

《SpringBoot项目配置logback-spring.xml屏蔽特定路径的日志》在SpringBoot项目中,使用logback-spring.xml配置屏蔽特定路径的日志有两种常用方式,文中的... 目录方案一:基础配置(直接关闭目标路径日志)方案二:结合 Spring Profile 按环境屏蔽关

Java使用HttpClient实现图片下载与本地保存功能

《Java使用HttpClient实现图片下载与本地保存功能》在当今数字化时代,网络资源的获取与处理已成为软件开发中的常见需求,其中,图片作为网络上最常见的资源之一,其下载与保存功能在许多应用场景中都... 目录引言一、Apache HttpClient简介二、技术栈与环境准备三、实现图片下载与保存功能1.

SpringBoot排查和解决JSON解析错误(400 Bad Request)的方法

《SpringBoot排查和解决JSON解析错误(400BadRequest)的方法》在开发SpringBootRESTfulAPI时,客户端与服务端的数据交互通常使用JSON格式,然而,JSON... 目录问题背景1. 问题描述2. 错误分析解决方案1. 手动重新输入jsON2. 使用工具清理JSON3.