免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1978 | 回复: 1
打印 上一主题 下一主题

[其他] 大神入 请叫shell 脚本加密的问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2015-03-04 14:42 |只看该作者 |倒序浏览
本帖最后由 teaklee 于 2015-03-04 14:58 编辑

通过 shc 可以将shell脚本转为二进制执行,以保护源碼.
但是如果这个shell脚本是 以 source xx.sh 方式被其他脚本调用 . 如下两个脚本
a.sh
tt=TEST


b.sh
source ./a.sh
echo $tt

a.sh加密后 , b.sh执行就出错了.
请问这种情况如何处理.我希望保护 a.sh 中的内容.

论坛徽章:
18
辰龙
日期:2014-05-21 21:01:4115-16赛季CBA联赛之深圳
日期:2016-12-23 13:51:3815-16赛季CBA联赛之北控
日期:2016-11-28 18:26:3815-16赛季CBA联赛之佛山
日期:2016-11-03 11:18:5815-16赛季CBA联赛之辽宁
日期:2016-07-10 16:09:4115-16赛季CBA联赛之江苏
日期:2016-02-20 23:09:202015亚冠之塔什干棉农
日期:2015-08-17 19:49:492015年亚洲杯之日本
日期:2015-04-30 01:24:342015年亚洲杯之约旦
日期:2015-04-01 00:37:182015年亚洲杯之沙特阿拉伯
日期:2015-03-02 15:55:40处女座
日期:2014-05-25 10:34:0020周年集字徽章-年
日期:2023-04-23 11:17:52
2 [报告]
发表于 2015-03-04 15:59 |只看该作者
本帖最后由 bikkuri 于 2015-03-04 16:20 编辑

a.sh加密后 , b.sh执行就出错了.
这个其实好理解。
假如a.sh经过shc加密后生成的文件是c.sh,那么b.sh实际上调用的是c.sh,而c.sh要有一个解密的过程还原出原来的a.sh,然后开启一个shell去执行a.sh。
虽然你的b.sh用的是source来调用c.sh,也就是说b.sh和c.sh是在同一个shell里面。
但是c.sh和a.sh并不是在同一个shell里面,所以shc加密事实上造成了b.sh和a.sh处于不同在shell里面,尽管b.sh里用了source命令。
那么当a.sh执行结束后,c.sh开启的那个shell中的环境变量也会随着shell的消亡而丢失。
所以b.sh是没办法得到a.sh传递的环境变量的。
可以通过临时文件传递变量。
a.sh
echo "TEST" > /tmp/tt


b.sh
source ./a.sh
tt=$(cat /tmp/tt)
echo $tt
但是临时文件如果是明文的话,又和你用shc加密a.sh的初衷相矛盾。
所以要不在a.sh中对临时文件也进行加密,然后在b.sh中对临时文件进行解密,
要不就不用shc来加密a.sh而是自己写一段加密程序来加密a.sh,在这段加密程序中用source来调用解密后的a.sh,以确保解密后的a.sh和b.sh也在同一个shell里。
当然除了用source还有很多其他办法,比如eval "$(cat a.sh)"。
后者应该比前者更安全一些。
但是shell脚本归根结底要解密成文本来执行,注定了其安全性不会太高,蒙一蒙门外汉还行,想糊弄稍微懂一点shell脚本的人都不能够。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP