通信网络-Socket、Java中的网络支持、多线程服务器

news2025/1/15 23:00:02

前言

通信网络-Socket、Java中的网络支持、多线程服务器
场景:使用java网络创建一个聊天室
博客地址:芒果橙的个人博客

文章目录

    • 前言
    • 通信网络-Socket
      • TCP/IP
      • TCP/IP 模型
      • 端口
    • Java中的网络支持
      • 概念
      • 1. InetAddress
      • 2. URL
      • 3. Socket
      • 4. Datagram
    • 多线程服务器
      • 应用多线程来实现服务器与多客户端之间的通信

通信网络-Socket

两台计算机进行通信的条件: 有唯一的标识,表示所处的身份和所处的位置:IP地址 有共同的语言:协议 每台主机都有端口号,用来区分哪个应用在通信

TCP/IP

  • TCP/IP是目前世界上应用最为广泛的协议,是以TCP和IP为基础的不同层次上多个协议的集合
  • 也称:TCP/IP协议族、TCP/IP协议栈
  • TCP:Transmission Control Protocol ——传输控制协议
  • IP:Internet Protocol ——互联网协议

TCP/IP 模型

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-SHIZsudK-1677913533652)(F:\website\Blog\blog\source_drafts\image-20230304093601628.png)]
在这里插入图片描述

端口

  • 用于区分不同应用程序
  • 端口号范围为065535,其中01023为系统所保留
  • IP地址和端口号组成了所谓的Socket,Socket是网络上运行的程序之间双向通信链路的终结点,是TCP和UDP的基础

Java中的网络支持

概念

针对网络通信的不同层次,Java中提供的网络功能有四大类

  1. InetAddress:用于标识网络上的硬件资源
  2. URL:统一资源定位符,通过URL可以直接读取或写入网络上的数据
  3. Sockets:使用TCP协议实现网络通信的Socket相关的类
  4. Datagram:使用UDP协议,将数据保存在数据报中,通过网络进行通信

1. InetAddress

  • 获取本地的InetAddress实例:InetAddress.getLocalHost()

  • 根据机器名获取InetAddress实例:InetAddress.getByName()

    InetAddress inetAddress = InetAddress.getLocalHost();
            System.out.println("IP地址:" + inetAddress.getHostAddress());
            System.out.println("计算机名:" + inetAddress.getHostName());
    
    InetAddress ia = InetAddress.getByName("NOD4AAITZWEN3FD");
            System.out.println("IP地址:" + ia.getHostAddress());
            System.out.println("计算机名:" + ia.getHostName());
    

2. URL

  1. Uniform Resource Locator——统一资源定位符,表示Internet上某一资源的地址
  2. 由两部分组成:协议名称和资源名称,冒号隔开
  • 创建URL实例:new URL()

    URL baidu = new URL("http://www.baidu.com");
            URL url = new URL(baidu,"/s?wd=什么是url");
            System.out.println("协议:" + url.getProtocol());  // http
            System.out.println("主机:" + url.getHost());      // www.baidu.com
            System.out.println("端口:" + url.getPort());      // -1 (未指定端口,则使用默认端口号,返回-1)
            System.out.println("查询字符串:" + url.getQuery());  // wd=什么是url
    

3. Socket

TCP协议是面向连接、可靠的、有序的,以字节流的方式发送数据

基于TCP协议实现网络通信的类

  • 客户端的Socket类
  • 服务端的ServerSocket类

基于tcp的socket模型

在这里插入图片描述

Socket和ServerSocket连接的实现步骤

  1. 创建ServerSocket和Socket
  2. 打开连接到Socket的输入/输出流
  3. 按照协议对Socket进行读/写操作
  4. 关闭输入输出流、关闭Socket
  • 创建服务端

    // 1.创建服务端
            ServerSocket server = new ServerSocket(8888);
            // 2.监听
            System.out.println("服务器启动中...");
            Socket socket = server.accept();
            // 3.获取输入流,读取客户端信息
            InputStream inputStream = socket.getInputStream();
            InputStreamReader inputStreamReader = new InputStreamReader(inputStream);
            BufferedReader bufferedReader = new BufferedReader(inputStreamReader);
            String info;
            while ((info = bufferedReader.readLine()) != null) {
                System.out.println("接收到客户端信息:" + info);
            }
            // 4.关闭输入流和资源
            System.out.println("关闭服务端");
            socket.close();
            bufferedReader.close();
            inputStreamReader.close();
            inputStream.close();
            socket.close();
            server.close();
    
  • 创建客户端

    // 1.创建客户端
            System.out.println("客户端启动中...");
            Socket client = new Socket("localhost",8888);
            // 2.获取输出流,向服务端发送信息
            OutputStream outputStream = client.getOutputStream();
            PrintWriter printWriter = new PrintWriter(outputStream);
            printWriter.write("我是客户端");
            printWriter.flush();
            // 3.关闭输出流和资源
            client.shutdownOutput();
            printWriter.close();
            outputStream.close();
            client.close();
    

4. Datagram

UDP协议——用户数据报协议,是无连接、不可靠、无序的,特点是速度比较快

