Shell 是用C语言编写的程序,即是一种命令语言,也是一种程序设计语言。其提供了一个界面,使得用户可以通过该界面访问操作系统内核的服务。
Shell种类有众多:获取指令:cat /etc/shells
Bourne shell (/usr/bin/sh或者/bin/sh)
Bourne again shell (/bin/bash)
C shell (/usr/bin/csh)
K shell (/usr/bin/ksh)
Shell for root (/sbin/sh)
…..
以下是命令的解释
echo 命令用于向窗口输出文本
chmod +x ./test.sh #使脚本具有执行权限
./test.sh #执行脚本,加.是告诉系统说在当前目录找test.sh文件
变量命名规则
。只能是字母、数字和下划线,首个字符不能以数字开头
。中间不能有空格,可以用下划线(_)
。不能使用标点符号
。不能使用关键字
for file in ‘ls /etc’ 或者 for file in $(ls /etc)将/etc目录下的文件名循环出来
使用一个定义过的变量,只要在变量名前面加美元符号即可,花括号可选,花括号帮助编译器识别变量边界,习惯加上即可
your_name=“panshuyan"
echo $your_name
echo ${your_name}
字符串可以是单引号,也可以使用双引号,也可以不用引号。但是有一些区别:
单引号中任何字符都会原样输出,其中的变量是无效的
双引号中可以使用变量,${your_name}就想%@输出一样,可以出现转义字符
文件测试运算符
-b file
检测文件是否是块设备文件,如果是,则返回 true。
[ -b $file ] 返回 false。
-c file
检测文件是否是字符设备文件,如果是,则返回 true。
[ -c $file ] 返回 false。
-d file
检测文件是否是目录,如果是,则返回 true。
[ -d $file ] 返回 false。
-f file
检测文件是否是普通文件(既不是目录,也不是设备文件),如果是,则返回 true。
[ -f $file ] 返回 true。
-g file
检测文件是否设置了 SGID 位,如果是,则返回 true。
[ -g $file ] 返回 false。
-k file
检测文件是否设置了粘着位(Sticky Bit),如果是,则返回 true。
[ -k $file ] 返回 false。
-p file
检测文件是否是有名管道,如果是,则返回 true。
[ -p $file ] 返回 false。
-u file
检测文件是否设置了 SUID 位,如果是,则返回 true。
[ -u $file ] 返回 false。
-r file
检测文件是否可读,如果是,则返回 true。
[ -r $file ] 返回 true。
-w file
检测文件是否可写,如果是,则返回 true。
[ -w $file ] 返回 true。
-x file
检测文件是否可执行,如果是,则返回 true。
[ -x $file ] 返回 true。
-s file
检测文件是否为空(文件大小是否大于0),不为空返回 true。
[ -s $file ] 返回 true。
-e file
检测文件(包括目录)是否存在,如果是,则返回 true。
[ -e $file ] 返回 true。
数值测试:
-eq
等于则为真
-ne
不等于则为真
-gt
大于则为真
-ge
大于等于则为真
-lt
小于则为真
-le
小于等于则为真
流程控制,
if else
fi
if的语法格式:
if condition
then
command1
command2
command3
…
commandN
fi
写成一行,适合iTerm2命令提示符:
if [ $(ps -ef | grep -c “ssh”) -gt 1]; then echo “true”; fi
TARGET_APP_FRAMEWORKS_PATH="$TARGET_APP_PATH/Frameworks"
if [ -d "$TARGET_APP_FRAMEWORKS_PATH" ];
then
for FRAMEWORK in "$TARGET_APP_FRAMEWORKS_PATH/"*
do
#签名
/usr/bin/codesign --force --sign "$EXPANDED_CODE_SIGN_IDENTITY" "$FRAMEWORK"
done
fi
上面代码的意思是:
获取APP framework的路径,判断路径目录是否存在,存在则遍历路径下所有的文件,也就是所有framework,对所有framework进行重签名
网友评论