Java网络编程基础详解

目录
  • 网络编程
    • 1.1 概述
    • 1.2、网络通信的要素
      • 1.网络编程中有两个主要的问题
      • 2.网络编程中的三要素
    • 1.3、IP
    • 1.4、端口
    • 1.5、通信协议
      • UDP协议
      • TCP协议
    • 1.6、TCP模拟通信
      • 客户端
      • 服务器
      • 文件上传
    • 1.7、UDP
    • 1.8、URL
      • 实例:
  • 总结

网络编程

1.1 概述

1.2、网络通信的要素

如何实现网络通信?

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

  • 如何定位到网络上的一台或者多台主机

使用cmd——>ping命令,ping一个域名,可以看到访问的主机的IP地址

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-ztQmkDEl-1628853105623)(D:\learningappDataSave\Typora\image\image-20210809212819370.png)]

  • 找到主机之后,如何进行通信。

2.网络编程中的三要素

  • IP
  • 端口号
  • 网络通信协议(udp,tcp类)

1.3、IP

要想让网络中的计算机能够互相通信,必须为每台计算机指定一个标识号,通过这个标识号来指定要接收数据的计算机和识别发送的计算机,而lP地址就是这个标识号。也就是设备的标识

ip地址:InetAddress

  • 使用IP可以唯一定位一台网络上的计算机
  • 本机IP 127.0.0.1 本机localhost(唯一一个没网也能ping得通得ip)
  • ip地址的分类
    • ipv4/ipv6
    • 公网(互联网)/私网(局域网)

可以用InetAddress查询Ip地址。

public class TestInetAddress {
    public static void main(String[] args) {
        try {
            //查询网站IP地址
            InetAddress ip1 = InetAddress.getByName("www.baidu.com");
            System.out.println(ip1);//www.baidu.com/163.177.151.109
            //查询本机
            InetAddress ip2 = InetAddress.getLocalHost();
            System.out.println(ip2);//飞雷神/192.168.153.1
        } catch (UnknownHostException e) {
            e.printStackTrace();
        }

    }
}

还有一个InetSocketAddress类

1.4、端口

网络的通信,本质上是两个应用程序的通信。每台计算机都有很多的应用程序,那么在网络通信时,如何区分这些应用程序呢?如果说IP地址可以唯一标识网络中的设备,那么端口号就可以唯一标识设备中的应用程序了。也就是应用程序的标识

  • 不同的进程有不同的端口号,用来区分应用程序
  • 被规定
    • TCP 0~65535
    • UDP 0~65535
    • 单个协议下,端口不冲突就可以使用。
  • 端口分类
    • 公有端口0~1023

      • HTTP:80
      • HTTPS:443
      • FTP:21
      • Telent:23
  • 程序注册端口012~49151
    • Tomcat:80
    • mysql:3306
    • Oracle:1521
    • 动态、私有

1.5、通信协议

协议:计算机网络中,连接和通信的规则被称为网络通信协议

UDP协议

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

  • UDP是无连接通信协议,即在数据传输时,数据的发送端和接收端不建立逻辑连接。简单来说,当一台计算机向另外一台计算机发送数据时,发送端不会确认接收端是否存在,就会发出数据,同样接收端在收到数据时,也不会向发送端反馈是否收到数据。
  • 由于使用UDP协议消耗资源小,通信效率高,所以通常都会用于音频、视频和普通数据的传输
  • 例如视频会议通常采用UDP协议,因为这种情况即使偶尔丢失一两个数据包,也不会对接收结果产生太大影响。但是在使用UDP协议传送数据时,由于UDP的面向无连接性,不能保证数据的完整性,因此在传输重要数据时不建议使用UDP协议

TCP协议

传输控制协议(Transmission Control Protocol)

  • TCP协议是面向连接的通信协议,即传输数据之前,在发送端和接收端建立逻辑连接,然后再传输数据,它提供了两台计算机之间可靠无差错的数据传输。在TCP连接中必须要明确客户端与服务器端,由客户端向服务端发出连接请求,每次连接的创建都需要经过“三次握手”
  • 三次握手:TCP协议中,在发送数据的准备阶段,客户端与服务器之间的三次交互,以保证连接的可靠

第一次握手,客户端向服务器端发出连接请求,等待服务器确认

第二次握手,服务器端向客户端回送一个响应,通知客户端收到了连接请求

第三次握手,客户端再次向服务器端发送确认信息,确认连接

形象记忆
三次握手(连接)
A:你愁啥?	 发送请求
B:瞅你咋地?	回应请求
A:来干一场!	确认链接

四次挥手:(断开)

1.6、TCP模拟通信

客户端

1.连接服务器

2.发送消息

import java.io.IOException;
import java.io.OutputStream;
import java.net.InetAddress;
import java.net.Socket;
import java.net.UnknownHostException;

//客户端
public class TcpClientDemo01 {

    private static OutputStream os;
    private static Socket socket;

    public static void main(String[] args) {

        try {
            //1.获得服务器的地址、端口号
            InetAddress serverIP = InetAddress.getByName("127.0.0.1");
            int port=9999;//服务器的端口号
            //2.创建一个Sock连接
            socket = new Socket(serverIP,port);
            //使用该链接发送IO流消息
            os = socket.getOutputStream();
            os.write("你好,吃饭了吗?".getBytes());
        } catch (IOException e) {
            e.printStackTrace();
        }finally {//关闭资源
            if(os!=null){
                try {
                    os.close();
                } catch (IOException e) {
                    e.printStackTrace();
                }
            }
            if (socket != null) {
                try {
                    socket.close();
                } catch (IOException e) {
                    e.printStackTrace();
                }
            }
        }
    }
}

服务器

1.建立服务的端口

2.等待用户连接

3.接收用户的消息

import com.sun.xml.internal.messaging.saaj.util.ByteOutputStream;

import java.io.IOException;
import java.io.InputStream;
import java.net.ServerSocket;
import java.net.Socket;

public class TcpServerDemo01 {

    private static ServerSocket serverSocket;
    private static Socket socket;
    private static InputStream stream;
    private static ByteOutputStream baos;

    public static void main(String[] args) throws IOException {
        try {
            //给自己一个地址,端口号
            serverSocket = new ServerSocket(9999);
            while(true) {
                //等待客户端连接
                socket = serverSocket.accept();
                //读取客户端的消息
                stream = socket.getInputStream();

                //管道流
                baos = new ByteOutputStream();
                byte[] bytes = new byte[1024];
                int len;
                while ((len = stream.read(bytes)) != -1) {
                    baos.write(bytes, 0, len);
                }
                System.out.println(baos.toString());
            }
        } catch (IOException e) {
            e.printStackTrace();
        }finally {
            baos.close();
            try {
                stream.close();
            } catch (IOException e) {
                e.printStackTrace();
            }
            try {
                socket.close();
            } catch (IOException e) {
                e.printStackTrace();
            }
            serverSocket.close();
        }

    }
}

文件上传

客服端上传文件

import com.sun.xml.internal.messaging.saaj.util.ByteOutputStream;
import java.io.ByteArrayInputStream;
import java.io.FileInputStream;
import java.io.InputStream;
import java.io.OutputStream;
import java.net.InetAddress;
import java.net.Socket;

public class TcpClientDemo02 {
    public static void main(String[] args) throws Exception {
        //创建一个Socket连接
        Socket socket = new Socket(InetAddress.getByName("127.0.0.1"), 9000);
        //socket的输出流
        OutputStream os = socket.getOutputStream();
        //读取文件的流
        FileInputStream fis = new FileInputStream("bg.jpeg");
        //写出文件

        byte[] bytes = new byte[1024];//缓冲区
        int len;
        while ((len = fis.read(bytes)) != -1) {//读到缓冲区
            os.write(bytes, 0, len);//从缓冲区写到输出流
        }

        //通知服务器,我已经上传完成
        socket.shutdownOutput();

        //接收确定服务器接收完毕的信息,断开连接
        InputStream inputStream = socket.getInputStream();
        ByteOutputStream bost = new ByteOutputStream();
        byte[] bytes2 = new byte[1024];
        int len2;
        while ((len2 = inputStream.read(bytes2)) != -1) {
            bost.write(bytes2,0,len2);
        }
        System.out.println(bost.toString());

        //关闭资源
        bost.close();
        inputStream.close();
        fis.close();
        os.close();
        socket.close();
    }
}

服务器接收文件

package com.yong.tcp;

import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import java.net.ServerSocket;
import java.net.Socket;

