用java实现客服聊天+网络爬虫下载音乐(java网络编程,io,多线程)

一 灵感:

在2022年的暑假,也就是我即将迈进高三的那个暑假,我并没有察觉自己应该要学习了,还是和过往的暑假一样玩着王者荣耀,凌晨2点睡觉,中午12点起床。我依稀记得这种状态一直持续到8月19。然而离开学还有6天时。我肚子开始剧烈的疼痛。想了一切可以的办法来恢复但是无极于终。我上百度去搜索,搜到了些眉目,我也进入了济南一家肠胃医院的网站。下面一幅图就是我咨询的聊天。那么你知道这种技术是怎么实现的吗?就是基本的网上聊天。还有一些咨询网站的客服聊天。

二 通信基本概念--实现网上聊天理论

计算机网络

①我们目的是为了写出一个后台聊天,为什么还要了解计算机网络呢?因为聊天的本质就是在计算机网络下进行的。
②何为计算机网络?通过百科搜索我们能查询到计算机网络其实就是一些相互连接的、以资源共享为目的的、自治的计算机的集合。通俗点讲就是计算机网络就像一个巨大的邮局,不同的计算机就像不同的信箱,通过电线或无线信号来传递信息
③通信就要用各种协议比如早期的http协议和更加安全的Https协议(https经过加密和身份验证)。通信协议就像是一套规则和标准,确保计算机网络中的设备能够正确地发送和接收信息。它定义了数据如何被封装、地址信息如何被添加、以及错误如何被检测和纠正等。协议就是不同计算机遵循的规则。
④https和http只不过是应用层协议我们常见的两种。还有很多这里就不一一赘述。下面要讲的TCP,UDP是传输层的协议与我们今天要讲的聊天密切相关。
⑤每个计算机都有它的IP就是地址。有各自的IP我们才能传送数据。IPv6格式能分配的地址非常多据说可以为地球的每一粒沙子分配地址。
⑥端口就是用来区分每个软件或进程的。在下面代码中我们会用到。
⑦接下来的测试将在本地进行。要用到特殊地址127.0.0.1。

三 TCP

TCP实现聊天:分为客户端和服务端。客户端用来构造连接,发送信息。服务端用来接受信息,输出信息。

我们用TCP实现简单文字传输:
//客户端
package chat;

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



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


        try {
            //获取服务端的地址
            InetAddress serverIp = InetAddress.getByName("127.0.0.1");
            int port = 9999;
            //创见一个Socket连接
            Socket socket = new Socket(serverIp, port);  //一步化简--》  Socket socket = new Socket(InetAddress.getName(""), 5555);
            //发送信息创建io流
            OutputStream os=socket.getOutputStream();
            os.write("你好".getBytes());

           os.close();
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
}
//服务端

package chat;

import java.io.ByteArrayInputStream;
import java.io.ByteArrayOutputStream;
import java.io.InputStream;
import java.net.ServerSocket;
import java.net.Socket;

//服务器端
public class TcpServerDemo1 {
    public static void main(String[] args) {
        ByteArrayOutputStream bao=null;
        //地址 端口号
        try {
            ServerSocket serverSocket = new ServerSocket(9999);
            //等待客户端连接过来
            Socket socket=serverSocket.accept();
            //读取客户端的信息
            InputStream is=socket.getInputStream();
            //管道流
             bao=new ByteArrayOutputStream();
            byte[]buffs=new byte[1024];
            int len;
            while((len=is.read(buffs))!=-1){
                bao.write(buffs,0,len);

                System.out.println(bao.toString());
                //关闭



            }

        }catch(Exception e){
            e.printStackTrace();
        }
        finally{
            if(bao!=null) {
                try {
                    bao.close();


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

                }
            }

        }
    }
}
我们用TCP实现文件上传(与上面代码很是相似但略有不同):
//客户端


package file;
import java.io.*;
import java.net.InetAddress;
import java.net.Socket;
import java.net.UnknownHostException;

//文件上传
public class TcpClientDemo2 {
    public static void main(String[] args) {
        try {
            //获取连接
            Socket socket=new Socket(InetAddress.getByName("127.0.0.1"),5555);
            //文件输出--》创建一个输出流
            OutputStream os=socket.getOutputStream();
            //读取文件
            FileInputStream fis=new FileInputStream(new File("C://Users//hp//OneDrive//图片//本机照片//微信图片_20240227182056.jpg"));
            int len;
            byte[]buffs=new byte[2014];
            while((len=fis.read(buffs))!=-1){
                os.write(buffs,0,len);//写进来再输出去
            }
            //写一个传送完成的标志,告诉服务器已经结束了
            socket.shutdownOutput();
            //当传送完成时应该输出语句输送成功
            InputStream is=socket.getInputStream();
            //管道输出
            ByteArrayOutputStream byteArrayOutputStream=new ByteArrayOutputStream();
            int len1;
            byte[]buffs1=new byte[2024];
            while((len1=is.read(buffs1))!=-1){
                byteArrayOutputStream.write(buffs1,0,len1);
            }
            System.out.println(byteArrayOutputStream.toString());


byteArrayOutputStream.close();
is.close();
            fis.close();
            os.close();
            socket.close();


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

}
//服务端

package file;
import java.io.*;
import java.net.ServerSocket;
import java.net.Socket;
import java.net.SocketAddress;

public class TcpServerDemo2 {
    public static void main(String[] args) {
        try {
            //服务端的端口
            ServerSocket serverSocket=new ServerSocket(5555);
            //等待接受,阻塞式监听会一直等待
            Socket socket=serverSocket.accept();
            //获取输入流
            InputStream is=socket.getInputStream();
            //文件输出
            FileOutputStream fos=new FileOutputStream(new File("receive.jpg"));  //命了个名
            int len;
            byte[]buffs=new byte[2024];
            while((len=is.read(buffs))!=-1){
                fos.write(buffs,0,len);//写进来输出
            }
            //输出输出完成
            //输出流
            OutputStream os=socket.getOutputStream();
            os.write("输送成功".getBytes());


            fos.close();
            is.close();
            socket.close();
            serverSocket.close();


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

}

文件上传成功后,我们文件会出现在最下面如图所示:

四 UDP

既然上面已经通过TCP实现交流了为什么还要UDP实现交流呢?这不得不提一下两者的差别。TCP协议需要进行连接,而UDP协议不需要进行连接,随便传送。

//建立一个Socket
DatagramSocket socket=new DatagramSocket();
//建立一个数据包
String msg="新年快乐";
InetAddress localhost=InetAddress.getByName("localhost");
int port=5555;
DatagramPacket packet=new DatagramPacket(msg.getBytes(),msg.getBytes().length,localhost,port);
//发送数据包
socket.send(packet);
//关闭
socket.close();
  //开发端口
    DatagramSocket socket=new DatagramSocket(5555);
    //接受数据包
    byte[]buffs=new byte[1024];
    DatagramPacket packet=new DatagramPacket(buffs,0,buffs.length);
    socket.receive(packet);
    System.out.println(packet.getAddress().getHostAddress());
    System.out.println(new String(packet.getData(),0, packet.getLength()));

通过上面的代码可以发现:UDP在客户端先建立一个socket连接,建立包,发送包的过程。然而没有了服务端这一概念,不需要进行连接而是接受包输出包的过程。

由此我们可以实现互发消息,通过多线程。

//发送消息


package send;

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.net.*;
import java.nio.charset.StandardCharsets;

public class UdpSend implements Runnable{
    DatagramSocket socket=null;
    BufferedReader reader=null;
    private int fromPort;
    private String toIp;
    private int toPort;

    public UdpSend(int fromPort, String toIp, int toPort) throws Exception {
        this.fromPort = fromPort;
        this.toIp = toIp;
        this.toPort = toPort;
        socket=new DatagramSocket(fromPort);
        reader=new BufferedReader(new InputStreamReader(System.in));

    }

    @Override
    public void run() {



        //准备数据控制台读取-->打包进去


        while (true) {


            try {
                String data = reader.readLine();
                byte[] datas;
                datas = data.getBytes();
                DatagramPacket packet = new DatagramPacket(datas, 0, datas.length, new InetSocketAddress(this.toIp, this.toPort));
                socket.send(packet);
                if (data.equals("bye")) {
                    break;
                }

            } catch (IOException e) {
                throw new RuntimeException(e);
            }
            //发送



        }

        socket.close();

    }



    }

//接受消息

package send;

import java.io.IOException;
import java.net.DatagramPacket;
import java.net.DatagramSocket;
import java.net.SocketException;
import java.nio.charset.StandardCharsets;

public class UdpReceive implements Runnable{
    DatagramSocket socket=null;
    private int port;
    private String msg;
    public UdpReceive(int port,String msg) throws Exception {
        this.port=port;
        this.msg=msg;
        socket=new DatagramSocket(port);
    }


        public void run(){
        while(true) {

            try {
                //准备接受包裹
                byte[] container = new byte[2024];
                DatagramPacket packet = new DatagramPacket(container, 0, container.length);
                //接受
                socket.receive(packet);
                //断开连接
                int length = packet.getLength();
                byte[] data = packet.getData();
                String receiveD = new String(data, 0, length);
                System.out.println(msg+":"+receiveD);

                if (receiveD.equals("bye")) {
                    break;
                }
            } catch (IOException e) {
                throw new RuntimeException(e);
            }



        }
            socket.close();

        }


    }


老师类:

package send;

public class tackTeacher {
    public static void main(String[] args) throws Exception {
        new Thread(new UdpSend(4444,"localhost",7777)).start();
        new Thread(new UdpReceive(8888,"学生")).start();

    }

}

学生类:

package send;

public class tackStudent {
    public static void main(String[] args) throws Exception {
        new Thread(new UdpSend(5555,"localhost",8888)).start();
        new Thread(new UdpReceive(7777,"老师")).start();

    }
}

五 URL

URL其实就相当于网络爬虫,下载网络视频音乐等。

这里是一段下载音乐的代码:

package U;

import java.io.FileOutputStream;
import java.io.InputStream;
import java.net.*;

public class UrlDown {
    public static void main(String[] args) throws Exception {
        //下载地址
        URL url=new URL("\n" +
                "https://m804.music.126.net/20240601202251/50656d3a6d5b5489905b09e4ada8bef2/jdyyaac/obj/w5rDlsOJwrLDjj7CmsOj/34873299362/7d37/4c2f/3640/245ede6e6294337d349d85532c0abcc3.m4a");
        //连接到这个资源
        HttpURLConnection connection=(HttpURLConnection)url.openConnection();
        //输入
        InputStream is=connection.getInputStream();
        FileOutputStream fos=new FileOutputStream("f.m4a");
        byte[]buffs=new byte[1024];
        int len;
        while((len=is.read(buffs))!=-1){
            fos.write(buffs,0,len);

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

    }
}

如果包最下面出现如图情况就说明下载完成了。如果还有什么不懂的地方或者没有实现,可以私信我或在评论区留下您的问题。

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

最全!最新!最细!Redis数据库从入门到应用

#前言: 该博客会详细介绍关于Redis数据库的内容,代码多有注释,最后会讲解如何将Redis应用(以Python与Django为例)。各位的点赞与关注将是小编变强的最大动力。 一、Redis数据库简介: Redis是一个开源的内…

fyne widget小部件2

fyne widget小部件2 form表单 package mainimport ("log""fyne.io/fyne/v2/app""fyne.io/fyne/v2/widget" )func main() {myApp : app.New()myWindow : myApp.NewWindow("Form Widget")entry : widget.NewEntry()textArea : widget.…

Stable Diffusion详细教程

目录 🐋引言 🐋Stable Diffusion基本概念 🦈潜在扩散模型 🦈图像生成原理 🐋Stable Diffusion安装部署 🦈环境要求 🦈安装步骤 🐋Stable Diffusion阶段 🦈准备阶…

正弦、余弦、正切

正弦、余弦、正切这三个概念都是在一个直角三角形这样一个上下文环境里定义的。在一个直角三角形中,斜边叫弦。 正弦(sine) 在一个给定的角θ,它的正弦就是这个角θ对着的直角边与弦的比值,记为sineθ。 余弦&#…

你想让ai干苦力,ai会叫你没脾气(问题实例)

当你想让ai生成的代码直接编译 - 你先要问自己一个直击灵魂的主题:我的修养配得上我的能力吗? 已发现存在需手动修复的问题 - 1/(马大哈)对于sdk理解的不 细致 ,会用基类函数来代替派生类函数; 比如&#…

【kubernetes】探索k8s集群的pod控制器详解(Deployment、StatefulSet、DaemonSet、Job、CronJob)

目录 一、Pod控制器及其功用 二、pod控制器有多种类型 2.1ReplicaSet 2.1.1ReplicaSet主要三个组件组成 2.2Deployment 2.3DaemonSet 2.4StatefulSet 2.5Job 2.6Cronjob 三、Pod与控制器之间的关系 3.1Deployment 3.2SatefulSet 3.2.1StatefulSet三个组件 3.2.2为…

7 款最佳 iPhone 解锁软件和应用程序

在 iOS 上反复失败的解锁尝试可能会导致 iPhone 永久禁用。适当的iPhone解锁器可以帮助恢复您的设备。大多数解锁器的成功率和可靠性都很低。这就是为什么从最好的 iPhone 解锁器中进行选择可以帮助绕过 MDM、删除密码运营商锁定并重新获得 iCloud 访问权限很重要的原因。 7 款…

Windows安装Docker

启用虚拟化 打开 勾选Hyper-V 验证 下载Docker Docker官网 阿里云 安装Docker 傻瓜式安装 遇到问题: 打开命令窗口,执行命令: wsl --update升级完成之后点击Restart按钮即可 切换阿里镜像 https://fmkoym4e.mirror.aliyuncs.com

cocos入门3:新建项目

Cocos Creator 新建项目教程 第一步:启动 Cocos Creator 打开你的计算机,找到并双击 Cocos Creator 的启动图标。如果你尚未安装 Cocos Creator,请首先访问其官方网站(https://www.cocos.com/creator/)下载并安装。 …

使用eclipse自动生成实体类

前言 在软件开发过程中,经常需要创建大量的实体类来映射数据库表或者表示业务模型。手动编写实体类既费时又容易出错,因此许多集成开发环境(IDE)提供了自动生成实体类的功能。本篇博客将介绍如何在 Eclipse 中内置功能来快速生成实…

MyBatis中的接口代理机制及其使用

1. MyBatis中的接口代理机制及其使用 文章目录 1. MyBatis中的接口代理机制及其使用2. 实操2.1 准备工作2.2 insert 增加操作2.3 delete 删除操作2.4 update 修改操作2.5 select 查询一条记录操作2.6 select 查询多条记录操作 3. 总结:4. 最后: MyBatis …

Winddow系统下关于Golang使用Cgo的配置

1.配置CGO_ENABLED为1 go env -w CGO_ENABLED1 2.安装gcc环境,否则出现cgo: C compiler "gcc" not found: exec: "gcc": executable file not found in %PATH%错误 安装包:链接:https://pan.baidu.com/s/1sgF9lijqGeP…

50个常用的Docker命令及如何使用

这里整理了50个常用的Docker命令以及每个命令的使用方法。 docker version:显示Docker版本信息。 示例:docker version docker info:显示Docker系统信息。 示例:docker info docker pull <image>:从Docker Hub下载镜像。 示例:docker pull ubuntu docker run <i…

列表标签 ul+ol/li

04-07、列表标签 ulol/li 概述 列表标签&#xff1a;无序列表ulli、有序列表olli和定义列表 dl dt dd 三种&#xff0c;在网页制作中应用非常广泛&#xff0c;列表就是信息资源的一种展示形式。 特点&#xff1a; 它们都是块元素&#xff0c;可以受到宽度&#xff0c;高度&…

ABP框架+Mysql(二)

展示页面--图书列表页面 本地化 开始的UI开发之前,我们首先要准备本地化的文本(这是你通常在开发应用程序时需要做的).本地化文本在前端页面会常用。 本地化文本位于 Acme.BookStore.Domain.Shared 项目的 Localization/BookStore 文件夹下: 打开 en.json (英文翻译)文件并更…

6.1Java方法

1、方法定义&#xff1a; 方法是一种语法结构&#xff0c;它可以把一段代码封装成一个功能&#xff0c;以便重复调用 方法的完整格式&#xff1a; 修饰符 返回类型 方法名(形参列表){ 方法体代码(需要执行的功能代码) return 返回值; } package com.define;public class …

每日一题——力扣20. 有效的括号(举一反三+思想解读+逐步优化)

一个认为一切根源都是“自己不够强”的INTJ 个人主页&#xff1a;用哲学编程-CSDN博客专栏&#xff1a;每日一题——举一反三Python编程学习Python内置函数 Python-3.12.0文档解读 目录 我的写法 专业点评 时间复杂度分析 空间复杂度分析 代码优化建议 我要更强 优化…

强烈推荐|分享6款小而美的图片美化工具

给大家分享6个我日常用到的图片美化软件&#xff0c;都是免费且好用的&#xff0c;如果大家觉得有用&#xff0c;求一个点赞收藏&#xff0c;如果点赞收藏超过60&#xff0c;后续我会继续分享&#xff0c;谢谢大家&#xff5e; 文字卡片美化&#xff1a; https://www.memocar…

C语言实现贪吃蛇小游戏(控制台)

本篇主要内容是使用C语言在Windows环境的控制台中模拟实现经典小游戏贪吃蛇。 一、准备工作 我们要实现的基本功能有&#xff1a; 地图绘制蛇吃食物的功能&#xff08;上、下、左、右方向键控制蛇的动作&#xff09;蛇撞墙死亡蛇撞自身死亡计算得分蛇身加速、减速暂停游戏 …

数据恢复大革新!EasyRecovery16版本带来UIUX及性能的重大提升

全球领先的数据恢复解决方案提供商Ontrack与其中国区总代理近日共同宣布&#xff0c;其广受欢迎的数据恢复软件EasyRecovery16迎来了重大更新&#xff0c;版本号提升至v16.0.0.5。这一更新为用户带来了一系列值得关注的新功能和改进&#xff0c;进一步巩固了EasyRecovery在数据…