当前位置: 首页 > news >正文

Java原生实现代码沙箱的实现

代码沙箱实现

代码沙箱:只负责接收代码和输入,返回编译运行的结果,不负责判题(可作为独立项目/服务,提供给其他需要执行代码的项目使用)
以Java语言为主,实现代码沙箱。主要学习其思想、关键流程。
(可扩展实现C、C++代码沙箱)

Java原生实现代码沙箱(原生:尽可能不借助第三方库和依赖,用最干净、最原始的方式实现)–代码沙箱实现原理:接受代码->编译代码(javac)->执行代码(java)

新建一个新的SpringBoot项目并且成功运行(Java8、SpringBoot2.7)

javac SimpleCompute.java 编译了 SimpleCompute.java 源文件javac .\SimpleCompute.java
.\SimpleCompute.java:10: 错误: 编码GBK的不可映射字符System.out.println("缁撴灉涓?" + a + b);^
1 个错误
编译后的程序中文乱码:命令行终端编码是GBK,和java代码文件本身的UTF-8编码不一致,导致乱码。
通过chcp查看命令查看编码,GBK是活动代码页: 936
解决方案:
javac -encoding utf-8 .\SimpleCompute.java
java -cp . SimpleCompute 1 2
结果:3
实际OJ系统中,对用户输入的代码会有一定的要求,便于系统统一处理。所以此处我们把用户输入代码的类名限制为Main 减少类名不一致的风险,而且不用从用户代码中提取类名,更方便。
示例代码:
public class Main {public static void main(String[] args) {int a = Integer.parseInt(args[0]);int b = Integer.parseInt(args[1]);System.out.println("结果:" + (a + b));}
}

实际执行

javac -encoding utf-8 .\Main.java         
java -cp . Main 1 2              
结果:3
核心流程实现(核心实现思路:用程序代替人工,用程序来操作命令行,去编译执行代码 Process Java-java进程执行管理类)
  1. 将用户代码保存为一个Main文件
  2. 编译代码,得到class文件
  3. 执行代码,得到输出结果
  4. 收集整理输出结果
  5. 文件清理
  6. 错误处理(提升程序健壮性)
1. 将用户代码保存为一个Main文件
  • 引入Hutool工具类,读取文件
<!-- https://hutool.cn/docs/index.html#/--><dependency><groupId>cn.hutool</groupId><artifactId>hutool-all</artifactId><version>5.8.8</version></dependency>

新建目录,每个用户的代码都存放在独立的目录下,便于维护

public class JavaNativeCodeSandbox implements CodeSandbox {private static final String GlOBAL_CODE_DIR_NAME = "tmpCode";private static final String GlOBAL_JAVA_CLASS_NAME = "Main.java";public static void main(String[] args) {JavaNativeCodeSandbox javaNativeCodeSandbox = new JavaNativeCodeSandbox();ExecuteCodeRequest executeCodeRequest = new ExecuteCodeRequest();executeCodeRequest.setInputList(Arrays.asList("2 2", "1 4"));executeCodeRequest.setUserCode(ResourceUtil.readStr("testCode/simpleComputeArgs/Main.java", StandardCharsets.UTF_8));executeCodeRequest.setCodeLanguage("java");ExecuteCodeResponse executeCodeResponse = javaNativeCodeSandbox.executeCode(executeCodeRequest);System.out.println(executeCodeResponse);}@Overridepublic ExecuteCodeResponse executeCode(ExecuteCodeRequest executeCodeRequest) {String userCode = executeCodeRequest.getUserCode();String userDir = System.getProperty("user.dir");//获取全局路径String globalCodePathName = userDir + File.separator + GlOBAL_CODE_DIR_NAME;//绝对代码路径//判断全局代码目录是否存在,若文件夹不存在就新建文件夹if (FileUtil.exist(globalCodePathName)) {FileUtil.mkdir(globalCodePathName);}//把用户代码隔离存放 用户代码文件夹String userCodeParentPath = globalCodePathName + File.separator + UUID.randomUUID();String userCodePath = userCodeParentPath + File.separator + GlOBAL_JAVA_CLASS_NAME;File userCodeFile = FileUtil.writeString(userCode, userCodePath, StandardCharsets.UTF_8);return null;}
}
2. 编译代码,得到class文件
  • 读取编译字符串,执行编译命令,java获取控制台输出
 //2.编译代码,得到class文件
String compileCmd = String.format("javac -encoding utf-8%s", userCodeFile.getAbsolutePath());//编译命令
try {Process compileProcess = Runtime.getRuntime().exec(compileCmd);//执行编译命令//分批获取进程的正常输出BufferedReader bufferedReader = new BufferedReader(new InputStreamReader(compileProcess.getInputStream()));StringBuilder compileOutputStringBuilder = new StringBuilder();String compileOutputLine;//逐行读取while ((compileOutputLine = bufferedReader.readLine()) != null) {compileOutputStringBuilder.append(compileOutputLine);}System.out.println(compileOutputStringBuilder);int exitValue = compileProcess.waitFor();//获取退出码 等待程序执行完毕,获取错误码判断程序执行结果if (exitValue == 0) {//正常退出System.out.println("编译成功!");} else {//异常退出System.out.println("编译失败!错误码:" + exitValue);//分批获取进程的异常输出BufferedReader errorBufferedReader = new BufferedReader(new InputStreamReader(compileProcess.getErrorStream()));String errorCompileOutputLine;StringBuilder errorCompileOutputStringBuilder = new StringBuilder();//逐行读取while ((errorCompileOutputLine = errorBufferedReader.readLine()) != null) {errorCompileOutputStringBuilder.append(errorCompileOutputLine);}System.out.println(errorCompileOutputStringBuilder);}
} catch (IOException | InterruptedException e) {throw new RuntimeException(e);
}
3. 执行代码,得到输出结果
  • 封装工具类,将执行命令以及处理执行结果的代码
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;/*** 执行进程并获取信息* @Author Adellle* @Date 2024/12/19 18:23* @Version 1.0*/
public class ProcessUtils {/*** @param runProcess* @param optName* @return*/public static ExecuteMessage runProcessAndGetMessage(Process runProcess,String optName) {ExecuteMessage executeMessage = new ExecuteMessage();try {int exitValue = 0;exitValue = runProcess.waitFor();executeMessage.setExitValue(exitValue);if (exitValue == 0) {//正常退出System.out.println(optName+"成功!");//分批获取进程的正常输出BufferedReader bufferedReader = new BufferedReader(new InputStreamReader(runProcess.getInputStream()));StringBuilder compileOutputStringBuilder = new StringBuilder();String compileOutputLine;//逐行读取while ((compileOutputLine = bufferedReader.readLine()) != null) {compileOutputStringBuilder.append(compileOutputLine);}executeMessage.setMessage(compileOutputStringBuilder.toString());} else {//异常退出System.out.println(optName+"失败!错误码:" + exitValue);//分批获取进程的正常输出BufferedReader bufferedReader = new BufferedReader(new InputStreamReader(runProcess.getInputStream()));StringBuilder compileOutputStringBuilder = new StringBuilder();String compileOutputLine;//逐行读取while ((compileOutputLine = bufferedReader.readLine()) != null) {compileOutputStringBuilder.append(compileOutputLine);}//分批获取进程的异常输出BufferedReader errorBufferedReader = new BufferedReader(new InputStreamReader(runProcess.getErrorStream()));String errorCompileOutputLine;StringBuilder errorCompileOutputStringBuilder = new StringBuilder();//逐行读取while ((errorCompileOutputLine = errorBufferedReader.readLine()) != null) {errorCompileOutputStringBuilder.append(errorCompileOutputLine);}executeMessage.setMessage(compileOutputStringBuilder.toString());executeMessage.setErrorMessage(errorCompileOutputStringBuilder.toString());}} catch (InterruptedException | IOException e) {e.printStackTrace();}return executeMessage;}
}
  • 本次使用的是非交互式的判题方式,无需用户输入。但是很多OJ都是与用户交互式的判题模式,可以让用户不断输入内容并获取,具体代码可以自己优化完善。
4. 收集整理输出结果
  • 获取程序执行时间和空间
    获取程序执行时间:使用Spring的StopWatch,此处使用每次样例执行时间的最大值作为执行时间
StopWatch stopWatch=new StopWatch();
stopWatch.start();
stopWatch.stop();
5. 文件清理(防止服务器内存浪费)
if (userCodeFile.getParentFile() != null) {if (FileUtil.del(userCodeParentPath)) {System.out.println("删除成功!");} else {System.out.println("删除失败!");}}
6. 错误处理(提升程序健壮性)
private ExecuteCodeResponse getErrorResponse(Throwable e) {ExecuteCodeResponse executeCodeResponse = new ExecuteCodeResponse();executeCodeResponse.setOutputList(new ArrayList<>());executeCodeResponse.setMessage(e.getMessage());executeCodeResponse.setStatus(2);//代码沙箱错误executeCodeResponse.setJudgeInfo(new JudgeInfo());return executeCodeResponse;
}

异常情况演示

目前为止,核心流程都已经实现,若真正上线,安全吗?
用户提交恶意代码

