第二十一章Java网络通信

网络通信这一章  基本分为三个部分  网络基础概念和TCP,UDP这三个部分主要如下:

6170263e430f4306a2867347c5f4dff5.png计算机网络实现了堕胎计算机间的互联,使得它们彼此之间能够进行数据交流。网络应用程序就是再已连接的不同计算机上运行的程序,这些程序借助于网络协议,相互之间可以交换数据,编写网络应用程序前,首先必须明确网络协议TCP/IP协议是网络应用程序的首选

网络程序设计基础:

网络程序设计编写始于其他计算机进行通信的程序,java已经将网络程序所需要而定元素封装成不同的类,用户只要床啊金这些类的对象,使用相应的方法即使不举报相关的网络知识,也是可以编写除高质量的网络通信程序的,

本章最主要的是TCP和UDP两个部分  他们两主要的区别就是一个是一对一通信  一个是一对多通信   当然两者都有各自的优势和劣势,接下来先讲解 TCP部分
TCP程序

TCP程序的通信方式呢 是一对一的   步骤是  先要打开服务器然后客户端连接服务器  先是尝试客户端是否能够接收到信息  如果可以接收到信息的话  这时服务器将会把文件传输给客户端,这样的话 能够保证客户端可以接收到信息  ,劣势呢就是每次都是要这样子 所以效率对比起UDP来说慢下了好多  以下代码将会进行讲解

客户端代码:

 
  1. package tcp;

  2.  
  3. import java.io.*;

  4. import java.net.Socket;

  5. import java.util.Scanner;

  6.  
  7. /**

  8. * Socket客户端

  9. **/

  10. public class SocketClient {

  11. public static void main(String[] args) {

  12. Socket s = null;

  13. try {

  14. // 与ip为127.0.0.1、端口为12345的服务端建立连接

  15. s = new Socket("127.0.0.1", 12345);

  16.  
  17. // 创建输入流接收服务端发送的消息(字节流)

  18. InputStream is = s.getInputStream();

  19. // 将服务端返回的字节流转化为字符流

  20. InputStreamReader isr = new InputStreamReader(is);

  21. // 创建字符流读取缓冲区,方便每行读取

  22. BufferedReader br = new BufferedReader(isr);

  23.  
  24. // 创建输出流返回消息

  25. OutputStream os = s.getOutputStream();

  26. // 创建输出流缓冲

  27. PrintWriter pw = new PrintWriter(os);

  28.  
  29. // 创建发送消息的线程

  30. Runnable rOut = () -> {

  31. boolean flag = true;

  32. while (flag) {

  33. try {

  34. // 接收控制台输入

  35. Scanner scan = new Scanner(System.in);

  36. String msg = scan.nextLine();

  37. // 将输入写入缓冲

  38. pw.println(msg);

  39. // 将缓冲内的数据推送至服务端并清空缓冲区

  40. pw.flush();

  41. } catch (Exception e) {

  42. flag = false;

  43. e.printStackTrace();

  44. }

  45. }

  46. };

  47.  
  48. // 创建接收消息的线程

  49. Runnable rIn = () -> {

  50. boolean flag = true;

  51. while (flag) {

  52. try {

  53. // 逐行读取服务端返回的消息并打印

  54. String str = br.readLine();

  55. System.out.println("服务端的消息:" + str);

  56. } catch (IOException e) {

  57. flag = false;

  58. e.printStackTrace();

  59. }

  60. }

  61. };

  62.  
  63. // 启动两个线程

  64. Thread tOut = new Thread(rOut);

  65. Thread tIn = new Thread(rIn);

  66. tOut.start();

  67. tIn.start();

  68. }catch (IOException e) {

  69. try {

  70. // 释放资源

  71. s.close();

  72. } catch (Exception exception) {

  73. exception.printStackTrace();

  74. }

  75. e.printStackTrace();

  76. }

  77. }

  78. }

 服务端代码:

 
  1. package tcp;

  2. import java.io.*;

  3. import java.net.ServerSocket;

  4. import java.net.Socket;

  5. import java.util.Scanner;

  6.  
  7. /**

  8. * Socket服务端

  9. **/

  10. public class SocketServer {

  11. public static void main(String[] args) {

  12. ServerSocket ss = null;

  13. Socket s = null;

  14. try {

  15. // 创建监听端口为12345的Socket服务端

  16. ss = new ServerSocket(12345);

  17. System.out.println("服务端Socket服务已建立,等待客户端连接...");

  18. // 通过ss.accept()开始持续监听12345端口,当有连接时获取收到的包装成Socket的客户端对象

  19. s = ss.accept();

  20. // 获取客户端的IP地址和端口号

  21. String ip = s.getInetAddress().getHostAddress();

  22. int port = s.getPort();

  23. System.out.println("服务端与 " + ip + ":" + port + " 已建立连接");

  24.  
  25. // 创建输入流接收客户端发送的消息(字节流)

  26. InputStream is = s.getInputStream();

  27. // 将客户端发送的字节流转化为字符流

  28. InputStreamReader isr = new InputStreamReader(is);

  29. // 创建字符流读取缓冲区,方便每行读取

  30. BufferedReader br = new BufferedReader(isr);

  31.  
  32. // 创建输出流返回消息

  33. OutputStream os = s.getOutputStream();

  34. // 创建输出流缓冲

  35. PrintWriter pw = new PrintWriter(os);

  36.  
  37. // 创建接受信息的线程

  38. Runnable rIn = () -> {

  39. boolean flag = true;

  40. while (flag) {

  41. try {

  42. // 逐行读取客户端发送的消息并打印

  43. String str = br.readLine();

  44. System.out.println("客户端的消息:" + str);

  45. } catch (IOException e) {

  46. flag = false;

  47. e.printStackTrace();

  48. }

  49. }

  50. };

  51.  
  52. // 创建发送消息的线程

  53. Runnable rOut = () -> {

  54. boolean flag = true;

  55. while (flag) {

  56. try {

  57. // 接收控制台输入

  58. Scanner scan = new Scanner(System.in);

  59. String msg = scan.nextLine();

  60. // 将输入写入缓冲

  61. pw.println(msg);

  62. // 将缓冲内的数据推送至客户端并清空缓冲区

  63. pw.flush();

  64. } catch (Exception e) {

  65. flag = false;

  66. e.printStackTrace();

  67. }

  68. }

  69. };

  70.  
  71. // 开启两个线程

  72. Thread tIn = new Thread(rIn);

  73. Thread tOut = new Thread(rOut);

  74. tIn.start();

  75. tOut.start();

  76. } catch (IOException e) {

  77. try {

  78. // 释放资源

  79. ss.close();

  80. s.close();

  81. } catch (Exception exception) {

  82. exception.printStackTrace();

  83. }

  84. e.printStackTrace();

  85. }

  86. }

  87. }

 代码图如下:

6211f267abfd4a728439360de8e485b8.pngf352813be7b54d6db5ddd278e265edea.png

运行结果如下所示:

 24849969072a4756bc28724ef692522c.png

 接下来讲解UDP程序

UDP程序

UDP程序跟TCP程序不同的地方呢  TCP通信是一对一通信 如果要一下通知好多个人的话 就需要一个一个来通信  所以这时将会需要UDP了  UDP的优势就在于效率高 但是不稳定的地方呢  就是效率高但是不一定每个人都能看到  就像老师在台上讲课 总有一些学生会在台下玩手机 或者带耳机  不一定每一个人都能够接受得到  这就是UDP的不稳定的地方 ,接下来使用代码来讲解:

广播类代码如下:

 
  1. package udp;

  2.  
  3. import java.io.IOException;

  4. import java.net.DatagramPacket;

  5. import java.net.InetAddress;

  6. import java.net.MulticastSocket;

  7. //广播 先运行

  8. public class Notification extends Thread{

  9. String weather = "节目预报:八点有大型晚会,请收听";//发送消息

  10. int port = 9898;//端口号

  11. InetAddress iaddress = null;

  12. MulticastSocket socket = null;//多点广播套接字

  13.  
  14. Notification(){

  15. try {

  16. iaddress = InetAddress.getByName("224.255.10.0");//地址

  17. socket = new MulticastSocket(port);//实例化多点广播套接字

  18. socket.setTimeToLive(1);//指定发送范围是本地网络

  19. socket.joinGroup(iaddress);//加入广播组

  20. }catch(IOException e){

  21. e.printStackTrace();//输出异常信息

  22. }

  23.  
  24. }

  25. public void run(){//run方法

  26. while(true) {

  27. DatagramPacket packet = null;//数据包

  28. byte data[]=weather.getBytes();//字符串消息的字节数组

  29. packet = new DatagramPacket(data,data.length,iaddress,port);//将数据打包

  30. System.out.println(weather);//控制台打印消息

  31. try {

  32. socket.send(packet);//发送数据

  33. sleep(3000);//让线程休眠3000毫秒

  34. }catch(IOException e){

  35. e.printStackTrace();

  36. }catch(InterruptedException e) {

  37. e.printStackTrace();

  38. }

  39. }

  40. }

  41. public static void main(String[]args) {

  42. Notification w =new Notification();

  43. w.start();//启动线程

  44. }

  45. }

接收类代码如下:

 
  1. package udp;

  2.  
  3. import java.awt.BorderLayout;

  4. import java.awt.Color;

  5. import java.awt.GridLayout;

  6. import java.awt.event.ActionEvent;

  7. import java.awt.event.ActionListener;

  8. import java.io.IOException;

  9. import java.net.DatagramPacket;

  10. import java.net.InetAddress;

  11. import java.net.MulticastSocket;

  12.  
  13. import javax.swing.JButton;

  14. import javax.swing.JFrame;

  15. import javax.swing.JPanel;

  16. import javax.swing.JTextArea;

  17. import javax.swing.WindowConstants;

  18. //接收 后运行

  19. public class Receive extends JFrame implements Runnable, ActionListener {

  20. int port ;//端口

  21. InetAddress group =null;//广播组地址

  22. MulticastSocket socket = null;//多点广播套接字对象

  23. JButton inceBtn = new JButton("开始接收");

  24. JButton stopBtn = new JButton("停止接收");

  25. JTextArea inceAr = new JTextArea(10,10);//显示接收广播的文本域

  26. JTextArea inced = new JTextArea(10,10);

  27. Thread thread ;

  28. boolean stop = false;//定制接受信息状态

  29.  
  30. public Receive () {

  31. setTitle("广播数据包");

  32. setDefaultCloseOperation(WindowConstants.EXIT_ON_CLOSE);

  33. thread = new Thread(this);

  34. inceBtn.addActionListener(this);//绑定按钮ince的单击事件

  35. stopBtn.addActionListener(this);//绑定按钮stop的单击事件

  36. inceAr.setForeground(Color.blue);//指定文本域中文字的颜色

  37.  
  38. JPanel north = new JPanel();

  39. north.add(inceBtn);//将按钮添加到面板north上

  40. north.add(stopBtn);

  41. add(north,BorderLayout.NORTH);//将north放置在窗体的上部

  42. JPanel center = new JPanel();//创建面板对象center

  43. center.setLayout(new GridLayout(1,2));//设置面板布局

  44. center.add(inceAr);//将文本域添加到面板上

  45. center.add(inced);

  46. add(center,BorderLayout.CENTER);//设置面板的布局

  47. validate();//刷新

  48. port =9898;//设置端口号

  49. try {

  50. group = InetAddress.getByName("224.255.10.0");//指定接收地址

  51. socket = new MulticastSocket(port);//绑定多点广播套接字

  52. socket.joinGroup(group);//加入广播组

  53. }catch(IOException e){

  54. e.printStackTrace();//输出异常信息

  55. }

  56. setBounds(100,50,360,380);//设置布局

  57. setVisible(true);//将窗体设置为显示状态

  58. }

  59. public void run() {//run方法

  60. while (!stop) {

  61. byte data[] = new byte[1024];//创建缓存字节数组

  62. DatagramPacket packet = null;

  63. packet = new DatagramPacket(data,data.length,group,port);//待接收的数据包

  64. try {

  65. socket.receive(packet);//接收数据包

  66. //获取数据包中的内容

  67. String message = new String(packet.getData(),0,packet.getLength());

  68. inceAr.setText("正在接收的内容:\n"+message);//将接受内容显示在文本域中

  69. inced.append(message+"\n");//每条信息为一行

  70. }catch(IOException e ) {

  71. e.printStackTrace();//输出异常信息

  72. }

  73.  
  74. }

  75. }

  76. public void actionPerformed(ActionEvent e) {//单机按钮ince出发时间

  77. if(e.getSource()==inceBtn) {

  78. inceBtn.setBackground(Color.red);//设置按钮颜色

  79. stopBtn.setBackground(Color.yellow);

  80. if(!(thread.isAlive())) {//如线程不处于“新建状态”

  81. thread = new Thread(this);//实例化Thread对象

  82. }

  83. thread.start();//启动线程

  84. stop = false;//开始接受信息

  85. }

  86. if(e.getSource()== stopBtn) {//单机按钮stop出发时间

  87. inceBtn.setBackground(Color.yellow);//设置按钮亚瑟

  88. stopBtn.setBackground(Color.red);

  89. stop = true;//停止接收信息

  90. }

  91. }

  92. public static void main(String[]args) {

  93. Receive rec = new Receive();

  94. rec.setSize(460,200);

  95. }

  96. }

