[shell] 将脚本编译成二进制可运行文件

将shell脚本编译成二进制可运行文件

  1. 前言

    在编写shell脚本的时候可能会存在一些端到端连接的密钥,这时候需要对脚本进行加密处理才能给客户使用。

    此时需要使用shc​工具来对shell脚本进行编译,使用shc​将bash/shell脚本编译为二进制可执行文件。

    SHC代表shell script compiler​,即shell脚本编译器。通过SHC编译过的脚本程序对普通用户而言是不读的,因此如果你想保护你的代码(例如含有密钥),则可以考虑SHC;然而有些人可以通过反向编译的方式破解SHC加密过的脚本。

  2. 安装

    sudo apt update
    sudo apt install shc
    
  3. 参数解析

    shc Usage: shc [-e date] [-m addr] [-i iopt] [-x cmnd] [-l lopt] [-o outfile] [-rvDSUHCABh] -f script
    
        -e %s  指定过期日期
        -m %s  指定过期后提示的消息
        -f %s  输入需要加密的文件名
        -i %s  Inline option for the shell interpreter i.e: -e
        -x %s  eXec command, as a printf format i.e: exec('%s',@ARGV);
        -l %s  Last shell option i.e: --
        -o %s  输出文件名
        -r     创建发行二进制文件,可以在别的(相同操作系统)系统中运行,如果只在当前系统中运行,可以不用加这个,否则要加
        -v     编译的详细情况
        -S     Switch ON setuid for root callable programs [OFF]
        -D     打开调试exec调用
        -U     Make binary untraceable [no]
        -H     Hardening : extra security protection [no]
               Require bourne shell (sh) and parameters are not supported
        -C     显示许可证并退出
        -A     显示描述并退出
        -B     Compile for busybox
        -h     显示帮助信息并退出
    
        Environment variables used:
        Name    Default  Usage
        CC      cc       C compiler command
        CFLAGS  <none>   C compiler flags
        LDFLAGS <none>   Linker flags
    
  4. 实践

    1. 创建一个测试文件,并输出它

      $ vim test.sh
      
      加入下面的代码
      #! /bin/bash
      echo "test"
      
      $ bash test.sh
      

      请添加图片描述

    2. 加密

      $ shc -v -f test.sh
      shc shll=bash
      shc [-i]=-c
      shc [-x]=exec '%s' "$@"
      shc [-l]=
      shc opts=
      shc: cc   test.sh.x.c -o test.sh.x
      shc: strip test.sh.x
      shc: chmod ug=rwx,o=rx test.sh.x
      

      执行加密后会生成两个文件test.sh.x.c​和test.sh.x​。

      • test.sh.x.c​是解析成c的源文件,没有作用,可以删除。
      • test.sh.x​是可执行的二进制文件,赋予执行权限后即可执行。

      执行命令:

      $ sudo chmod 777 test.sh.x
      $ mv test.sh.x test.sh
      $ ./test.sh
      

      请添加图片描述

  5. 安全性

    shc​ 使用的加密类型是叫做 RC4流密码的一个变体,目前它已经被证实存在弱点,存在被破解的可能,
    尤其在 shc​ 中,密钥被携带到加密脚本本身中,所以,是存在 通过反汇编破解出密钥,进而通过密钥还原原始脚本的可能性

    因此,我们不应该依赖 shc​ 加密的安全性,而是更多的把它当作是shell脚本内容的隐藏或者混淆工具。

  6. 解密方案

    https://github.com/yanncam/UnSHc

Reference

https://www.cnblogs.com/wangzy-Zj/p/17329627.html

https://www.phpernote.com/linux/1728.html

https://www.linuxprobe.com/shc-encrypt-shell.html

https://www.cnblogs.com/yuhaohao/p/10373050.html

https://blog.csdn.net/Neutionwei/article/details/132503346

https://www.jb51.net/article/230510.htm

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

锡城筱凯

你的鼓励是我创造的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值