Cyberchef开发operation操作之-node开发环境搭建

news/2025/1/18 10:41:53/

本文介绍一下Cyberchef开发operation操作环境的搭建工作,为后续的Cyberchef开发operation操作提供开发环境基础,这里。该篇作为我的专栏《Cyberchef 从入门到精通教程》中的一篇,详见这里。

Linux环境

由于cyberchef只支持Linux和MAC的开发环境,因此需要安装Linux,我个人选择Debian为开发环境。
在这里插入图片描述
我的环境如下:
在这里插入图片描述
个人可以根据情况灵活选择MAC系统或者不同的Linux发行版本。

node_7">node安装

cyberchef的开发环境为node18,具体要求详见这里。关于node的安装参考见这里,和这里。使用如下命令安装node18:

sudo apt-get install -y curl
curl -fsSL https://deb.nodesource.com/setup_18.x -o nodesource_setup.sh
sudo -E bash nodesource_setup.sh
sudo apt-get install -y nodejs
node -v

SMB设置

由于开发环境是在debian中,但是IDE工具使用的是Windows上的VS code,因此需要配置SMB。debian默认没有SMB,因此需要首先安装,命令如下:

apt-get install samba
sudo mkdir -p /repo
sudo chmod 777 /repo
chown -R debain:debian repo

选择repo为共享目录,同时通过bashnano /etc/samba/smb.conf修改SMB配置文件,在配置文件末尾添加如下配置:

[share]comment = Shared folderpath = /repobrowseable = yesguest only = yeswritable = yesread only = nocreate mask = 0777directory mask = 0777

修改之后重启SMB,如下:

systemctl restart smbd
systemctl restart nmbd

这里这个共享目录路径选择非常关键,最好在根目录下设置repo。因为在Samba里,如果你要设置的共享目录是/home/debian/share,那么必须把home,debian ,share这三个目录,即共享的父目录直到 / 下面的目录,全部设置为可访问可读写权限,这样最后才能在Windows上成功访问SMB,不然的话在输入正确的用户名和密码之后会一直提示没有权限访问。因此为了省事,上述直接在根目录新建repo目录。

Windows设置

为了避免可能的SMB访问问题,通常在window上还需要做如下设置,首先打开SMB1:
在这里插入图片描述

其次启动不安全来宾登录:
在这里插入图片描述

最后将SMB的文件路径映射到本地的F盘:
在这里插入图片描述

如果已经存在连接使用如下命令进行删除:

net use \\192.168.233.132\share /delete

Git设置

下载代码,首先确保本机器安装了gitgit的下载链接为这里。需要设置git的代理进行GitHub代码下载,前提要本地启用代理,在debian中使用命令如下:

git config --global http.proxy http://127.0.0.1:7890
git config --global https.proxy http://127.0.0.1:7890

当然也可以在winddows上VScode设置,如下:
在这里插入图片描述

cyberchef_69">cyberchef

代理

首先在debian的cyberchef文件夹下,执行npm install,将会按照package.json文件中的配置,安装cyberchef所需要的依赖文件。需要注意的是这个地方需要设置代理,不然有些安装包源可能存在问题,debian上设置代理如下:
在这里插入图片描述

去除代理的命令为:

unset http_proxy
unset https_proxy

npm_install_80">npm install

执行npm install,安装依赖如下:
在这里插入图片描述
npm install执行的结果如下

npm warn EBADENGINE Unsupported engine {
npm warn EBADENGINE   package: '@astronautlabs/amf@0.0.6',
npm warn EBADENGINE   required: { node: '^14' },
npm warn EBADENGINE   current: { node: 'v18.20.5', npm: '10.8.2' }
npm warn EBADENGINE }
npm warn deprecated phin@2.9.3: Package no longer supported. Contact Support at https://www.npmjs.com/support for more info.
npm warn deprecated glob@8.1.0: Glob versions prior to v9 are no longer supported
npm warn deprecated loglevel-message-prefix@3.0.0: Use @natlibfi/loglevel-message-prefix instead
npm warn deprecated es6-polyfills@2.0.0: Use @natlibfi/es6-polyfills instead> cyberchef@10.19.4 postinstall
> npx grunt exec:fixCryptoApiImports && npx grunt exec:fixSnackbarMarkup && npx grunt exec:fixJimpModuleRunning "exec:fixCryptoApiImports" (exec) taskDone.
Running "exec:fixSnackbarMarkup" (exec) taskDone.
Running "exec:fixJimpModule" (exec) taskDone.added 1468 packages in 2m199 packages are looking for fundingrun `npm fund` for details

npm_start_114">npm start

执行npm start, 该命令的逻辑位于package.json中,如下:
在这里插入图片描述

npm start 执行结果如下:

> cyberchef@10.19.4 start
> npx grunt devRunning "clean:dev" (clean) task
>> 0 paths cleaned.Running "clean:config" (clean) task
>> 0 paths cleaned.Running "exec:generateConfig" (exec) task--- Regenerating config files. ---
Written operation index.
Written OperationConfig.json
Written Ciphers module
Written Default module
Written Encodings module
Written Image module
Written Crypto module
Written Serialise module
Written Hashing module
Written Bletchley module
Written Compression module
Written Code module
Written Diff module
Written Shellcode module
Written Charts module
Written Regex module
Written PGP module
Written PublicKey module
Written OCR module
Written URL module
Written UserAgent module
Written Protobuf module
Written Yara module
Written OpModules.mjs
--- Config scripts finished. ---Running "concurrent:dev" (concurrent) taskRunning "watch:config" (watch) taskWaiting...Running "webpack-dev-server:start" (webpack-dev-server) task<i> [webpack-dev-server] Project is running at:<i> [webpack-dev-server] Loopback: http://localhost:8080/, http://[::1]:8080/<i> [webpack-dev-server] Content not from webpack is served from '/repo/CyberChef-Peter/public' directoryBrowserslist: caniuse-lite is outdated. Please run:npx update-browserslist-db@latestWhy you should do it regularly: https://github.com/browserslist/update-db#readme

访问本地localhost:8080的web服务如下:
在这里插入图片描述

有了上述的前期准备,接下来就可以按照自己的需求定制化自己的operation了,详见后续的文章《Cyberchef开发operation操作之-增加LEEF解析插件》,这里。

上述就是cyberchef开发所依赖的环境配置,希望对你开发cyberchef的操作有所帮助。

本文为CSDN村中少年原创文章,未经允许不得转载,博主链接这里。


http://www.ppmy.cn/news/1563862.html

相关文章

Python 替换excel 单元格内容

要在Python中替换Excel单元格的内容&#xff0c;你可以使用openpyxl库。openpyxl是一个用于读写Excel 2010 xlsx/xlsm/xltx/xltm文件的库。 安装openpyxl 首先&#xff0c;你需要安装openpyxl库。如果还没有安装&#xff0c;可以使用pip进行安装&#xff1a; pip install ope…

RV1126+FFMPEG推流项目(3)VI模块视频编码流程

视频编码的流程&#xff1a; 本章节讲的是RV1126视频编码的流程&#xff0c;在整个项目之中视频编码功能是核心之一。视频编码流程主要分三步&#xff1a;VI的初始化、VENC的初始化(硬件编码)、绑定VI和VENC节点、开启VENC线程进行视频编码的采集&#xff0c;注意一下这里的…

react中,使用antd的Upload组件上传zip压缩包文件

需求 使用antd的Upload上传.zip压缩包文件 代码 const [uploadLoaing, setUploadLoaing] useState(false);// 辅助函数&#xff1a;检查文件是否为zip格式function isZipFile(file: File): boolean {const fileType file.type;return fileType application/zip || file.n…

Checkbox 多选框的使用

基础用法 在el-checkbox元素中定义v-model绑定变量&#xff0c;单一的checkbox中&#xff0c;默认绑定变量的值会是Boolean&#xff0c;选中为true 禁用状态 设置disabled属性即可。 多选框组 checkbox-group元素能把多个 checkbox 管理为一组&#xff0c;只需要在 Group …

前端下载图片

可直接看第3条 1、a链接形式&#xff08;不推荐&#xff09; 这种方式可以下载文件&#xff0c;对于图片类&#xff0c;浏览器会直接打开 export function downloadFile(src: string, fileName: string) {const ele document.createElement(a);ele.setAttribute(href, src)…

Keil使用STLink下载烧录闪退解决(使用STLink烧录)

一&#xff1a;问题出现 在使用新版本keil开发STM32的的时候在选择STLink下载&#xff0c;在下载的的时候会进行闪退&#xff0c;点击load会直接退出keil&#xff0c;经过检查发现是STLink驱动出了问题&#xff0c;只需要重新安装驱动即可&#xff0c;具体解决方案如下。 二&am…

Android BitmapShader更简易的实现刮刮乐功能,Kotlin

Android BitmapShader更简易的实现刮刮乐功能&#xff0c;Kotlin 比这种方式 Android使用PorterDuffXfermode模式PorterDuff.Mode.SRC_OUT橡皮擦实现“刮刮乐”效果&#xff0c;Kotlin&#xff08;2&#xff09;-CSDN博客 更简单实现刮刮乐效果。 import android.content.Cont…

01、flink的原理和安装部署

flink中主要有两个进程&#xff0c;分别是JobMManager和TaskManager&#xff0c;当然了根据flink的部署和运行环境不同&#xff0c;会有一些不同&#xff0c;但是主要的功能是类似的&#xff0c;下面我会讲下聊下&#xff0c;公司用的多的部署方式&#xff0c;基于yarn集群的部…