public class TcpServerDemo02 {
    public static void main(String[] args) throws IOException {
        //创建链接
        ServerSocket serverSocket = new ServerSocket(9000);
        //监听客户端的连接
        Socket socket = serverSocket.accept();
        //获取输入流
        InputStream inputStream = socket.getInputStream();//阻塞式监听,会一直等待

        //文件输出
        FileOutputStream fos = new FileOutputStream("receiver.jpeg");
        byte[] bytes = new byte[1024];
        int len;
        while ((len = inputStream.read(bytes)) != -1) {
            fos.write(bytes, 0, len);
        }

        //通知客户端,我已接收完毕
        OutputStream os = socket.getOutputStream();
        os.write("我接收完毕了,可以断开链接了".getBytes());

        //关闭资源
        os.close();
        fos.close();
        inputStream.close();
        socket.close();
        serverSocket.close();

    }
}

1.7、UDP

UDP消息发送(聊天实现)

发送方

package com.yong.chat;

import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.net.DatagramPacket;
import java.net.DatagramSocket;
import java.net.InetSocketAddress;

public class ChatSendDemo01 {
    public static void main(String[] args) throws Exception {
        //建立一个端口
        DatagramSocket socket = new DatagramSocket(8888);

        //建立一个包裹
        //准备数据,从控制台
        BufferedReader reader = new BufferedReader(new InputStreamReader(System.in));

        while (true) {

            String data = reader.readLine();//控制台控制输入
            byte[] datas = data.getBytes();
            DatagramPacket packet = new DatagramPacket(datas, 0, data.length(), new InetSocketAddress("localhost", 9999));

            //发送包裹
            socket.send(packet);

            if ("bye".equals(data)) {
                break;
            }

        }
        socket.close();
    }
}

接收方

import java.net.DatagramPacket;
import java.net.DatagramSocket;

public class ChatReceiverDemo01 {
    public static void main(String[] args) throws Exception {
        DatagramSocket socket = new DatagramSocket(9999);

        while (true) {

            //准备接收包裹
            byte[] bytes = new byte[1024];
            DatagramPacket packet = new DatagramPacket(bytes, 0, bytes.length);

            socket.receive(packet);//阻塞式接受包裹
            byte[] data = packet.getData();//拿出消息
            String receiveData = new String(data, 0, data.length);//转为字符串,注意不要导错包

            System.out.println(receiveData);

            //退出接收
            if ("bye".equals(receiveData.trim())) {
                break;
            }

        }
        socket.close();
    }
}

1.8、URL

实例:

爬取网络资源,url是网络资源的地址

import java.io.FileOutputStream;
import java.io.InputStream;
import java.net.HttpURLConnection;
import java.net.URL;

public class UrlDown {
    public static void main(String[] args) throws Exception {
        //下载地址,
        URL url = new URL("https://m701.music.126.net/20210813190206/833ba2325a035b223f2f315a7a5b1d4f/jdyyaac/0353/055e/565e/4910a621a524e5158013a4ccdad535d9.m4a");

        //连接到这个资源
        HttpURLConnection connection = (HttpURLConnection) url.openConnection();

        InputStream is = connection.getInputStream();
        FileOutputStream fos = new FileOutputStream("富士山下(陈奕迅).m4a");

        byte[] bytes = new byte[1024];
        int len;
        while ((len = is.read(bytes)) != -1) {
            fos.write(bytes, 0, len);
        }

        fos.close();
        is.close();
        connection.disconnect();//断开连接
    }
}

总结

本篇文章就到这里了,希望能给你带来帮助,也希望您能够多多关注我们的更多内容!

(0)

相关推荐

  • Java之网络编程案例讲解

    Java基础之网络编程 基本概念 IP:每个电脑都有一个IP地址,在局域网内IP地址是可变的. 网络通信协议:通信协议是对计算机必须遵守的规则,只有遵守这些规则,计算机之间才能进行通信.这就好比在道路中行驶的汽车一定要遵守交通规则一样,协议中对数据的传输格 式.传输速率.传输步骤等做了统一规定,通信双方必须同时遵守,最终完成数据交换. TCP协议(传输控制协议):是面向连接的传输层协议,应用程序在使用TCP之前,必须先建立TCP连接,在传输数据完毕后,必须释放已经建立的连接(跟打电话是否类似).

  • 一篇文章带你入门java网络编程

    目录 基于TCP/IP协议的通信 基于UDP协议的通信 InetAddress 案例演示 (简易聊天室) UDP 演示 总结 基于TCP/IP协议的通信 TCP/IP协议 TCP/IP协议.会在通信两端建立连接(虚拟连接),用于发送和接收数据 TCP/IP协议是一种可靠的网络协议,它通过重发机制来保证这种可靠性 通信的实现 ServerSocket用来监听来自客户端的连接,当没有连接时,它处于阻塞状态 客户端使用Socket连接到指定的服务器 基于UDP协议的通信 UDP协议 UDP协议不会在通

  • Java经典面试题汇总:网络编程

    目录 1. HTTP 响应码 301 和 302 代表的是什么?有什么区别? 2. 简单说一下http协议? 3. HTTP与HTTPS的区别? 4. HTTP协议下客户端请求报文是什么? 5. HTTP协议服务器响应报文有哪些? 6. HTTP协议中的请求方法有哪些? 7. 常见的HTTP状态码有哪些? 8. forward 和 redirect 的区别? 9. 简述 tcp 和 udp的区别? 10. TCP 为什么要三次握手,两次不行吗?为什么? 11. 说一下 TCP 粘包是怎么产生的?

  • Java面试题冲刺第六天--网络编程1

    目录 面试题1:说一下TCP连接的三次握手和四次挥手吧 正经回答: 深入追问: 追问1:为什么连接的时候是三次握手,关闭的时候却是四次握手? 追问2:如果已经建立了连接,但是客户端突然出现故障了怎么办? 面试题2:常见的HTTP状态码有哪些? 正经回答: 面试题3:先说说GET和POST请求有哪些区别吧? 正经回答: 深入追问: 追问1:那Get请求有Request body么?如果有的话参数可以像Post请求一样放在里面么? 追问2:那你刚才说的URL中传送参数的长度限制在Get和Post中都

  • 新手初学Java网络编程

    目录 运行线程 回调 同步方法 同步块 死锁 优先级 暂停 可以对IO阻塞 可以对同步对象阻塞 可以放弃 可以休眠 可以连接另一个线程 可以等待一个对象 可以结束 可以被更高优先级线程抢占 总结 运行线程 创建Thread的子类 public class ThreadChild extends Thread { @Override public void run() { while (true) { System.out.println("run"); } } } public cla

  • Java网络编程基础详解

    目录 网络编程 1.1 概述 1.2.网络通信的要素 1.网络编程中有两个主要的问题 2.网络编程中的三要素 1.3.IP 1.4.端口 1.5.通信协议 UDP协议 TCP协议 1.6.TCP模拟通信 客户端 服务器 文件上传 1.7.UDP 1.8.URL 实例: 总结 网络编程 1.1 概述 1.2.网络通信的要素 如何实现网络通信? 1.网络编程中有两个主要的问题 如何定位到网络上的一台或者多台主机 使用cmd-->ping命令,ping一个域名,可以看到访问的主机的IP地址 [外链图片

  • C++中Socket网络编程实例详解

    C++中Socket网络编程实例详解 现在几乎所有C/C++的后台程序都需要进行网络通讯,其实现方法无非有两种:使用系统底层socket或者使用已有的封装好的网络库.本文对两种方式进行总结,并介绍一个轻量级的网络通讯库ZeroMQ.  1.基本的Scoket编程 关于基本的scoket编程网络上已有很多资料,作者在这里引用一篇文章中的内容进行简要说明. 基于socket编程,基本上就是以下6个步骤: 1.socket()函数 2.bind()函数 3.listen().connect()函数 4

  • java多线程编程技术详解和实例代码

     java多线程编程技术详解和实例代码 1.   Java和他的API都可以使用并发. 可以指定程序包含不同的执行线程,每个线程都具有自己的方法调用堆栈和程序计数器,使得线程在与其他线程并发地执行能够共享程序范围内的资源,比如共享内存,这种能力被称为多线程编程(multithreading),在核心的C和C++语言中并不具备这种能力,尽管他们影响了JAVA的设计. 2.   线程的生命周期 新线程的生命周期从"新生"状态开始.程序启动线程前,线程一直是"新生"状态:

  • java网络编程基础知识介绍

    网络基础知识 1.OSI分层模型和TCP/IP分层模型的对应关系 这里对于7层模型不展开来讲,只选择跟这次系列主题相关的知识点介绍. 2.七层模型与协议的对应关系 网络层 ------------ IP(网络之间的互联协议) 传输层 ------------ TCP(传输控制协议).UDP(用户数据报协议) 应用层 ------------ Telnet(Internet远程登录服务的标准协议和主要方式).FTP(文本传输协议).HTTP(超文本传送协议) 3.IP地址和端口号 1.ip地址用于

  • Java并发编程之详解CyclicBarrier线程同步

    CyclicBarrier线程同步 java.util.concurrent.CyclicBarrier提供了一种多线程彼此等待的同步机制,可以把它理解成一个障碍,所有先到达这个障碍的线程都将将处于等待状态,直到所有线程都到达这个障碍处,所有线程才能继续执行. 举个例子:CyclicBarrier的同步方式有点像朋友们约好了去旅游,在景点入口处集合,这个景点入口就是一个Barrier障碍,等待大家都到了才一起进入景点游览参观. 进入景点后大家去爬山,有的人爬得快,有的人爬的慢,大家约好了山顶集合

  • Java并发编程之详解ConcurrentHashMap类

    前言 由于Java程序员常用的HashMap的操作方法不是同步的,所以在多线程环境下会导致存取操作数据不一致的问题,Map接口的另一个实现类Hashtable 虽然是线程安全的,但是在多线程下执行效率很低.为了解决这个问题,在java 1.5版本中引入了线程安全的集合类ConcurrentMap. java.util.concurrent.ConcurrentMap接口是Java集合类框架提供的线程安全的map,这意味着多线程同时访问它,不会影响map中每一条数据的一致性.ConcurrentM

  • Java基于Socket实现网络编程实例详解

    一,网络编程中两个主要的问题 一个是如何准确的定位网络上一台或多台主机,另一个就是找到主机后如何可靠高效的进行数据传输. 在TCP/IP协议中IP层主要负责网络主机的定位,数据传输的路由,由IP地址可以唯一地确定Internet上的一台主机. 而TCP层则提供面向应用的可靠(tcp)的或非可靠(UDP)的数据传输机制,这是网络编程的主要对象,一般不需要关心IP层是如何处理数据的. 目前较为流行的网络编程模型是客户机/服务器(C/S)结构.即通信双方一方作为服务器等待客户提出请求并予以响应.客户则

  • Java网络编程基础篇之单向通信 原创

    在网络编程中如果只要求客户机向服务器发送消息,不要求服务器向客户机发送消息,称为单线通信.客户机套接字和服务器套接字链接成功后,可估计通过输出流发送数据,服务器则通过输入流接受数据,下面是简单的单向通信的例子. 实例1:本实例是一个TCP服务器端程序,在 getserver() 方法中建立服务器套接字,调用getClienMessage()方法获取客户端信息.代码如下: import java.io.BufferedReader; import java.io.IOException; impo

  • iOS socket网络编程实例详解

    代码下载 服务端代码下载地址 客户端代码下载地址 相关概念 socket是一个针对TCP和UDP编程的接口,你可以借助它建立TCP连接等.socket是对TCP/IP协议的封装,Socket本身并不是协议,而是一个调用接口(API),通过Socket,我们才能使用TCP/IP协议.Socket的出现只是使得程序员更方便地使用TCP/IP协议栈而已,是对TCP/IP协议的抽象,从而形成了我们知道的一些最基本的函数接口. socket连接:socket连接就是所谓的长连接,理论上客户端和服务器端一旦

  • JAVA多线程编程实例详解

    本文实例讲述了JAVA多线程编程.分享给大家供大家参考,具体如下: 进程是系统进行资源调度和分配的一个独立单位. 进程的特点 独立性:进程是系统中独立存在的实体,拥有自己的独立资源和私有空间.在没有经过进程本身允许的情况下,不能直接访问其他进程. 动态性:进程与程序的区别在于,前者是一个正在系统中活动的指令,而后者仅仅是一个静态的指令集合 并发性:多个进程可以在单个处理器上并发执行,而不受影响. 并发性和并行性的区别: 并行性:在同一时刻,有多条指令在多个处理器上同时执行(多个CPU) 并发性:

随机推荐