shell脚本可以加密吗

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了shell脚本可以加密吗相关的知识,希望对你有一定的参考价值。

第一种方法(gzexe):
这种加密方式不是非常保险的方法,但是能够满足一般的加密用途,可以隐蔽脚本中的密码等信息。它是使用系统自带的gzexe程序,它不但加密,同时压缩文件。
使用方法: gzexe file.sh
它会把原来没有加密的文件备份为file.sh~ ,同时 file.sh 即被变成加密文件;
第二种方法(shc):
使用 shc 对 Linux shell 脚本加密.
shc是一个专业的加密shell脚本的工具.它的作用是把shell脚本转换为一个可执行的二进制文件,这个办法很好的解决了脚本中含有IP、密码等不希望公开的问题.
参考技术A 两种方法
gzexe shell-script
这样会把shell脚本打包成一个可执行程序,但是使用者看不到脚本内容
gcc compile file
用gcc对shell进行编译生成可执行文件

我可以从另一个 shell 脚本调用一个 shell 脚本的函数吗?

【中文标题】我可以从另一个 shell 脚本调用一个 shell 脚本的函数吗?【英文标题】:Can I call a function of a shell script from another shell script? 【发布时间】:2012-06-05 01:43:57 【问题描述】:

我有 2 个 shell 脚本。

第二个shell脚本包含以下函数 second.sh

func1 
func2

first.sh 将调用带有一些参数的第二个 shell 脚本和 将使用特定于该函数的一些其他参数调用 func1 和 func2。

这是我所说的例子

second.sh

val1=`echo $1`
val2=`echo $2`

function func1 

fun=`echo $1`
book=`echo $2`



function func2 

fun2=`echo $1`
book2=`echo $2`



first.sh

second.sh cricket football

func1 love horror
func2 ball mystery

我怎样才能实现它?

【问题讨论】:

重复 - ***.com/questions/8352851/… v=$(echo $1) 完全是多余的。只需写fun2=$1。唯一的区别是$()(或反引号)将删除尾随的换行符。 由于从 shell 脚本调用函数与命令行相比没有什么特别之处,所以这个问题可以简化为“如何调用 bash 函数?” 【参考方案1】:

像这样重构你的 second.sh 脚本:

func1 
   fun="$1"
   book="$2"
   printf "func=%s,book=%s\n" "$fun" "$book"


func2 
   fun2="$1"
   book2="$2"
   printf "func2=%s,book2=%s\n" "$fun2" "$book2"

然后像这样从脚本first.sh 调用这些函数:

source ./second.sh
func1 love horror
func2 ball mystery

输出:

func=love,book=horror
func2=ball,book2=mystery

【讨论】:

为避免意外的副作用,请注意source 命令实际上会运行作为参数传递的脚本。 @dvlcube 如果你能提出一个替代方案会更好。 这个答案很清楚很好。重要的是,***.com/a/42101141/852196 描述了一些人可能遇到的问题,并提供了一个优雅的通用解决方案。 @Alpha2k 我不确定是否有替代方案。这个想法是“小心你在源文件中放入的内容”【参考方案2】:

您不能直接调用另一个 shell 脚本中的函数。

您可以将您的函数定义移动到一个单独的文件中,然后使用. 命令将它们加载到您的脚本中,如下所示:

. /path/to/functions.sh

这会将functions.sh 解释为好像它的内容此时实际存在于您的文件中。这是实现 shell 函数共享库的常用机制。

【讨论】:

这与接受的答案不一样吗,因为.source 的别名? 好吧,我先回答了,所以从技术上讲,接受的答案与这个相同:)。此外,虽然source 在许多shell 中是. 的别名,但情况并非总是如此。例如,Debian 上提供/bin/shdash 软件包没有source 命令。 source 命令在 Ubuntu @ajsharma 中不起作用。参考:source command not found in sh shell 太奇怪了,这条评论没有被评为最高?这是正确的 #!/bin/sh 语法,另一种只能在 bash 中使用。【参考方案3】:

问题

当前接受的答案仅在重要条件下有效。给定...

/foo/bar/first.sh:

function func1   
   echo "Hello $1"

/foo/bar/second.sh:

#!/bin/bash

source ./first.sh
func1 World

这只有在first.sh 是从first.sh 所在的同一目录中执行时才有效。 IE。如果shell当前工作路径为/foo,则尝试运行命令

cd /foo
./bar/second.sh

打印错误:

