JMeter 实现 Protobuf 加密解密

一、 .proto文件编译成.jar文件

相关依赖下载详见:将 message.proto 编译成 .jar文件

1.依赖于java编译环境
2.依赖protoc编译jar包

编译目录

1.创建一个根目录:protobuf
2.在protobuf下创建buildoutputlibsrc目录
在这里插入图片描述
lib:放 protobuf-java-4.31.1.jar
src:放 xxx.proto
在这里插入图片描述

准备.proto 文件

将准备好的.protp 文件放入src目录下

syntax = "proto3"; option java_package = "com.message.proto";
option java_outer_classname = "MessageProBuf";package Message;//消息的头信息
message MessageHead
{string from = 1;string to = 2;string messageId = 3;int32 chatType = 4;}//消息的 body 
message ChatMessage
{MessageHead messageHead=1;string fromUserId = 2;string toUserId= 3;int64 timeSend= 4;int32 type= 5;string content=6;
}

将.proto文件编译.java 文件

执行命令:

cd .\src\
protoc --java_out=../output message.proto

命令执行完成后,根据.proto 文件中的 java_package、java_outer_classname 生成对应的包目录和文件名,示例如下:
在这里插入图片描述
在这里插入图片描述

使用javac命令将MessageProBuf.java编译成.class文件

这里依赖protobuf-java-4.31.1.jar 库,所以需要根目录下创建一个lib目录,并将protobuf-java-4.31.1.jar文件放到lib目录下
在这里插入图片描述

cd ..\lib\
javac -encoding UTF-8 -cp ".;protobuf-java-4.31.1.jar" -d ..\build ..\output\com\message\proto\MessageProBuf.java 

使用 jar 命令将所有 .class 文件打包成 .jar 文件

cd ..\build\
jar cf message-protobuf.jar com/

在这里插入图片描述

示例完整命令汇总

:: .proto文件编译为.java文件
cd .\src\
protoc --java_out=../output message.proto:: .java文件编译为.class文件
cd ..\lib\
javac -encoding UTF-8 -cp ".;protobuf-java-4.31.1.jar" -d ..\build ..\output\com\message\proto\MessageProBuf.java :: .class文件编译为.jar包
cd ..\build\
jar cf message-protobuf.jar com/

二、编写 .groovy文件编译成.jar文件

相关依赖下载详见:JMeter groovy 编译成.jar 文件

编译目录

1.创建一个根目录:groovy
2.在protobuf下创建buildlibsrc目录
在这里插入图片描述
lib:放 message-protobuf.jarprotobuf-java-4.31.1.jar 等jar包
src:放 .groovy 文件
在这里插入图片描述

准备 MessageBuilder.groovy (消息构建文件)

// 导入 .proto 文件中的包名和类名
import com.message.proto.MessageProBuf
java_package :com.message.proto
java_outer_classname:MessageProBuf