代码图如下所示:

5cc1e4ad9965450ea1aa1525baa5be89.pngd68f48201009454e925a777d0f4d7fe7.png运行结果如下所示:

2331a6e0b0874692b09ae175c614c62b.png

 

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

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

相关文章

Java线上问题排查思路

1、Java 服务常见问题 Java 服务的线上问题从系统表象来看大致可分成两大类: 系统环境异常、业务服务异常。 系统环境异常:主要从CPU、内存、磁盘、网络四个方面考虑。比如:CPU 占用率过高、CPU 上下文切换频率次数较高、系统可用内存长期处于较低值、…

第二证券:普通人怎么选个股?

普通人怎么选个股 1、成果 成果是推动个股上涨的内在动力,即成果好的个股能推动个股持续上涨,成果差的个股会导致个股持续跌落,因而,投资者应该选择成果较好的个股。 2、资金 资金是影响股价涨跌的一重要因素,当资…

使用electron属性实现保存图片并获取图片的磁盘路径

在普通的网页开发中,JavaScript由于安全性的考虑,通常是无法直接获取到客户端的磁盘路径的。浏览器出于隐私和安全原因对此类信息进行了限制。 在浏览器环境下,JavaScript主要通过Web APIs来与浏览器进行交互,而这些API通常受到浏…

代码随想录-刷题第四十一天

