IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 网络协议 -> 区块链中Java基于WebSocket构建P2P网络 -> 正文阅读

[网络协议]区块链中Java基于WebSocket构建P2P网络

一、pom依赖

       <dependency>
            <groupId>org.java-websocket</groupId>
            <artifactId>Java-WebSocket</artifactId>
            <version>1.5.1</version>
        </dependency>

二、服务端代码

package com.peck.blockchain.p2p;

import org.java_websocket.WebSocket;
import org.java_websocket.handshake.ClientHandshake;
import org.java_websocket.server.WebSocketServer;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.core.annotation.Order;
import org.springframework.stereotype.Component;
import org.testng.util.Strings;

import javax.annotation.PostConstruct;
import java.net.InetSocketAddress;
import java.util.ArrayList;
import java.util.List;

/**
 * @author songanning
 * @ClassName:P2pPointServer
 * @Description:基于springBoot的WebSocket服务端
 * @Date:2021/11/23 10:18
 */
@Component
public class P2pPointServer {
    /**
    * 日志记录
    */
    private Logger logger = LoggerFactory.getLogger(P2pPointServer.class);

    /**
    * 本机Server的WebSocket端口
     * 多机测试可以改变该值
    */
    private int port = 7001;

    /**
    * 所有连接到服务端的WebSocket缓存器
    */
    private List<WebSocket> localSockets = new ArrayList<WebSocket>();

    public List<WebSocket> getLocalSockets() {
        return localSockets;
    }

    public void setLocalSockets(List<WebSocket> localSockets) {
        this.localSockets = localSockets;
    }

    /**
     * 初始化P2P Server端
     *
     */
    @PostConstruct
    @Order(1)
    public void initServer() {
        /**
        * 初始化WebSocket的服务端定义内部类对象socketServer,源于WebSocketServer;
         * new InetSocketAddress(port) 是WebSocketServer构造器的参数
         * InetSocketAddress是(Ip地址+端口号)类型,即端口地址类型
        */
        final WebSocketServer socketServer = new WebSocketServer(new InetSocketAddress(port)) {
            /**
            * 重写5个事件方法,事件发生时触发对应的方法
            */
            @Override
            //创建连接成功时触发
            public void onOpen(WebSocket webSocket, ClientHandshake clientHandshake) {
                sendMessage(webSocket,"北京服务端成功创建连接");
                //当成功创建一个WebSocket连接时,将该链接加入连接池
                localSockets.add(webSocket);
            }

            @Override
            //断开连接时触发
            public void onClose(WebSocket webSocket, int i, String s, boolean b) {
                logger.info(webSocket.getRemoteSocketAddress() + "客户端与服务器断开连接!");
                //当客户端断开连接时,WebSocket连接池删除该链接
                localSockets.remove(webSocket);
            }

            @Override
            //收到客户端发送来的消息时触发
            public void onMessage(WebSocket webSocket, String msg) {
                logger.info("北京服务端接收到客户端消息:" + msg);
                sendMessage(webSocket,"收到消息");
            }

            @Override
            //连接发生错误时调用,紧接着触发onClose方法
            public void onError(WebSocket webSocket, Exception e) {
                logger.info(webSocket.getRemoteSocketAddress() + "客户端连接错误!");
                localSockets.remove(webSocket);
            }

            @Override
            public void onStart() {
                logger.info("北京服务端监听socketServer端启动......");
            }
        };
        socketServer.start();
        logger.info("北京服务端监听socketServer端口:" + port);
    }
    /**
    * 向连接到本机的某客户端发送消息
    */
    public void sendMessage(WebSocket ws,String message) {
        logger.info("发送给" + ws.getRemoteSocketAddress().getPort() + "的篇p2p消息是:" + message);
        ws.send(message);
    }

    /**
     * 向所有连接到本机的客户端广播消息
     * @param message
     */
    public void broatcast(String message) {
        if (localSockets.size() == 0 || Strings.isNullOrEmpty(message)) {
            return;
        }

        logger.info("Glad to say broatcast to clients being startted!");
        for (WebSocket socket : localSockets) {
            this.sendMessage(socket,message);
        }
        logger.info("Glad to say broatcast to clients has overred!");
    }
}

三、客户端代码

package com.peck.blockchain.p2p;

import org.java_websocket.WebSocket;
import org.java_websocket.client.WebSocketClient;
import org.java_websocket.handshake.ServerHandshake;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.core.annotation.Order;
import org.springframework.stereotype.Component;
import org.testng.util.Strings;

import javax.annotation.PostConstruct;
import java.net.URI;
import java.net.URISyntaxException;
import java.util.ArrayList;
import java.util.List;


/**
 * @author songanning
 * @ClassName:P2pPointClient
 * @Description:基于SpringBoot的WebSocket客户端
 * @Date:2021/11/23 11:09
 */
@Component
public class P2pPointClient {
    /**
    * 日志记录
    */
    private Logger logger = LoggerFactory.getLogger(P2pPointClient.class);

    /**
    * p2p 网络中的节点既是服务端,又是客户端。作为服务端运行在7001端口
     * (P2pPointServer 的port字段),同时作为客户通过ws://localhost:7001连接到服务器
    */
    private String wsUrl = "ws://localhost:7001/";

    /**
    * 所有客户端WebSocket的连接池缓存
    */
    private List<WebSocket> localSockets = new ArrayList<>();

    public List<WebSocket> getLocalSockets() {
        return localSockets;
    }

    public void setLocalSockets(List<WebSocket> localSockets) {
        this.localSockets = localSockets;
    }

    /**
    * 连接到服务器
    */
    @PostConstruct
    @Order(2)
    public void connentPeer() {
        try {
            final WebSocketClient socketClient = new WebSocketClient(new URI(wsUrl)) {
                @Override
                public void onOpen(ServerHandshake serverHandshake) {
                    sendMessage(this,"北京客户端成功创建客户端");
                    localSockets.add(this);
                }

                @Override
                public void onMessage(String msg) {
                    logger.info("北京客户端收到北京服务端发送的消息:" + msg);
                }

                @Override
                public void onClose(int i, String s, boolean b) {
                    logger.info("北京客户端关闭");
                    localSockets.remove(this);
                }

                @Override
                public void onError(Exception e) {
                    logger.info("北京客户端报错");
                    localSockets.remove(this);
                }
            };
            //客户端开始连接服务端
            socketClient.connect();
        }catch (URISyntaxException e) {
            e.printStackTrace();
        }
    }

    /**
     * 向服务端发送消息,当前WebSocket的远程Socket地址就是服务端
     * @param ws
     * @param message
     */
    public void sendMessage(WebSocket ws,String message) {
        logger.info("发送给" + ws.getRemoteSocketAddress().getPort() + "的p2p消息:" + message);
        ws.send(message);
    }

    /**
     * 向所有连接过的服务端广播消息
     * @param message 待广播的消息
     */
    public void broadcast(String message) {
        if (localSockets.size() == 0 || Strings.isNullOrEmpty(message)) {
            return;
        }
        logger.info("Glad to say broatcast to servers being startted!");
        for (WebSocket socket:localSockets) {
            this.sendMessage(socket,message);
        }
        logger.info("Glad to say broatcast to servers has overred!");
    }
}

四、运行截图

在这里插入图片描述

  网络协议 最新文章
使用Easyswoole 搭建简单的Websoket服务
常见的数据通信方式有哪些?
Openssl 1024bit RSA算法---公私钥获取和处
HTTPS协议的密钥交换流程
《小白WEB安全入门》03. 漏洞篇
HttpRunner4.x 安装与使用
2021-07-04
手写RPC学习笔记
K8S高可用版本部署
mySQL计算IP地址范围
上一篇文章      下一篇文章      查看所有文章
加:2021-11-24 08:19:34  更:2021-11-24 08:21:32 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年7日历 -2024/7/3 21:24:04-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码