/foo/bar/second.sh: line 4: func1: command not found

这是因为source ./first.sh 是相对于当前工作路径的,而不是脚本的路径。因此,一种解决方案可能是利用 subshel​​l 并运行

(cd /foo/bar; ./second.sh)

更通用的解决方案

鉴于...

/foo/bar/first.sh:

function func1   
   echo "Hello $1"

/foo/bar/second.sh:

#!/bin/bash

source $(dirname "$0")/first.sh

func1 World

然后

cd /foo
./bar/second.sh

打印

Hello World

工作原理

$0 返回执行脚本的相对或绝对路径 dirname 返回目录的相对路径,$0 脚本所在的目录 $( dirname "$0" ) dirname "$0" 命令返回相对 执行脚本的目录路径,然后用作source 命令的参数 在“second.sh”中,/first.sh只是附加了导入的shell脚本的名称 source 将指定文件的内容加载到当前 贝壳

【讨论】:

这正是我所需要的。非常感谢!【参考方案4】:

second.sh

#!/bin/bash

function func1() 
   fun="$1"
   book="$2"
   echo "$fun, $book\n"


function func2() 
   fun2="$1"
   book2="$2"
   printf "$fun2, $book2\n"

first.sh

#!/bin/bash

source /absolute_path_to/second.sh
func1 love horror
func2 ball mystery

在使用之前你需要记住这些事情

关键字source.(句点)是同一个命令。 如果FILENAME 不是文件的完整路径,该命令将在$PATH 环境变量中指定的目录中搜索文件。如果在$PATH 中找不到该文件,该命令将在当前目录中查找该文件。 如果给出任何ARGUMENTS,它们将成为FILENAME 的位置参数。 如果FILENAME存在,则源命令退出码为0,否则,如果找不到文件,则返回1

在这些要点中,要关注的一点是second,如果您使用的是#!/bin/bash,则实际上需要为文件提供ABSOLUTE_PATH,如果是,RELATIVE_PATH 只是不起作用你的情况然后我的朋友你只需要将路径更改为ABSOLUTE_FILE_PATH

【讨论】:

【参考方案5】:

如果你定义了

    #!/bin/bash
        fun1()
          echo "Fun1 from file1 $1"
        
fun1 Hello
. file2 
fun1 Hello
exit 0

在文件 1 中(chmod 750 文件 1) 和文件2

   fun1()
      echo "Fun1 from file2 $1"
    
    fun2()
      echo "Fun1 from file1 $1"
    

然后运行 ​​./file2 你会得到 来自file1的Fun1 来自file2的Fun1 惊喜!!!您用 file2 中的 fun1 覆盖 file1 中的 fun1... 为了不这样做,您必须

declare -f pr_fun1=$fun1
. file2
unset -f fun1
fun1=$pr_fun1
unset -f pr_fun1
fun1 Hello

它会保存您之前对 fun1 的定义并使用之前的名称恢复它,删除不需要导入的名称。 每次从另一个文件导入函数时,您可能会记住两个方面:

    你可以用相同的名字覆盖现有的(如果你想要的东西你必须如上所述保留它们) 导入导入文件的所有内容(函数和全局变量) 当心!这是一个危险的过程

【讨论】:

【参考方案6】:

这是一个非常古老的帖子,我知道。但是我发现即使它位于同一目录中,我也无法获取另一个文件。

line 3: ./functions.bash: No such file or directory

然后我记得我已经为这种确切情况准备了一个方法,因为我是从一个 ini 文件导入的。所以这是我的解决方案,它允许我从任何地方(显然是源文件)运行程序,而无需对路径进行硬编码。

app="$(cd "$(dirname "$BASH_SOURCE[0]")" &>/dev/null && pwd)"
source $app/functions.bash

我不能把这归功于这个,已经有一段时间了,我不记得我从哪里得到的,否则我会相信他们,但这就是我用来源文件的全部。

【讨论】:

【参考方案7】:
#vi function.sh

#!/bin/bash
f1() 
    echo "Hello $name"


f2() 
    echo "Enter your name: "
    read name
    f1

f2

#sh function.sh

这里的函数f2会调用函数f1

【讨论】:

以上是关于shell脚本可以加密吗的主要内容,如果未能解决你的问题,请参考以下文章

手机shell脚本加密后不能运行

shell脚本加密笔记!

shell 脚本加密

Shell 脚本加密

对shell脚本进行加密

linxu下的shell脚本加密