Linux下创建可执行bin安装文件

简化操作,对于有些安装操作而言,需要包含安装脚本和脚本需要的文件两部分,封装成可执行bin文件之后就只有一个安装包了。

代码保护,在很多情况下,我们并不希望用户可以直接接触到代码部分,这种情况下,我们就更需要封装成bin文件来安装了。

【基本原理】

其实说起来很简单,可执行bin文件,其实就是将安装脚本和脚本需要的文件同时放到了同一个文件里面,然后在脚本里面去读取bin文件最后面的那部分内容。

读取出来之后正常执行脚本。

然后再删除。

如下:

#!/bin/sh
dir_installation=/root/create_bin
mkdir $dir_installation
sed -n -e '1,/^exit 0$/!p' $0 > "${dir_installation}/abc.rpm" 2>/dev/null
cd $dir_installation
rpm -ivh abc.rpm
rm -y abc.rpm
rm -y $dir_installation
exit 0

红色部分最为重要,它的目的主要是把exit 0后面的内容提取出来,另存为rpm包,然后执行安装,安装完成后删掉rpm。

绿色部分是实际我们执行的脚本。

【创建过程】

创建过程就更简单了:

cat install.sh ./abc.rpm > install.bin

然后用vim打开install.bin文件,发现最开始是我们的脚本部分内容,后半部分是我们的文件。

【代码保护】

关于代码保护,我们可以使用shc工具。

./shc -f install.bin

通过 shc 可以将脚本文件编译成二进制文件,隐藏了脚本的内容。

当然这并不是一个完美无缺的方案,linux也提供了方法对二进制文件进行反编译,但是至少普通用户是没有办法去查看相关代码内容了。

Linux公社的RSS地址https://www.linuxidc.com/rssFeed.aspx

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/11801.html