import com.message.proto.MessageProBuf  // .proto 中的java_package、java_outer_classname
import com.google.protobuf.MessageLite/*** 消息构建工具类*/
class MessageBuilder {/*** 构建单聊消息* @param fromUserId 发送者ID* @param fromUserName 发送者名称* @param toUserId 接收者ID* @param toUserName 接收者名称* @param content 消息内容* @param messageId 消息ID(可选)* @return 构建完成的 MessageLite 对象*/static MessageLite buildChatMessage(String fromUserId, String fromUserName,String toUserId, String toUserName,String content, String messageId = null) {if (messageId == null) {messageId = UUID.randomUUID().toString()}return MessageProBuf.ChatMessage.newBuilder().setMessageHead(MessageProBuf.MessageHead.newBuilder().setFrom("${fromUserId}/pc").setTo(toUserId).setMessageId(messageId).setChatType(1)) // 单聊.setFromUserId(fromUserId).setFromUserName(fromUserName).setToUserId(toUserId).setToUserName(toUserName).setContent(content).setType(1) // 文本消息.setTimeSend(System.currentTimeMillis()).setIsReadDel(false).setIsEncrypt(false).setSeqNo(-1).build()}// ...  构建其他消息类型省略
}

准备 ProtobufParser.groovy (加密解密文件)

import com.message.proto.MessageProBuf
import com.google.protobuf.InvalidProtocolBufferException
import com.google.protobuf.MessageLite
import java.util.function.Function
import org.apache.logging.log4j.LogManager
import org.apache.logging.log4j.Loggerclass ProtobufParser {private static final Logger log = LogManager.getLogger(ProtobufParser::class)// 支持扩展的命令解析映射private static final Map<Integer, Function<byte[], MessageLite>> MESSAGE_PARSERS = new HashMap<>()static {MESSAGE_PARSERS.put(10, { data -> MessageProBuf.ChatMessage.parseFrom(data) });// 更多指令码和解析函数的映射可以添加到这里}/*** 构建加密后的消息字节数组* @param command 指令码* @param message Protobuf 消息体* @return 拼接后的字节数组*/static byte[] encryptMessage(int command, MessageLite message) {if (message == null) {throw new IllegalArgumentException("Message cannot be null")}byte[] buffer = message.toByteArray()byte[] bytes = new byte[buffer.length + 1]bytes[0] = (byte) commandSystem.arraycopy(buffer, 0, bytes, 1, buffer.length)return bytes}/*** 解析响应数据中的 Protobuf 消息* @param responseData 响应字节数组数据* @return 解析后的 MessageLite 对象(可扩展)*/static Optional<MessageLite> parseProtobufMessage(byte[] responseData) {if (responseData == null || responseData.length < 1) {throw new IllegalArgumentException("Response data is null or empty")}int command = responseData[0] & 0xFFbyte[] messageData = Arrays.copyOfRange(responseData, 1, responseData.length)try {Function<byte[], MessageLite> parser = MESSAGE_PARSERS.get(command)if (parser != null) {MessageLite message = parser.apply(messageData)log.info("Decoded message: ${message.toString()}")return Optional.of(message)} else {log.warn("Unknown command: $command")return Optional.empty()}} catch (InvalidProtocolBufferException e) {log.error("Failed to parse Protobuf message", e)throw new RuntimeException("Failed to parse Protobuf message with command: $command", e)}}
}

编译 Groovy 文件为 .class

1、将MessageBuilder.groovy 构件成 MessageBuilder.class 文件到指定的build/message 目录下
2、将ProtobufParser.groovy 构件成 ProtobufParser.class 文件到指定的build/protobuf 目录下

:: 切换到目录
cd groovygroovyc -cp "lib/*" src/MessageBuilder.groovy -d build/messagegroovyc -cp "lib/*" src/ProtobufParser.groovy -d build/protobuf

将目录build/message 、build/protobuf 目录下所有的.class 文件分别构建成 .jar文件

:: 切换到目录
cd groovyjar cf MessageBuilder.jar -C build/message .jar cf ProtobufParser.jar -C build/protobuf .

示例完整命令汇总

PS D:\System\Desktop\csdn> cd groovy
PS D:\System\Desktop\csdn\groovy> groovyc -cp "lib/*" src/MessageBuilder.groovy -d build/message
PS D:\System\Desktop\csdn\groovy> groovyc -cp "lib/*" src/ProtobufParser.groovy -d build/protobuf
PS D:\System\Desktop\csdn\groovy> jar cf MessageBuilder.jar -C build/message .
PS D:\System\Desktop\csdn\groovy> jar cf ProtobufParser.jar -C build/protobuf .
PS D:\System\Desktop\csdn\groovy>

在这里插入图片描述

三、JMeter 使用加解密

将 protobuf-java-4.31.1.jar 文件复制到 jmeter lib 目录下

在这里插入图片描述

将message-protobuf.jar、MessageBuilder.jar、ProtobufParser.jar 三个文件复制到lib/ext 目录下

在这里插入图片描述

四、重启JMeter

五、在JMeter 中使用

在JMeter 中添加线程组

在这里插入图片描述

在线程组上添加取样器/JSR223 Sampler

在这里插入图片描述
在JSR223 Sampler 中的script 脚本添加如下代码

import com.message.proto.MessageProBuf;
import com.google.protobuf.MessageLite;
import org.apache.logging.log4j.LogManager
import org.apache.logging.log4j.Logger// 创建日志记录器
Logger logger = LogManager.getLogger("test-protpbuf-jsr223-sampler")// 单聊消息
MessageLite chatMessage = MessageBuilder.buildChatMessage("${fromUserId}","fromUserName","${userId}","toUserName","我是xxx"); // 构建消息体
byte[] chatMessageEncryptedBytes = ProtobufParser.encryptMessage(10,chatMessage); // 加密
logger.info("单聊消息byte: {}", chatMessageEncryptedBytes)
def chatMessageDecrypt = ProtobufParser.parseProtobufMessage(chatMessageEncryptedBytes); // 消息解密

在这里插入图片描述

设置显示日志视图

在这里插入图片描述

运行测试

在这里插入图片描述

运行结果

在这里插入图片描述

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

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

相关文章

发票识别在费控系统应用剖析

一、发票识别与费控系统的融合价值1.1 解决传统费控痛点效率瓶颈突破&#xff1a;将人工处理每张发票的5-8分钟缩短至秒级自动识别准确性飞跃&#xff1a;关键字段识别准确率从人工的95%提升至99%以上合规性强化&#xff1a;自动对接税务系统验真&#xff0c;虚假发票识别率提升…

Rust实战:决策树与随机森林实现

基于 Rust 实现决策树(Decision Tree)和随机森林(Random Forest)的实例 Linfa的基本定义 Linfa是意大利语中“淋巴”(lymph)的意思,在医学领域指淋巴系统相关的结构或功能。淋巴系统由淋巴管、淋巴结、脾脏等组成,负责免疫防御和体液平衡。 Linfa在生物学中的作用 …

9. isaacsim4.2教程-ROS加相机/CLOCK

在本示例中&#xff0c;我们将学习如何&#xff1a; 向场景中添加额外的相机并将其安装在机器人上 添加相机发布器&#xff08;Camera Publishers&#xff09; 通过 rostopics 发送真实的合成感知数据&#xff08;ground truth synthetic perception data&#xff09; 前提…

微信小程序171~180

1.封装购物车接口API import http from /utils/httpexport const reqAddCrt ({ goodsId, count, ...data }) > {return http.get(/cart/addToCart/${goodsId}/${count}, data) }export const reqCartList () > {return http.get(/cart/getCartList) }export const reqU…

修改 docker 容器的挂载配置(保持数据不丢的情况)

一、核心原理Docker 容器的运行时配置&#xff08;包括挂载&#xff09;是启动时确定的&#xff0c;一旦启动无法直接修改。因此&#xff0c;需通过以下步骤实现&#xff1a;保存原容器中的数据&#xff08;避免丢失&#xff09;&#xff1b;基于原镜像创建新容器&#xff0c;同…

MVCC(多版本并发控制)介绍及实现原理

一、什么是MVCC&#xff1f; MVCC&#xff08;Multi-Version Concurrency Control&#xff0c;多版本并发控制&#xff09;是数据库中用于解决并发访问问题的一种机制。它通过为数据维护多个版本&#xff0c;让读写操作在不同版本上独立进行&#xff0c;从而避免了传统锁机制中…

密码学基础概念详解:从古典加密到现代密码体系

一、引言&#xff1a;为什么我们需要密码学&#xff1f; 在数字化时代&#xff0c;信息已成为核心生产要素&#xff0c;而信息安全则是保障社会运转的基石。当我们在电商平台输入银行卡密码时&#xff0c;当我们通过即时通讯工具发送私密消息时&#xff0c;当企业在云端存储核心…

小鹏汽车视觉算法面试30问全景精解

小鹏汽车视觉算法面试30问全景精解 ——智能驾驶 车路协同 视觉创新:小鹏汽车视觉算法面试核心考点全览 前言 小鹏汽车作为中国智能电动汽车的创新引领者,致力于通过AI与自动驾驶技术推动智能出行的变革。小鹏视觉算法团队深耕自动驾驶感知、车路协同、智能座舱、3D重建…

程序是如何生成的-以c语言为例

一&#xff0c;序言 从代码到能跑的程序&#xff0c;整个过程就像 “把外文翻译成母语&#xff0c;再组装成能直接用的东西”&#xff0c;一步步来更清楚&#xff1a; 源代码&#xff08;程序员写的代码&#xff0c;如C语言文件&#xff09;↓ 预处理&#xff08;处理#开头的命…

风险识别清单:构建动态化的风险管理体系

在项目管理实践中&#xff0c;风险识别是确保项目成功的关键环节。PMBOK提出的风险提示清单&#xff08;Prompt List&#xff09;为项目团队提供了一个系统化的思考框架&#xff0c;帮助突破个人经验局限&#xff0c;实现更全面的风险覆盖。这一工具的价值不仅在于其提供的标准…

从“点状用例”到“质量生态”:现代软件测试的演进、困局与破局

测试的三次范式跃迁业务高速迭代下的四大困局质量工程化&#xff1a;流程、平台、度量三位一体左移与右移&#xff1a;把缺陷扼杀在摇篮&#xff0c;也把监控铺到坟墓自动化金字塔的再平衡&#xff1a;UI、API、单元、契约、e2e数据驱动测试&#xff1a;从“拍脑袋”到“科学实…

【C++】继承和多态扩展学习

目录 1. 菱形虚拟继承原理剖析 1.1.虚基表 2. 单继承和多继承的虚函数表深入探索 2.1 单继承虚函数表深入探索 2.2 多继承虚函数表深入探索 ​编辑 2.3 菱形继承、菱形虚拟继承 3. 继承和多态考察的一些常见问题 1. 菱形虚拟继承原理剖析 继承的文章中我们讲到C的多继承…

Visual Studio Code 远端云服务器开发使用指南

目录 一、下载安装 1、官方下载 2、下载加速方案 二、基于Ubuntu系统的开发环境搭建方案 1、开发环境配置 2、云服务器架构 3、工作流程关系 4、总结 三、推荐插件 1、免配置插件 1. Remote-SSH - 远程登录Linux服务器 2. C/C - 必备的C/C开发插件 3. C/C Extensi…

技术演进中的开发沉思-41 MFC系列:定制 AppWizard

MFC开发&#xff0c;最为重要的无非就是用“MFC AppWizard” 对话框做开发了&#xff0c;第一次使用感觉像拆收音机的孩子 —— 左边是项目类型选择&#xff0c;右边是一堆打勾的选项&#xff0c;点完 “完成”&#xff0c;屏幕上就冒出了能直接编译运行的窗口程序。那时还不知…

Libevent(3)之使用教程(2)创建事件

Libevent(3)之使用教程(2)创建事件 Author: Once Day Date: 2025年6月29日 一位热衷于Linux学习和开发的菜鸟&#xff0c;试图谱写一场冒险之旅&#xff0c;也许终点只是一场白日梦… 漫漫长路&#xff0c;有人对你微笑过嘛… 本文档翻译于&#xff1a;Fast portable non-bl…

Kotlin 作用域函数 let 的实现原理

Kotlin 中的 let 是一个 标准库扩展函数&#xff0c;它广泛用于作用域函数&#xff08;Scope Functions&#xff09;中&#xff0c;尤其适用于对可空对象&#xff08;nullable&#xff09;做非空判断并执行代码块的场景。 示例代码 val name: String? "123" name?…

从FDTD仿真到光学神经网络:机器学习在光子器件设计中的前沿应用工坊

FDTD仿真与光学神经网络的基础概念 FDTD&#xff08;时域有限差分&#xff09;是一种数值方法&#xff0c;用于求解麦克斯韦方程组&#xff0c;广泛应用于光子器件设计。光学神经网络通过光波导、衍射元件等物理结构实现矩阵运算&#xff0c;具有低能耗、高并行的优势。 机器学…

在Ubutu22系统上面离线安装Go语言环境【教程】

0.引言 Go语言&#xff08;又称Golang&#xff09;是Google开发的一种静态强类型、编译型、并发型编程语言&#xff0c;由Robert Griesemer、Rob Pike和Ken Thompson于2007年开始设计&#xff0c;2009年正式发布。 1.到官网下载压缩包 2.从win10系统离线上传压缩包给ubuntu22…

CMake实践:CMake3.30版本之前和之后链接boost的方式差异

目录 1.背景 2.boost引入CMake时机 3.CMake 3.30 之前&#xff08;含 3.29&#xff09;链接 Boost 的方式 4.CMake 3.30 及之后链接 Boost 的方式 5.CMake3.30后引入Boost的步骤 6.迁移建议&#xff08;3.30 之前 → 3.30 之后&#xff09; 7.CMake 3.30 移除FindBoost的…

告别挂马风险!PBootCMS完美替代方案BadouCMS

开发企业网站时一直比较喜欢用pbootcms,标签套用很简单&#xff0c;使用也方便。 但是pbootcms一直有被挂马的问题&#xff0c;官方好像也不怎么更新了&#xff01;换过好几个cms&#xff0c;比如eyoucms、dedecms、帝国等等&#xff0c;感觉都不怎么能用得习惯&#xff0c;还…