343. 整数拆分 题目链接:343. 整数拆分 思路:动态规划五步曲 dp[i]:拆分数字i,可以得到的最大乘积为dp[i]。 递推公式:dp[i] max(dp[i], max((i - j) * j, dp[i - j] * j)) 从1遍历j,有两种渠道得到dp[…

媲美保时捷:小米汽车正式亮相| 一周 IT资讯

1、对标保时捷、特斯拉!小米汽车首款产品发布 12月28日,万众瞩目之下,小米汽车首场技术发布会终于揭开神秘面纱,来自全国各地的米粉齐聚北京,共同见证了小米汽车的技术特色及优势。 在本次发布会上,小米汽…

数据库进阶教学——读写分离(Mycat1.6+Ubuntu22.04主+Win10从)

目录 1、概述 2、环境准备 3、读写分离实验 3.1、安装jdk 3.2、安装Mycat 3.3、配置Mycat 3.3.1、配置schema.xml ​​​​3.3.2、配置server.xml 3.4、修改主从机远程登陆权限 3.4.1、主机 3.4.2、从机 3.5、启动Mycat 3.6、登录Mycat 3.7、验证 1、概述 读写分…

【HarmonyOS开发】案例-记账本开发

OpenHarmony最近一段时间,简直火的一塌糊度,学习OpenHarmony相关的技术栈也有一段时间了,做个记账本小应用,将所学知识点融合记录一下。 1、记账本涉及知识点 基础组件(Button、Select、Text、Span、Divider、Image&am…

TikTok真题第8天 | 418.屏幕可显示句子的数量、395.至少有K个重复字符的最长子串、1010.总持续时间可以被60整除的歌曲对

418.屏幕可显示句子的数量 题目链接:418.sentence-screen-fitting 解法: 这道题,看题解都很难看懂,哪怕看出点门道了,也很难用自己的话解释出来。 有几点必须清楚: (1)将字符串…

10. Opencv检测并截取图中二维码

1. 说明 在二维码扫描功能开发中,使用相机扫描图片时,往往图片中的信息比较多样,可能会造成二维码检测失败的问题。一种提高检测精度的方式就是把二维码在图片中单独抠出来,去除其它冗余信息,然后再去识别这张提取出来的二维码。本篇博客记录采用的一种实现二维码位置检测…

计算机网络——应用层与网络安全(六)

前言: 前几章我们已经对TCP/IP协议的下四层已经有了一个简单的认识与了解,下面让我们对它的最顶层,应用层进行一个简单的学习与认识,由于计算机网络多样的连接形式、不均匀的终端分布,以及网络的开放性和互联性等特征&…

L1-069:胎压监测

题目描述 小轿车中有一个系统随时监测四个车轮的胎压,如果四轮胎压不是很平衡,则可能对行车造成严重的影响。 让我们把四个车轮 —— 左前轮、右前轮、右后轮、左后轮 —— 顺次编号为 1、2、3、4。本题就请你编写一个监测程序,随时监测四轮的…

GaussDB数据库中的同义词SYNONYM

目录 一、前言 二、GasussDB数据库中的Synonym 1、Synonym的概念 2、语法介绍 3、Synonym的用途 三、Synonym在GaussDB数据库中是如何使用的 1、表的同义词使用(示例) 2、视图的同义词使用(示例) 3、函数的同义词使用&am…

分布式IO在工业自动化中的应用

传统的自动化产线及物流系统主要是利用PLC来处理数据,并将这些数据保存在PC当中。但是随着互联网技术的迅速发展,越来越多的系统集成商利用分布式IO模块,实现从控制器到自动化最底层之间的IO通信。 分布式IO在工业自动化中的应用 分布式IO是用…

Vue3+ElementPlus: 给点击按钮添加触发提示

一、需求 在Vue3项目中,有一个下载按钮,当鼠标悬浮在按钮上面时,会出现文字提示用户可以点击按钮进行数据的下载技术栈 Vue3 ElementPlusTooltip组件 ElementPlus中的Tooltip组件 ,可用于展示鼠标 hover 时的提示信息 二、实现…

【SD】IP-Adapter 进阶 - 垫图 【1】

目录 关于SD1.5的画风迁移 修改动作-方法一:提示词 修改动作-方法二:openpose 关于SD1.5的画风迁移 1.5测试模型:flat2DAnimerge_v30_2.safetensors [b2c93e7a89] 测试图: 文生图:best quality,masterpiece, co…

GPT-5、开源、更强的ChatGPT!

年终岁尾,正值圣诞节热闹气氛的OpenAI写下了2024年的发展清单。 OpenAI联合创始人兼首席执行官Sam Altman在社交平台公布,AGI(稍晚一些)、GPT-5、更好的语音模型、更高的费率限制; 更好的GPTs;更好的推理…

weblogic未授权命令执行漏洞(CVE-2020-14882)

漏洞描述: 未经身份验证的远程攻击者可能通过构造特殊的 HTTP GET请求,利用该漏洞在受影响的 weblogic Server 上执行任意代码。 复现过程: 1.访问ip:port/console 2.poc构造 #!/usr/bin/env python3 # -*- coding: utf-8 -*-…

春款来啦~我先冲了

这款假两件设计的连帽风衣外套 宽松版型对身材包容性很强,韩系慵懒风颜色很舒服 时尚百搭怎么穿都好看系列 做了腰部可调节抽绳,想要修身一点的可以自己调节哈 袖口处也做了金属按扣调节,防风保暖 这件风衣也很好搭配,很经典…

css原子化的框架Tailwindcss的使用教程(原始html和vue项目的安装与配置)

安装教程 中文官网教程 原始的HTML里面使用 新建文件夹npm init -y 初始化项目 安装相关依赖 npm install -D tailwindcss postcss-cli autoprefixer初始化两个文件 npx tailwindcss init -p根目录下新建src/style.css tailwind base; tailwind components; tailwind ut…

利用Jmeter做接口测试(功能测试)全流程分析!

利用Jmeter做接口测试怎么做呢?过程真的是超级简单。 明白了原理以后,把零碎的知识点填充进去就可以了。所以在学习的过程中,不管学什么,我一直都强调的是要循序渐进,和明白原理和逻辑。这篇文章就来介绍一下如何利用…