综合 保护你的 Shell 脚本:Shell 脚本高效加密指南

2024-11-19 07:28:17 +0800 CST views 1839

保护你的 Shell 脚本:Shell 脚本高效加密指南

在日常运维工作中,Shell 脚本的使用非常广泛。然而,随着脚本的重要性和敏感性增加,如何对其进行加密保护变得尤为重要。本文将介绍两种常见的 Shell 脚本加密工具:SHCgzexe。SHC 提供了高等级的加密,而 gzexe 则适用于安全性要求不高的场景。

SHC - 高等级加密

SHC(Shell Script Compiler)是一款专门用于加密和编译 Shell 脚本的工具。它可以将 Shell 脚本转换成二进制可执行文件,保护脚本的源代码不被直接查看和修改。

注意:

  • CentOS 7 与 CentOS 8 生成的脚本不通用,需要在哪个版本生成就在相同版本中使用。

通过 yum 安装

首先,通过 yum 安装 shc 工具:

yum install -y shc

通过下载源码安装

如果需要通过源码安装,可以按照以下步骤进行:

  1. 安装 gcc 及 make

    如果已安装 gcc 和 make,可略过此步骤:

    yum -y install gcc make
    
  2. 下载并编译安装 shc-4.0.3

    建议使用科学上网工具从 GitHub 下载源码:shc-4.0.3下载地址

  3. 解压下载的压缩包

    tar -xzvf shc-4.0.3.tar.gz
    
  4. 编译并安装 shc

    进入解压后的目录并执行以下命令进行编译安装:

    cd shc-4.0.3
    ./configure && make install
    
  5. 安装完成

    至此,shc 安装完成。

使用 shc 加密脚本

  1. 创建一个 Shell 脚本

    vim test-shc.sh
    

    内容如下:

    #!/bin/sh
    echo `date`
    
  2. 生成加密脚本

    shc -v -f test-shc.sh
    
  3. 查看生成的文件

    ll
    

    输出内容:

    -rw-r--r-- 1 root root    22 May 26 14:52 test-shc.sh
    -rwxrwxr-x 1 root root 11120 May 26 14:52 test-shc.sh.x
    -rw-r--r-- 1 root root 17592 May 26 14:52 test-shc.sh.x.c
    

    说明:

    • test-shc.sh 是原始的未加密 Shell 脚本。
    • test-shc.sh.x 是二进制格式的加密 Shell 脚本。
    • test-shc.sh.x.c 是生成加密脚本的 C 源代码。
  4. 执行加密后的脚本

    ./test-shc.sh.x
    

    输出:

    Thu May 26 14:56:30 CST 2022
    
  5. 指定脚本过期时间并设置提示信息

    shc -e 06/10/2023 -m "error" -v -f test-shc.sh
    

    如果脚本过期,提示如下:

    ./test-shc.sh.x: has expired!
    error
    

gzexe - 低等级加密

gzexe 是系统自带的工具,无需另外安装。它适用于对安全性要求不高的文件进行简单加密,支持 Shell 脚本以及其他文本文件。

gzexe 加密/解密用法

  1. 加密

    gzexe example.sh
    

    加密后会生成两个文件:

    • example.sh: 加密后的脚本文件。
    • example.sh~: 原始脚本的备份文件。
  2. 解密

    gzexe -d example.sh
    

    解密后恢复原始脚本,原加密文件会被重命名为 example.sh~

总结

通过本文介绍的 SHC 和 gzexe 工具,你可以根据实际需求选择合适的 Shell 脚本加密方式。SHC 提供了更高等级的加密保护,适合需要严格安全性的场景;而 gzexe 则适用于对安全性要求较低的场景。


引用链接

[1] shc-4.0.3 下载地址

复制全文 生成海报 Shell脚本 安全 加密工具

推荐文章

imap_open绕过exec禁用的脚本
2024-11-17 05:01:58 +0800 CST
Go 开发中的热加载指南
2024-11-18 23:01:27 +0800 CST
Nginx 状态监控与日志分析
2024-11-19 09:36:18 +0800 CST
向满屏的 Import 语句说再见!
2024-11-18 12:20:51 +0800 CST
在 Nginx 中保存并记录 POST 数据
2024-11-19 06:54:06 +0800 CST
MySQL 主从同步一致性详解
2024-11-19 02:49:19 +0800 CST
Hypothesis是一个强大的Python测试库
2024-11-19 04:31:30 +0800 CST
网络数据抓取神器 Pipet
2024-11-19 05:43:20 +0800 CST
Vue 3 中的 Watch 实现及最佳实践
2024-11-18 22:18:40 +0800 CST
Vue3中的组件通信方式有哪些?
2024-11-17 04:17:57 +0800 CST
mysql 优化指南
2024-11-18 21:01:24 +0800 CST
一键配置本地yum源
2024-11-18 14:45:15 +0800 CST
Vue3中如何处理跨域请求?
2024-11-19 08:43:14 +0800 CST
Nginx负载均衡详解
2024-11-17 07:43:48 +0800 CST
Golang在整洁架构中优雅使用事务
2024-11-18 19:26:04 +0800 CST
程序员茄子在线接单