进行数据传输时,首先将要传输的数据定义成数据报,在数据报中指明数据所要达到的Socket,然后再将数据报发送出去

TCP和UDP区别

TCPUDP
是否连接面向连接面向非连接
传输可靠性可靠不可靠
应用场合传输大量数据少量数据
速度
  • 创建服务端

    // 1.创建服务端
            System.out.println("服务端启动中...");
            DatagramSocket server = new DatagramSocket(8888);
            // 2.定义数据报
            byte[] bytes = new byte[1024];
            DatagramPacket datagramPacket = new DatagramPacket(bytes, bytes.length);
            // 3.接收数据
            //while (true) {
                server.receive(datagramPacket);
                // 4.读取数据
                String info = new String(datagramPacket.getData(),datagramPacket.getOffset(),datagramPacket.getLength(), StandardCharsets.UTF_8);
                System.out.println("接收到客户端信息:" + info);
                // 5.关闭资源
                server.close();
                System.out.println("服务端关闭...");
            //}
    
  • 创建客户端

    // 1. 定义发送数据
            String message = "我是客户端";
            byte[] bytes = message.getBytes(StandardCharsets.UTF_8);
            // 2. 创建数据报,包含发送的信息
            DatagramPacket datagramPacket = new DatagramPacket(bytes, bytes.length);
            // 3. 创建Socket
            System.out.println("客户端启动...");
            DatagramSocket client = new DatagramSocket();
            // 4. 连接并发送
            client.connect(new InetSocketAddress("localhost",8888));
            client.send(datagramPacket);
            // 5. 关闭资源
            client.close();
    

多线程服务器

应用多线程来实现服务器与多客户端之间的通信

基本步骤

  1. 服务端创建ServerSocket,循环调用accept()等待客户端连接(死循环)
  2. 客户端创建一个Socket并请求和服务端连接
  3. 服务端接收客户端请求,创建Socket与该客户端建立连接
  4. 建立连接的两个socket在一个单独的线程中对话
  5. 服务端持续等待新的连接

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/387668.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

使用ECharts打造一个数据可视化面板

使用ECharts打造一个数据可视化面板1. 使用技术2. 案例适配方案3. 基础设置4. header 布局5. mainbox 主体模块6. 公共面板模块 panel7. 柱形图 bar 模块(布局)8. 中间布局9. ECharts 介绍10. ECharts 体验11. ECharts 基础配置12. 柱状图图表&#xff0…

MDK软件使用技巧

本文主要汇总MDK软件使用技巧 一、字体大小及颜色修改 第一步点击工具栏的这个小扳手图标 进去后显示如下,先设置 Encoding 为:Chinese GB2312(Simplified),然后设置 Tab size 为:4 以更好的支持简体中文,否则&…

Java 多线程 --- 线程协作 wait/notify

Java 多线程 --- 线程协作 wait/notifywait / notifyObject.wait() , Object.notify() / notifyAll()notify 和 wait 的原理notify会导致死锁的问题wait / notify的开销以及问题wait / notify 在多线程中, 如果程序拿到锁之后, 但是没有满足指定条件而不能继续往下执行, 我们可…

外网用户打不开公司的网站?web服务器端口映射到公网

我们经常会遇到这样的情景,在公司内部可以打开公司的网站,在家里或者外网却打不开,按照网上的做法,重新启动了服务器和iis,还是不行。许多用户设置了路由器端口映射功能,但是端口映射不成功怎么办&#xff…

2023河南新乡市第二届职业技能大赛“网络安全”项目B模块比赛任务书

