【Linux乱炖】Shell脚本代码实现自解压缩,简单加密

AWZY
43
文章
1
评论
2020年5月14日08:25:52 评论 30 1407字

申明:以下内容大部分搜集于网络,由个人整理成更容易理解的简明教程!

 

一、原理阐述

linux下可以用几个最基本的命令制作一个自解压的程序。其原理是:利用cat 命令可以将两个文件连起来(用>>追加也能达到同样效果),前一个文件是shell脚本,负责执行解压和安装;后一个文件是一个压缩包。

把这两个文件通过cat连接成一个新的可执行文件,前面是解压程序,后面是压缩包,当你执行这个自解压文件时,会先执行前面的shell脚本,利用tail -n 取得后面的压缩包内容并往下执行解压和调用动作。这样就具有自动解压和安装的功能了。这里比较重要的命令是tail -n将后多少行(也就是压缩文件的内容)进行解压。

如此一来,也实现了内容的简单加密,使用cat合并两个文件之后,你再用cat去获取得到的内容会发现都是乱码,而且只要shell脚本行数和解压路径不知道,一时半会也很难找到源代码(当然,应该可以通过history来查看。

二、程序执行逻辑

  • 执行程序中的shell脚本代码
  • 把程序后面的部分进行解压
  • 执行源码安装和部署脚本
  • 退出程序

三、应用举例

假如当前目录下有一个压缩文件httpd.tar.gz,压缩包内有一个httpd文件夹,文件夹内有httpd的安装脚本install.sh和其他相关文件,现在需要将这个压缩文件制作成自解压并自动执行install.sh的可执行文件。现在开始介绍:

1.编写自解压引导脚本setup.sh

#vim setup.sh
#!/bin/bash
line=`wc -l $0|awk '{print $1}'`
line=`expr $line - 10`
tail -n $line $0 |tar zx -C /usr/local/src
cd /usr/local/src/httpd
./install.sh
ret=$?
#以下注释行(含此行)由代码中$line-10的10(假如叫n)来决定,应该补齐代码总行数为n+1行,这里即为11行
#
#
exit $ret

这个就是负责解压和调用安装脚本(install.sh)的引导脚本(或称“头文件”)

2.制作安装tar包

httpd.tar.gz是一个apache源码包的一个tar.gz包,里面已经DIY加入了install.sh脚本,也就是包含了手动安装apache所用的如./configure –with prefix=/usr/local/apache2,make,make install之类的安装命令。
反正就是在apache原始安装包解压后加入了install.sh脚本,然后使用命令
tar cvzf httpd.tar.gz httpd/重新打包为httpd.tar.gz
Ps:也就是说,若要手动安装,这解压这个包,然后执行./install.sh即可安装apache了。

3.制作最后的自解压安装程序

cat setup.sh httpd.tar.gz >install_httpd
chmod +x install_httpd

自解压安装程序的使用方法非常简单:

执行 ./install_httpd即可自动安装apache

注意:需要以root用户执行。

写在最后:这个教程百度能搜到很多,但是之前的内容如果是新手去看的话,可能有点难理解,一旦理解了就会觉得很容易,我重新整理了下,改成了更容易理解的应用举例即相关说明,希望和我当初一样的刚学linux的新人能快速学会这个方法。

weinxin
我的微信
爱玩资源网 致力于分享互联网优秀的绿色软件、电脑经验、技术交流、it资讯分享的博客网站.
  • 本文由 发表于 2020年5月14日08:25:52
  • 除非特殊声明,本站文章均为原创,转载请务必保留本文链接
【建站技巧】前端页面HTML压缩 建站搬砖

【建站技巧】前端页面HTML压缩

压缩HTML页面的好处就是略微提升页面加载速度,并给那些爱扒皮的缺德玩意制造些许麻烦。好了将如下代码添加在functions.php中即可: //压缩WordPress前端html代码     fun...
匿名

发表评论

匿名网友 填写信息

:?::razz::sad::evil::!::smile::oops::grin::eek::shock::???::cool::lol::mad::twisted::roll::wink::idea::arrow::neutral::cry::mrgreen: