Java中网络编程的学习

news2025/1/15 12:39:10

目录

网络编程概述

网络模型

网络通信三要素:  IP   端口号    通信协议

IP地址(Internet Protocol Address)

端口号

网络通信协议

TCP

三次握手

四次挥手

UDP

TCP编程

  客户端Socket的工作过程包含以下四个基本的步骤:

服务器程序的工作过程包含以下四个基本的步骤:

UDP编程

发送端

接收端,要指定监听的端口


网络编程概述

计算机网络:

     把分布在不同地理区域的具有独立功能的计算机,通过通信设备与线路连接起来,由功能完善的

软件实现资源共享和信息传递的系统。

    Java是 Internet 上的语言,它从语言级上提供了对网络应用程序的支持,程序员能够很容易开

发常见的网络应用程序。

    Java提供的网络类库,可以实现网络连接,联网的底层细节被隐藏在Java 的本机安装系统里,

由 JVM 进行控制。并且 Java 实现了一个 跨平台的网络库,程序员面对的是一个统一的网络编程

环境。

网络编程的目的:

     直接或间接地通过网络与其它计算机进行通讯。

网络编程中有两个主要的问题:

  1.如何准确地定位网络上一台或多台主机

  2.找到主机后如何可靠高效地进行数据传输。

网络模型

网络通信三要素:  IP   端口号    通信协议

IP地址(Internet Protocol Address

    IP是指互联网协议地址,又译为网际协议地址.网络中的计算机使用IP地址来进行唯一标识。

    在Windows系统下,打开cmd,输入命令ipconfig,按回车即可查看。

    本地回环地址(hostAddress):127.0.0.1 ,它代表设备的本地虚拟接口。

端口号

   端口号是计算机中的应用程序的一个整数数字标号,用来区分不同的应用程序。

  0 ~ 1024 未被系统使用或保留的端口号,0 ~ 65535为有效的端口号,也就是说我们要对一些程

序定义端口号的时候,要选择1024 ~ 65535范围内的整数数字。

网络通信协议

       计算机网络中实现通信必须有一些约定,即通信协议,对速率、传输代码、代码结构、 传输控制步骤、出错控制等制定标准。

传输层协议中有两个非常重要的协议:

       传输控制协议TCP(Transmission Control Protocol)

       用户数据报协议UDP(User Datagram Protocol)。

TCP

      使用TCP协议前,须先建立TCP连接,形成传输数据通道

      传输前,采用“三次握手”方式,是可靠的

      TCP协议进行通信的两个应用进程:客户端、服务端

      在连接中可进行大数据量的传输

      传输完毕,需释放已建立的连接,效率低

      在断开时要进行“四次挥手”

三次握手

而用更通俗的语言来说则是这样:

四次挥手

而用更通俗的语言来说则是这样:

UDP

将数据、源、目的封装成数据包,不需要建立连接

 每个数据报的大小限制在64K

 因无需连接,故是不可靠的

 发送数据结束时无需释放资源,速度快

TCP编程

利用套接字(Socket)开发网络应用程序早已被广泛的采用,以至于成为事实上的标准。

   通信的两端都要有Socket,是两台机器间通信的端点

   网络通信其实就是Socket间的通信。

   Socket允许程序把网络连接当成一个流,数据在两个Socket间通过IO传输。

  客户端Socket的工作过程包含以下四个基本的步骤:

1.创建 Socket:

    根据指定服务端的 IP 地址或端口号构造 Socket 类对象。若服务器端响应,则建立客户端到服务器的通信线路。若连接失败,会出现异常。

2.打开连接到 Socket 的输入/出流:

    使用 getInputStream()方法获得输入流

    使用 getOutputStream()方法获得输出流,进行数据传输

3.按照一定的协议对 Socket 进行读/写操作:

     通过输入流读取服务器放入线路的信息(但不能读取自己放入线路的信息),通过输出流将信息写入线程。

4.关闭 Socket:

    断开客户端到服务器的连接,释放线路

客户端程序可以使用Socket类创建对象, 创建的同时会自动向服务器方发 起连接
/*
客户端
 */
public class Client {
    public static void main(String[] args) {
        //创建客户端
        try {
            Socket socket=new Socket("127.0.0.1",6666);//连接自己ip为127.0.0.1
            String s ="你好服务器";
            OutputStream output=socket.getOutputStream();
            output.write(s.getBytes());
        } catch (IOException e) {
            throw new RuntimeException(e);
        }
    }
}

使用包装流输入输出:

public class Client {
    public static void main(String[] args) {

        try {
            Socket socket = new Socket("127.0.0.1",6666);

            String s = "你好服务器";
            DataOutputStream dataOutputStream = new DataOutputStream(socket.getOutputStream());
            dataOutputStream.writeUTF(s);

            DataInputStream dataInputStream  = new DataInputStream(socket.getInputStream());
            String s1 = dataInputStream.readUTF();
            System.out.println(s1);

        } catch (IOException e) {
            e.printStackTrace();
        }
    }
}

服务器程序的工作过程包含以下四个基本的步骤:

1.调用 ServerSocket(int port) :

      创建一个服务器端套接字,并绑定到指定端口上。用于监听客户端的请求。

2.调用 accept():

     监听连接请求,如果客户端请求连接,则接受连接,返回通信套接字对象。

3.调用 该Socket类对象的 getOutputStream() 和 getInputStream ():

     获取输出流和输入流,开始网络数据的发送和接收。

4.关闭ServerSocket和Socket对象:

     客户端访问结束,关闭通信套接字。

服务器建立 ServerSocket 对象

      ServerSocket 对象负责等待客户端请求建立套接字连接,类似邮局某个窗口中的业务员。也就是说,服务器必须事先建立一个等待客户请求建立套接字连接的ServerSocket对象。

/*
服务器
 */
public class Server {
    public static void main(String[] args) {
        try {
            //创建服务器对象
            ServerSocket serverSocket=new ServerSocket(6666);
            System.out.println("服务器启动成功");
            //监听客户端是否向服务器发送链接请求

                Socket socket= serverSocket.accept();
                System.out.println("有客户端连接到了服务器");
                //后续操作
                InputStream input=socket.getInputStream();
                byte[]bytes=new byte[100];
                int size=input.read(bytes);
                String s=new String(bytes,0,size);
                System.out.println(s);


        }catch (IOException e){
                e.printStackTrace();
            System.out.println("服务器启动失败,端口已被占用");
        }
    }
}

使用包装流输入输出:

public class Server {
    public static void main(String[] args) {
        try {
            System.out.println("服务器开始启动");
            ServerSocket serverSocket =   new ServerSocket(6666);
            System.out.println("服务器启动成功");
            Socket socket = serverSocket.accept();

            //包装流 直接读到一个字符串
            DataInputStream dataInputStream = new DataInputStream(socket.getInputStream());
            String s = dataInputStream.readUTF();
            System.out.println(s);

            //从服务器端向客户端发送一个消息
            String s1 = "你好客户端!";

            DataOutputStream dataOutputStream = new DataOutputStream(socket.getOutputStream());
            dataOutputStream.writeUTF(s1);


        } catch (IOException e) {
            e.printStackTrace();
        }
    }
}

UDP编程

    类 DatagramSocket 和 DatagramPacket 实现了基于 UDP 协议网络程序。

    UDP数据报通过数据报套接字 DatagramSocket 发送和接收,系统不保证UDP数据报一定能够安全送到目的地,也不能确定什么时候可以抵达。

     DatagramPacket 对象封装了UDP数据报,在数据报中包含了发送端的IP地址和端口号以及接收端的IP地址和端口号。

     UDP协议中每个数据报都给出了完整的地址信息,因此无须建立发送方和接收方的连接

流程:

1. DatagramSocket与DatagramPacket

2. 建立发送端,接收端

3. 建立数据报

4. 调用Socket的发送、接收方法

5. 关闭Socket

注意:发送端与接收端是两个独立的运行程序

发送端

/*
发送端
 */
public class Send {
    public static void main(String[] args) throws IOException {
        //用来发送和接受数据
        DatagramSocket datagramSocket=new DatagramSocket();
/*
    public DatagramPacket(byte buf[], int offset, int length,
                          InetAddress address, int port) {  参数分别为字节数组,从哪里开始发送 ,发送多长 ,用一个类来分装IP地址,端口
        setData(buf, offset, length);
        setAddress(address);
        setPort(port);
    }
 */
        byte []bytes="你好".getBytes();
        //数据报
        DatagramPacket datagramPacket=new DatagramPacket(bytes,0,bytes.length, InetAddress.getByName("127.0.0.1"),6666);
        //发送
        datagramSocket.send(datagramPacket);


        System.out.println("发送完成");
    }
}

接收端,要指定监听的端口

/*
接收端
 */
public class Receive {
    public static void main(String[] args) throws IOException {
        //用来发送和接受数据
        DatagramSocket datagramSocket=new DatagramSocket(6666);

        //创建一个接受的数据报
        byte[]bytes=new byte[100];
        DatagramPacket datagramPacket=new DatagramPacket(bytes,0,bytes.length);

        //接受
        datagramSocket.receive(datagramPacket);

        String s=new String(bytes,0,datagramPacket.getLength());//datagramPacket.getLength()接受到数据的实际长度

    }
}

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

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

相关文章

浅谈云计算03 | 云计算的技术支撑(云使能技术)

云计算的技术支撑 一、定义与内涵1.1 定义与内涵 二、云计算使能技术架构2.1 宽带网络和 Internet 架构2.2 数据中心技术2.3 虚拟化技术2.4 Web 技术2.5 多租户技术2.6 服务技术 一、定义与内涵 1.1 定义与内涵 云计算技术包含一些基础的关键技术,这里称为使能技术…

腾讯云AI代码助手编程挑战赛-智能聊天助手

作品简介 本作品开发于腾讯云 AI 代码助手编程挑战赛,旨在体验腾讯云 AI 代码助手在项目开发中的助力。通过这一开发过程,体验到了 AI 辅助编程的高效性。 技术架构 前端: 使用 VUE3、TypeScript、TDesign 和 ElementUI 实现。 后端: 基于 Python 开发…

pip install hnswlib安装不成功

参考这个文章解决了问题:ERROR: Could not build wheels for hnswlib, which is required to install pyproject.toml-based projects 以下是我安装的时候,报错: Building wheel for hnswlib (pyproject.toml) ... errorerror: subprocess-e…

OpenGL学习笔记(四):Shader 着色器(GLSL、Shader类封装)

文章目录 GLSL数据类型输入与输出Uniform的使用Shader类封装练习0练习1练习2练习3 前面的文章提到,着色器(Shader)是运行在GPU上的小程序。这些小程序为图形渲染管线的某个特定部分运行。从本质上来说,着色器只是一种把输入转化为输出的程序。着色器也是…

移动云自研云原生数据库入围国采!

近日,中央国家机关2024年度事务型数据库软件框架协议联合征集采购项目产品名单正式公布,移动云自主研发的云原生数据库产品顺利入围。这一成就不仅彰显了移动云在数据库领域深耕多年造就的领先技术优势,更标志着国家权威评审机构对移动云在数…

vLLM私有化部署大语言模型LLM

目录 一、vLLM介绍 二、安装vLLM 1、安装环境 2、安装步骤 三、运行vLLM 1、运行方式 2、切换模型下载源 3、运行本地已下载模型 四、通过http访问vLLM 一、vLLM介绍 vLLM(官方网址:https://www.vllm.ai)是一种用于大规模语言模型&#x…

Dify社区版部署,更换docker.io避免出现安装失败

这几天在部署Dify的社区版,用docker compose进行部署,看Dify里面的部署文档也是相当简单,只需要几个命令就可以执行完成了,但当开始执行的时候就发现会有各种问题。 Docker Compose最好是升级到最新的版本,我们以前用…

IntelliJ IDEA Type Hierarchy Scope Pattern 学习指南

IntelliJ IDEA Type Hierarchy Scope Pattern 学习指南 什么是 Type Hierarchy? Type Hierarchy 是 IntelliJ IDEA 提供的一个工具,允许开发者查看某个类的继承关系及其实现的接口结构。它是理解类关系的重要工具,尤其在处理复杂的继承体系…

Redis数据结构服务器

Redis数据结构服务器 什么是Redis数据结构服务器 的概念和特点 是一个开源(BSD许可),内存中的数据结构存储服务器,可用作数据库、缓存和消息中间件。它支持多种类型的数据结构,如字符串(strings&#xff09…

【Linux】进程结束和进程等待

进程的结束 退出码的认识 在我们学习C/C的时候我们通常在进行写main函数时,main函数主体写完后通常会进行写一条语句 " return 0 " ,这里的这条语句到底是什么意思呢?? 我们知道当在主函数中调用其他函数或者在其他函…

Spring Boot教程之五十五:Spring Boot Kafka 消费者示例

Spring Boot Kafka 消费者示例 Spring Boot 是 Java 编程语言中最流行和使用最多的框架之一。它是一个基于微服务的框架,使用 Spring Boot 制作生产就绪的应用程序只需很少的时间。Spring Boot 可以轻松创建独立的、生产级的基于 Spring 的应用程序,您可…

1月14日作业

将图形类的获取周长和获取面积函数设置成虚函数&#xff0c;完成多态 #include <iostream> #include <cmath> #define PI 3.14159 using namespace std;// 父类&#xff1a;图形类 class Shape { protected:double perimeter;double area; public:Shape():perimet…

基于Springboot + vue实现的文档管理系统

&#x1f942;(❁◡❁)您的点赞&#x1f44d;➕评论&#x1f4dd;➕收藏⭐是作者创作的最大动力&#x1f91e; &#x1f496;&#x1f4d5;&#x1f389;&#x1f525; 支持我&#xff1a;点赞&#x1f44d;收藏⭐️留言&#x1f4dd;欢迎留言讨论 &#x1f525;&#x1f525;&…

Spring Boot 2 学习指南与资料分享

Spring Boot 2 学习资料 Spring Boot 2 学习资料 Spring Boot 2 学习资料 在当今竞争激烈的 Java 后端开发领域&#xff0c;Spring Boot 2 凭借其卓越的特性&#xff0c;为开发者们开辟了一条高效、便捷的开发之路。如果你渴望深入学习 Spring Boot 2&#xff0c;以下这份精心…

高级软件工程-复习

高级软件工程复习 坐标国科大&#xff0c;下面是老师说的考试重点。 Ruby编程语言的一些特征需要了解要能读得懂Ruby程序Git的基本命令操作知道Rails的MVC工作机理需要清楚&#xff0c;Model, Controller, View各司什么职责明白BDD的User Story需要会写&#xff0c;SMART要求能…

easyui datagrid表头和网格错位问题

问题&#xff1a;表头与数据网格错位 解决&#xff1a; 在onLoadSuccess事件中调用fitColumns方法 $(this).datagrid(‘fitColumns’);

React方向:react中5种Dom的操作方式

1、通过原生JS获取Dom去操作 通过document.querySelector(#title)原生js的方式去拿到dom节点&#xff0c;然后去进行操作。 import {Component} from "react";class App extends Component {//定义获取Dom的函数handleGetDom(){let title document.querySelector(#t…

【深度学习】多目标融合算法(二):底部共享多任务模型(Shared-Bottom Multi-task Model)

目录 一、引言 1.1 往期回顾 1.2 本期概要 二、Shared-Bottom Multi-task Model&#xff08;SBMM&#xff09; 2.1 技术原理 2.2 技术优缺点 2.3 业务代码实践 三、总结 一、引言 在朴素的深度学习ctr预估模型中&#xff08;如DNN&#xff09;&#xff0c;通常以一个行…

天机学堂3-ES+Caffeine

文章目录 day05-问答系统表 用户端分页查询问题目标效果代码实现 3.6.管理端分页查询问题ES相关 管理端互动问题分页实现三级分类3.6.5.2.多级缓存3.6.5.3.Caffeine 4.评论相关接口目标效果新增回答或评论 day05-问答系统 效果&#xff1a; 表 互动提问的问题表&#xff1a…

【Docker】Docker部署多种容器

关于docker&#xff0c;Windows上使用Powershell/CMD执行指令&#xff0c;Linux系统直接使用终端执行指令。 docker安装MySQL 拉取MySQL 也可以跳过拉取步骤&#xff0c;直接run&#xff0c;这样本地容器不存在的话&#xff0c;会自动拉取最新/指定的版本。 # 默认拉取最新…