2023河南新乡市第二届职业技能大赛“网络安全”项目 比赛任务书一、竞赛时间二、竞赛阶段及内容B-1 Windows操作系统渗透测试B-2 Wireshark数据包分析B-3 CMS网站渗透B-4 未公开B-5 未公开一、竞赛时间 总计:180分钟 二、竞赛阶段及内容 (一&#xff…

嵌入式系统实验——【玄武F103开发板】实现两个LED小灯闪烁

目录一、实验文件main.cstm32f10x.h二、实验思路(一)打开两个LED小灯1.在玄武F103开发板上找到LED0、LED1对应的GPIO控制寄存器2.找到GPIOB、GPIOE的地址3.打开APB2外设时钟的使能寄存器4.对GPIO寄存器进行设置对端口输出寄存器进行设置(二&a…

Go语言基准测试(benchmark)三部曲之三:提高篇

欢迎访问我的GitHub 这里分类和汇总了欣宸的全部原创(含配套源码):https://github.com/zq2599/blog_demos 本篇概览 -《Go语言基准测试(benchmark)三部曲》已近尾声,经历了《基础篇》和《内存篇》的实战演练,相信您已熟练掌握了基准测试的常…

Spring Security 实现自定义登录和认证(1)

1 SpringSecurity 1.1 导入依赖 <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-security</artifactId> </dependency>1.2 编写配置类 在spring最新版中禁用了WebSecurityConfigurerAdapter…

《Linux运维实战:基于ansible一键离线部署容器版MySQL一主两从集群(5.6.50、5.7.30、8.0.30)》

一、部署背景 由于业务系统的特殊性&#xff0c;我们需要针对不同的客户环境部署 MySQL主从复制集群&#xff0c;由于大都数用户都是专网环境&#xff0c;无法使用外网&#xff0c;为了更便捷&#xff0c;高效的部署&#xff0c;针对业务系统的特性&#xff0c;我这边编写了基于…

【C++修炼之路】24.哈希应用--位图

每一个不曾起舞的日子都是对生命的辜负 哈希应用--位图哈希应用&#xff1a;位图一.提出问题二.位图概念三.位图代码四.位图应用五.经典问题哈希应用&#xff1a;位图 一.提出问题 问题&#xff1a; 给40亿个不重复的无符号整数&#xff0c;没排过序。给一个无符号整数&#x…

信息服务上线渗透检测网络安全检查报告和解决方案3(系统漏洞扫描、相对路径覆盖RPO漏洞、nginx漏洞修复)

系列文章目录 信息服务上线渗透检测网络安全检查报告和解决方案2(安装文件信息泄漏、管理路径泄漏、XSS漏洞、弱口令、逻辑漏洞、终极上传漏洞升级)信息服务上线渗透检测网络安全检查报告和解决方案 文章目录系列文章目录前言一、中风险漏洞相对路径覆盖(RPO)漏洞二、低风险漏…

【2021.12.28】ctf逆向中的迷宫问题(含exe及wp)

【2021.12.28】ctf逆向中的迷宫问题&#xff08;含exe及wp&#xff09; 文章目录【2021.12.28】ctf逆向中的迷宫问题&#xff08;含exe及wp&#xff09;1、迷宫简介&#xff08;1&#xff09;简单例子&#xff08;2&#xff09;一般的迷宫代码2、二维迷宫&#xff08;1&#xf…

LeetCode 460. LFU 缓存 -- 哈希查询+双向链表

LFU 缓存 困难 634 相关企业 请你为 最不经常使用&#xff08;LFU&#xff09;缓存算法设计并实现数据结构。 实现 LFUCache 类&#xff1a; LFUCache(int capacity) - 用数据结构的容量 capacity 初始化对象 int get(int key) - 如果键 key 存在于缓存中&#xff0c;则获取键…

IP网络广播对讲系统的先进性及系统功能

IP网络广播对讲系统是一套基于TCP/IP网络的纯数字IP网络对讲机系统。在物理结构上&#xff0c;IP网络广播系统与标准IP网络集成。它不仅真正实现了基于TCP/IP网络的数字音频广播、直播和点播&#xff0c;而且借助TCP/IP网络的优势&#xff0c;突破了传统模拟广播系统的局限性、…

用Python写个猜数字游戏,写游戏难道比玩游戏还好玩(12)

小朋友们好&#xff0c;大朋友们好&#xff01;我是猫妹&#xff0c;一名爱上Python编程的小学生。欢迎和猫妹一起&#xff0c;趣味学Python。今日主题开学差不多有1个月了吧&#xff1f;猫妹刚刚从寒假的玩玩玩模式切换到上学的学学学模式。你呢&#xff1f;这是猫妹的课程表&…

嵌入式中backtrace的使用

大家好&#xff0c;我是bug菌&#xff5e; backtrace主要用于调试程序时&#xff0c;能够打印出程序在运行过程中的函数调用栈&#xff0c;以帮助开发者快速定位程序出现异常或崩溃的原因。 通过backtrace的输出&#xff0c;开发者可以了解程序在哪个函数出现问题&#xff0c…

APM飞控使用动捕等外部定位

本文初次写于2023.03.03&#xff0c;pixhawk飞控应该是刷写了ArduPilot 4.1以上的版本。 机载计算机通过WIFI和vrpn_ros_client获取动捕系统&#xff08;vicon或者nokov&#xff09;的无人机定位数据&#xff08;x&#xff0c;y&#xff0c;z四元数&#xff09;&#xff0c;然…

HMM-维特比算法

HMM-维特比算法&#xff08;viterbi&#xff09;HMM回顾隐马科夫链解法&#xff1a;维特比算法&#xff08;Viterbi&#xff09;HMM回顾 最终的公式可以解释主要分为两个部分&#xff1a; P(xi|yi)&#xff0c;发射概率&#xff0c;字面意思是从一个词性中发射/生成出某一个单…

【Java】Spring Boot下的MVC

文章目录Spring MVC程序开发1. 什么是Spring MVC&#xff1f;1.1 MVC定义1.2 MVC 和 Spring MVC 的关系2. 为什么学习Spring MVC&#xff1f;3. 怎么学习Spring MVC&#xff1f;3.1 Spring MVC的创建和连接3.1.1 创建Spring MVC项目3.1.2 RequestMapping 注解介绍3.1.3 Request…

1 网关介绍

网关介绍 在微服务架构中&#xff0c;一个系统会被拆分为很多个微服务。那么作为客户端要如何去调用这么多的微服务呢&#xff1f;如果没有网关的存在&#xff0c;我们只能在客户端记录每个微服务的地址&#xff0c;然后分别去调用。这样的话会产生很多问题&#xff0c;例如&a…