  1. 执行阻塞,占用资源不释放(如果多个用户可能会把服务器资源占用不释放导致服务器崩溃)
public class SleepError {public static void main(String[] args) throws InterruptedException {long ONE_HOUR = 60 * 60 * 1000L;Thread.sleep(ONE_HOUR);System.out.println("睡丸辣");}
}
  1. 占用内存,不释放(程序可能试图创建大量对象,导致堆内存被耗尽)
import java.util.ArrayList;
import java.util.List;/*** 浪费系统内存** @Author Adellle* @Date 2024/12/19 20:45* @Version 1.0*/
public class Main {public static void main(String[] args) throws InterruptedException {List<byte[]> bytes = new ArrayList<>();while(true){bytes.add(new byte[10000]);}}
}

实际运行中我们会发现JVM内存占用到达一定空间后程序会自动报错:java.lang.OutOfMemoryError: Java heap space
这是JVM的一种保护机制
3. 读文件(越过权限,读取数据库信息)

import java.io.File;
import java.io.IOException;
import java.nio.file.Files;
import java.nio.file.Paths;
import java.util.List;/*** 读取服务器文件(文件信息泄露) ** @Author Adellle* @Date 2024/12/19 20:45* @Version 1.0*/
public class Main {public static void main(String[] args) throws InterruptedException, IOException {String property = System.getProperty("user.dir");String filePath = property+ File.separator+"src/main/resources/application.yml";List<String> strings= Files.readAllLines(Paths.get(filePath));System.out.println(String.join("\n",strings));}
}
  1. 写文件,文件信息泄露(越权,植入木马)
import java.io.File;
import java.io.IOException;
import java.nio.file.Files;
import java.nio.file.Paths;
import java.util.Arrays;
import java.util.List;/*** 向服务器写文件,植入木马** @Author Adellle* @Date 2024/12/19 20:45* @Version 1.0*/
public class Main {public static void main(String[] args) throws InterruptedException, IOException {String property = System.getProperty("user.dir");String filePath = property+ File.separator+"src/main/resources/木马程序.bat";String errorProgram="java -version 2>&1";Files.write(Paths.get(filePath), Arrays.asList(errorProgram));System.out.println("木马植入成功!你又丸辣哈哈");}
}
  1. 运行其他程序(直接通过Process执行危险程序,或者电脑上其他程序)
import java.io.BufferedReader;
import java.io.File;
import java.io.IOException;
import java.io.InputStreamReader;/*** 向服务器写文件,植入木马** @Author Adellle* @Date 2024/12/19 20:45* @Version 1.0*/
public class Main {public static void main(String[] args) throws InterruptedException, IOException {String property = System.getProperty("user.dir");String filePath = property + File.separator + "src/main/resources/木马程序.bat";Process process=Runtime.getRuntime().exec(filePath);process.waitFor();//分批获取进程的正常输出BufferedReader bufferedReader = new BufferedReader(new InputStreamReader(process.getInputStream()));StringBuilder compileOutputStringBuilder = new StringBuilder();String compileOutputLine;//逐行读取while ((compileOutputLine = bufferedReader.readLine()) != null) {
//            compileOutputStringBuilder.append(compileOutputLine);System.out.println(compileOutputLine);}System.out.println("执行异常程序成功!");}
}
  1. 执行高危命令
    甚至不用写木马文件,直接执行系统自带的危险命令(例如删除服务器文件,删除数据库,或者获取系统上的所有文件信息)
怎么解决?(解决方案)
  1. 超时控制:通过创建一个守护线程,超时后自动中断process实现
Process runProcess = Runtime.getRuntime().exec(runCmd);//执行运行命令
new Thread(() -> {try {Thread.sleep((TIME_OUT));runProcess.destroy();} catch (InterruptedException e) {throw new RuntimeException(e);}
}).start();
  1. 限制给用户分配资源:不能让每个Java进程的执行占用的JVM最大内存空间都和系统的一致,实际应该小一点 在启动Java时,可以指定JVM的参数:-Xmx256m(最大堆空间大小)-Xm(初始堆空间大小)java -Xmx256m -Dfile.encoding=UTF-8 -cp %s Main %s
  2. 限制代码(禁止写读写文件的代码)黑白名单
    先定义一个黑白名单
//字典树校验黑名单代码
WordTree wordTree = new WordTree();
wordTree.addWords(blackList);
FoundWord foundWord = wordTree.matchWord(userCode);
if (foundWord != null) {System.out.println(foundWord.getFoundWord());ExecuteCodeResponse executeCodeResponse = new ExecuteCodeResponse();executeCodeResponse.setMessage("无操作权限!请输入正确代码");return executeCodeResponse;
}

字典树:节约空间,节约时间查找
缺点:无法遍历所有的黑名单;不同的编程语言对应领域和关键词都不同,成本太大。
4. 限制用户操作权限(文件、内存、CPU、网络、执行)
Java安全管理器(实现更加严格的限制)Security Manager:
5. 运行环境隔离

相关文章:

Java原生实现代码沙箱的实现

代码沙箱实现 代码沙箱&#xff1a;只负责接收代码和输入&#xff0c;返回编译运行的结果&#xff0c;不负责判题&#xff08;可作为独立项目/服务&#xff0c;提供给其他需要执行代码的项目使用&#xff09; 以Java语言为主&#xff0c;实现代码沙箱。主要学习其思想、关键流…...

Docker基础命令实战

问题&#xff1a;Error response from daemon: Get "https://index.docker.io/v1/search?qmysql&n25": dial tcp 199.59.148.9:443: connect: connection refused 在pull nginx时出现的报错&#xff0c;可能原因是镜像源过期了&#xff0c;我们需要更换镜像源 …...

【QT实战の心情笔记】

文章目录 界面布局主要界面分为三部分&#xff1a;1. 笔记列表区域2. 笔记内容编辑区域3. 操作按钮区域 Qt Designer 界面设计步骤完整界面布局图各控件设置和属性Qt Designer 文件 (.ui) 数据库表结构SQL 表结构&#xff1a; 逻辑代码1. 项目结构2. Note 类 (Note.h 和 Note.c…...

关于Unity VFX 在Spawn状态的一些笔记

一. periodic burst 和 single burst 的区别 1. Single Burst 定义:Single Burst 是一次性发射粒子,只在粒子系统启动时触发一次。 它是一个瞬时的发射行为,适合单次效果。 特性: 只触发一次。发射时间通常是粒子系统启动时。不会重复发射,除非重新触发粒子系统。适用场景…...

AutoMQ 流表一体新特性 Table Topic 发布: 无缝集成 AWS S3 Table 和 Iceberg

超越共享存储&#xff1a;使用 Apache Iceberg 中的 AutoMQ Table Topic 实现流处理与分析的统一 自 2023 年底官宣以来&#xff0c;AutoMQ 成功地将 Apache Kafka 从“Shared Nothing architecture”转变为“Shared Storage architecture”&#xff0c;这为京东、知乎、小红书…...

springboot445新冠物资管理(论文+源码)_kaic

摘 要 使用旧方法对新冠物资管理的信息进行系统化管理已经不再让人们信赖了&#xff0c;把现在的网络信息技术运用在新冠物资管理的管理上面可以解决许多信息管理上面的难题&#xff0c;比如处理数据时间很长&#xff0c;数据存在错误不能及时纠正等问题。这次开发的新冠物资管…...

【AIGC】LangChain 环境搭建及模型API能力集成使用详解

目录 一、前言 二、LangChain 概述 2.1 LangChain 是什么 2.2 LangChain 主要特点 2.3 LangChain能做什么和能力一览 2.4 LangChain 主要应用场景 三、环境准备 3.1 python 开发环境 3.1.1 python环境 3.1.2 配置vscode环境 3.1.3 安装LangChain相关插件包 3.2 获取…...

YOLOv8目标检测(六)_封装API接口

YOLOv8目标检测(一)_检测流程梳理&#xff1a;YOLOv8目标检测(一)_检测流程梳理_yolo检测流程-CSDN博客 YOLOv8目标检测(二)_准备数据集&#xff1a;YOLOv8目标检测(二)_准备数据集_yolov8 数据集准备-CSDN博客 YOLOv8目标检测(三)_训练模型&#xff1a;YOLOv8目标检测(三)_训…...

Firecrawl教程①:自动化抓取与数据转化,赋能AI应用

Firecrawl教程①:自动化抓取与数据转化,赋能AI应用 前言一、功能特点1. 支持 LLM 可处理的数据格式2. 全面抓取网站3. 强大的操作支持4. 灵活的定制选项5. 支持多种编程语言 SDK二、如何开始使用 Firecrawl第一步:获取 API 密钥第二步:官网在线工具使用第三步:安装 Firecr…...

2-2-18-17 QNX系统架构之“实时”

阅读前言 本文以QNX系统官方的文档英文原版资料为参考&#xff0c;翻译和逐句校对后&#xff0c;对QNX操作系统的相关概念进行了深度整理&#xff0c;旨在帮助想要了解QNX的读者及开发者可以快速阅读&#xff0c;而不必查看晦涩难懂的英文原文&#xff0c;这些文章将会作为一个…...

Linux下部署MySQL8.0集群 - 主从复制(一主两从)

目录 一、部署前准备 1、查看系统信息 # 查看系统版本 cat /etc/red* # 查看系统位数 getconf LONG_BIT[rootlocalhost ~]# cat /etc/red* CentOS Linux release 7.5.1804 (Core) [rootlocalhost ~]# getconf LONG_BIT 642、下载对应安装包 进入MySQL官网&#xff1a;https:…...

将HTML转换为PDF:使用Spire.Doc的详细指南

目录 引言 1. 为什么选择 Spire.Doc&#xff1f; 1.1 主要特点 1.2 适用场景 2. 准备工作 2.1 引入 Spire.Doc 依赖 2.2 禁用 SSL 证书验证 3. 实现功能 3.1 主类结构 3.2 代码解析 4. 处理图像 5. 性能优化 5.1 异步下载图像 示例代码 5.2 批量处理优化 示例代…...

HarmonyOS 实践 - 设计模式在代码中的作用

文章目录 前言设计模式概述单例模式&#xff1a;全局状态管理代码分析 策略模式&#xff1a;界面主题切换代码分析 示例测试单例模式测试策略模式测试 体验评价总结 前言 在软件开发中&#xff0c;设计模式是公认的最佳实践&#xff0c;它能帮助开发者通过模块化和规范化的代码…...

kubeadm一键部署K8S 集群架构

kubeadm一键部署K8S 集群架构(centos7) https://www.k8src.cn/ https://kubernetes.io/zh-cn/docs/home/ https://blog.csdn.net/m0_58709145/article/details/140128179 https://blog.csdn.net/jiaqijiaqi666/article/details/129745828 Kubeadm init报错[ERROR CRI]: contai…...

[NSSCTF 2022 Spring Recruit]factor

给了&#xff1a; 说n是p*q 先求一下p*q factordb.com 然后再让pq 得到&#xff1a;31207540994438423298 接着用md5加密得到falg NSSCTF{7957a92ef959998115a6bda6d992656e}...

go 中使用redis 基础用法

1、安装redis 参考链接&#xff1a;https://www.codeleading.com/article/98554130215/ 1.1 查看是否有redis yum 源 yum install redis没有可用的软件包&#xff0c;执行1.2 1.2下载fedora的epel仓库 yum install epel-release --下载fedora的epel仓库1.3启动redis s…...

git branch -r(--remotes )显示你本地仓库知道的所有 远程分支 的列表

好的&#xff0c;git branch -r 这个命令用于列出远程分支。让我详细解释一下&#xff1a; 命令&#xff1a; git branch -rdgqdgqdeMac-mini ProductAuthentication % git branch -rorigin/main作用&#xff1a; 这个命令会显示你本地仓库知道的所有 远程分支 的列表。它不…...

回归预测 | MATLAB实现CNN-BiGRU卷积神经网络结合双向门控循环单元多输入单输出回归预测

回归预测 | MATLAB实现CNN-BiGRU卷积神经网络结合双向门控循环单元多输入单输出回归预测 目录 回归预测 | MATLAB实现CNN-BiGRU卷积神经网络结合双向门控循环单元多输入单输出回归预测预测效果基本介绍程序设计参考资料预测效果 基本介绍 CNN-BiGRU,即卷积神经网络(CNN)与双…...

【人工智能数学基础】——深入详解贝叶斯理论:掌握贝叶斯定理及其在分类和预测中的应用

深入详解贝叶斯理论&#xff1a;掌握贝叶斯定理及其在分类和预测中的应用 贝叶斯理论&#xff08;Bayesian Theory&#xff09;是概率论和统计学中的一个重要分支&#xff0c;它以托马斯贝叶斯&#xff08;Thomas Bayes&#xff09;命名&#xff0c;主要关注如何根据新的证据更…...

Gin-vue-admin(1):环境配置和安装

目录 环境配置如果443网络连接问题&#xff0c;需要添加代理服务器 后端运行前端运行 环境配置 git clone https://gitcode.com/gh_mirrors/gi/gin-vue-admin.git到server文件目录下 go mod tidygo mod tidy 是 Go 语言模块系统中的一个命令&#xff0c;用于维护 go.mod 文件…...

深入解析与防范:基于缓冲区溢出的FTP服务器攻击及调用计算器示例

深入解析与防范&#xff1a;基于缓冲区溢出的FTP服务器攻击及调用计算器示例 摘要 本文将详细探讨一种利用缓冲区溢出漏洞对FTP服务器进行远程攻击的技术&#xff0c;并通过分析给定代码示例&#xff0c;揭示其工作原理和潜在风险。我们将重点讨论如何在靶机上实现调用计算器…...

Gargoyle路由安装dockerd

ea8500刷石像鬼路由1.14.0&#xff0c;安dockerd&#xff0c;需先下载并安装以下依赖包&#xff0c;逐个安装。 kernel_5.10.176-1-6b05bc664d80d655942a20fb9ef8c3cd_arm_cortex-a15_neon-vfpv4.ipk kmod-br-netfilter_5.10.176-1_arm_cortex-a15_neon-vfpv4.ipk kmod-crypto…...

在linux系统的docker中安装GitLab

一、安装GitLab&#xff1a; 在安装了docker之后就是下载安装GitLab了&#xff0c;在linux系统中输入命令&#xff1a;docker search gitlab就可以看到很多项目&#xff0c;一般安装第一个&#xff0c;它是英文版的&#xff0c;如果英文不好可以安装twang2218/gitlab-ce-zh。 …...

滑动窗口

滑动窗口 标志: 利用两个指针 只进不退的特性 &#xff08;样子与窗口类似&#xff09; 解题模板 更新结果的时机 应该具体题目具体分析。 例题&#xff1a; 438. 找到字符串中所有字母异位词 - 力扣&#xff08;LeetCode&#xff09; 1658. 将 x 减到 0 的最小操作数 - 力…...

人工智能 AI 大模型研究设计与实践应用技术研究报告

人工智能 AI 大模型研究设计与实践应用技术研究报告 摘要&#xff1a; 本报告深入探讨了人工智能 AI 大模型的研究设计架构以及在各领域的实践应用技术。通过对模型架构、训练方法、优化策略的详细阐述&#xff0c;结合实际案例分析其在自然语言处理、计算机视觉、智能医疗等领…...

【深度学习】 零基础介绍卷积神经网络(CNN)

CNN学习 零基础介绍写个CNN最简单的代码一. 概述二. 搭建CNN1. 输入层2. 卷积层3. 激活层4. 池化层5. 全连接层6. 网络搭建小结7. 损失函数8. 梯度下降9. 反向传播10. 模型评估与正则化11. 尝试搭建自己的第一个CNN 三. 经典CNN结构四. 猫狗识别项目实践1. Paddle实现版本&…...

答题考试系统v1.6.1高级版源码分享+uniapp+搭建测试环境

一.系统介绍 一款基于FastAdminThinkPHPUniapp开发的小程序答题考试系统&#xff0c;支持多种试题类型、多种试题难度、练题、考试、补考模式&#xff0c;提供全部前后台无加密源代码&#xff0c;支持私有化部署 二.测试环境 系统环境&#xff1a;CentOS、 运行环境&#x…...

PowerMILL 客制化宏 - 变量

从PowerMILL2012起&#xff0c;命令起始支持变量。支持变量将使宏命令更加灵活和功能强大。可以对变量做一些运算而不依赖其它语言。 当前支持有变量类型为&#xff1a; INT&#xff1b; REAL&#xff1b; STRING&#xff1b; ENTITY&#xff1b; ARRAY LIST; OBJECT; 以下就…...

第五篇:前后端如何“扯皮”——HTTP 在开发中的应用

文章目录 第五篇&#xff1a;前后端如何“扯皮”——HTTP 在开发中的应用1. HTTP 在前后端分离中的作用1.1 前后端分离的崛起1.2 HTTP 的职责 2. RESTful API 与 GraphQL 的对比2.1 RESTful API&#xff1a;标准化的老兵2.2 GraphQL&#xff1a;灵活的新秀2.3 RESTful 和 Graph…...

如何在 Ubuntu 22.04 服务器上安装 Jenkins

简介 Jenkins 是一个非常流行的免费自动化工具&#xff0c;每个人都应该了解它。DevOps 工程师使用它来自动化代码构建、测试和部署。本文将重点介绍如何在新的 Ubuntu LTS 版本&#xff0c;即 Ubuntu 22.04 中安装 Jenkins。 但在此之前&#xff0c;让我们快速讨论一下 Jenk…...

关于代码注释

代码注释的重要性与最佳实践 在软件开发过程中&#xff0c;代码注释被认为是代码质量的一个重要组成部分。它不仅帮助开发人员理解和维护代码&#xff0c;还有助于团队协作和代码的可持续性。然而&#xff0c;如何有效地使用注释是一个值得深思的问题。本文将探讨代码注释的重…...

Mitt 库使用笔记

1. 介绍 Mitt 是一个轻量级的 JavaScript 库&#xff0c;用于在应用程序中实现事件触发和监听。它不依赖任何外部库&#xff0c;功能简洁&#xff0c;主要用于在模块间进行事件传递。 体积小&#xff1a;Mitt 的压缩版本仅有几千字节&#xff0c;非常适合在前端框架中作为事件…...

OpenCVE:一款自动收集NVD、MITRE等多源知名漏洞库的开源工具,累计收录CVE 27万+

漏洞库在企业中扮演着至关重要的角色&#xff0c;不仅提升了企业的安全防护能力&#xff0c;还支持了安全决策、合规性要求的满足以及智能化管理的发展。前期博文《业界十大知名权威安全漏洞库介绍》介绍了主流漏洞库&#xff0c;今天给大家介绍一款集成了多款漏洞库的开源漏洞…...

uniapp中的uni-file-picker组件上传多张图片到服务器

由于在uniapp官方文档中的uni-file-picker组件可实现图片上传功能&#xff0c;默认的是上传到自带的服务&#xff0c;所以我们要修改成自己的服务器 1. 添加 :auto-upload"false" 加上这个取消自动上传 <uni-file-picker v-model"jobAddUpdateForm.imag…...

LIF神经元模型的显隐转换

本文星主将介绍LIF神经元模型的显式和隐式转换&#xff08;星主看见有论文[1]是这个称呼的&#xff0c;所以本文也称显式和隐式&#xff09;&#xff0c;并得到隐式模型的解析解。注意&#xff1a;理解本文内容需要有一定的微积分基础&#xff0c;如果大家看着数学头疼&#xf…...

Node的学习以及学习通过Node书写接口并简单操作数据库

Node的学习 Node的基础上述是关于Node的一些基础&#xff0c;总结的还行&#xff1b; 利用Node书写接口并操作数据库 1. 初始化项目 创建新的项目文件夹&#xff0c;并初始化 package.json mkdir my-backend cd my-backend npm init -y2. 安装必要的依赖 安装Express.js&…...

Android 获取屏幕物理尺寸

注&#xff1a;编译 sdk 需要使用 30 因为引入了 WindowMetrics、uild.VERSION_CODES.R 新 sdk 才存在的类和属性 某些场景处理 view &#xff0c;对 view 显示的位置要求比较精确&#xff0c;通常我们使用context.getResources().getDisplayMetrics().widthPixels 获取到的宽、…...

【FFmpeg】解封装 ① ( 封装与解封装流程 | 解封装函数简介 | 查找码流标号和码流参数信息 | 使用 MediaInfo 分析视频文件 )

文章目录 一、解封装1、封装与解封装流程2、解封装 常用函数 二、解封装函数简介1、avformat_alloc_context 函数2、avformat_free_context 函数3、avformat_open_input 函数4、avformat_close_input 函数5、avformat_find_stream_info 函数6、av_read_frame 函数7、avformat_s…...

#渗透测试#红队全栈 powshell基础使用

声明&#xff01; 学习视频来自B站up主 泷羽sec&#xff0c;任何违法事件与本人以及泷羽sec团队无关&#xff0c;切勿触碰法律底线&#xff0c;否则后果自负&#xff01;&#xff01;&#xff01;&#xff01; 目录标题 认识powsehll打开方式 使用方式美化自己的powershell简单…...

Qt之自定义标题栏拓展(十)

Qt开发 系列文章 - user-defined-titlebars&#xff08;十&#xff09; 目录 前言 一、方式一 1.效果演示 2.创建标题栏类 3.可视化UI设计 4.定义相关函数 5.使用标题栏类 二、方式二 1.效果演示 2.创建标题栏类 3.定义相关函数 1.初始化函数 2.功能函数 3.窗口关…...

设计模式之创建型

1、What 关注对象的创建过程&#xff0c;旨在通过不同的方式来创建对象&#xff0c;以解耦对象的创建与其使用过程。这些模式提供了创建对象的灵活性和可扩展性&#xff0c;使得代码更加易于维护和管理。 1.1 单例模式 确保一个类只有一个实例&#xff0c;并提供一个全局访问…...

记录一下自己对网络安全法的笔记

仅记录一下自己对网络安全法的笔记 文章来源&#xff08;https://www.cac.gov.cn/2016-11/07/c_1119867116_2.htm&#xff09;&#xff08;2016年11月7日第十二届全国人民代表大会常务委员会第二十四次会议通过&#xff09;该法自2017年6月1日起施行。《网络安全法》是我国第一…...

Mybatis-plus-Join--分页查询

数据表四张&#xff1a; user&#xff1a; id,username,create_time,update_time product&#xff1a; id,name,price,number(库存),create_time,update_times order&#xff1a; id,quantity,order_time(下单时间),update_time order_detail:id,product_id,order_id,quant…...

EE308FZ_Sixth Assignment_Beta Sprint_Sprint Essay 5

Assignment 6Beta SprintCourseEE308FZ[A] — Software EngineeringClass Link2401_MU_SE_FZURequirementsTeamwork—Beta SprintTeam NameFZUGOObjectiveSprint Essay 5_Day9-Day10 (12.19-12.20)Other Reference1. WeChat Mini Program Design Guide 2. Javascript Style Gui…...

【AI日记】24.12.19 kaggle 比赛 2-8 | 睡眠质量提高

【AI论文解读】【AI知识点】【AI小项目】【AI战略思考】【AI日记】 工作 参加&#xff1a;kaggle 比赛 Regression with an Insurance Dataset时间&#xff1a;8 小时 读书 书名&#xff1a;富兰克林自传时间&#xff1a;0.5 小时阅读原因&#xff1a;100 美元纸币上的人物 …...

string

1.对象创建 // // Created by 徐昌真 on 2024/12/15. // #include <iostream> #include <string>using namespace std;int main() {string s "意思是不要沉迷于空洞的幻想 也不要追求无用的虚名 强调了做事要脚踏实地 专注于实际的目标与行动";// 1. 无…...

观龙鱼之态,察疾病之征

龙鱼&#xff0c;以其独特的外形、优雅的游姿&#xff0c;成为众多养鱼爱好者的心头好。然而&#xff0c;这些水中的 “精灵” 一旦患病&#xff0c;其状态会发生明显变化。了解龙鱼患病的表现&#xff0c;对于鱼主人及时发现并治疗至关重要。 当龙鱼出现食欲不振的情况时&…...

【NLP 16、实践 ③ 找出特定字符在字符串中的位置】

看着父亲苍老的白发和渐渐老态的面容 希望时间再慢一些 —— 24.12.19 一、定义模型 1.初始化模型 ① 初始化父类 super(TorchModel, self).__init__()&#xff1a; 调用父类 nn.Module 的初始化方法&#xff0c;确保模型能够正确初始化。 ② 创建嵌入层 self.embedding n…...

一.photoshop导入到spine

这里使用的是 photoshoptospine脚本 下载地址:https://download.csdn.net/download/boyxgb/90156744 脚本的使用,可以通过文件的脚本的浏览,浏览该脚本使用该脚本,也可以将该脚本放在photoshop安装文件夹里的script文件夹下,具体路径:Photoshop\Presets\Scripts,重启photosho…...

docsify

macos ➜ ~ node -v v16.20.2➜ ~ npm --version 8.19.4全局安装 docsify-cli 工具 npm i docsify-cli -g➜ ~ docsify -vdocsify-cli version:4.4.4初始化项目 docsify init ./docsls -ah docs . .. .nojekyll README.md index.htmlindex.html 入口文件README.md 会…...