0

我正在使用以下脚本(Source)加密我的 Cocoa 应用程序中的一些资源:

DIRNAME=EncryptedResources
ENC_KEY="abcdefghijklmnopqrstuvwxyz123456"

INDIR=$PROJECT_DIR/$DIRNAME
OUTDIR=$TARGET_BUILD_DIR/$CONTENTS_FOLDER_PATH/$DIRNAME

if [ ! -d "$OUTDIR" ]; then
  mkdir -p "$OUTDIR"
fi

for file in "$INDIR"/*
do
  echo "Encrypting $file"
  "$PROJECT_DIR/crypt" -e -k $ENC_KEY -i "$file" -o "$OUTDIR/`basename "$file"`"
done

但是,该脚本不处理 EncryptedResources 目录中的子目录。我有几个嵌套的子目录,那么修改 shell 脚本以处理子目录并正确输出这些文件的最简单方法是什么。

4

2 回答 2

1

您需要使用find命令而不是for循环。

find $INDIR -exec "$PROJECT_DIR/crypt" 
    -e -k $ENC_KEY -i {} -o "$OUTDIR/`basename {}`" \; # all on one line

可能是您需要做的一个很好的近似值,但find很难使用,而且我正在记忆中工作。

于 2013-04-22T02:59:52.200 回答
0

仅供参考,我使用了以下内容:

DIRNAME=ENCRYPTEDCONTENT
ENC_KEY="INSERT ENCRYPTION KEY HERE"

INDIR=$PROJECT_DIR/$DIRNAME
OUTDIR=$TARGET_BUILD_DIR/$CONTENTS_FOLDER_PATH/Resources/$DIRNAME

if [ ! -d "$OUTDIR" ]; then
mkdir -p "$OUTDIR"
fi


while IFS= read -r -d $'\0' dir;
do
DIRECTORY=`echo $dir | sed -e "s,$INDIR,$OUTDIR,g"`
mkdir -p "$DIRECTORY"
done < <(find "$INDIR" -type d -print0)

while IFS= read -r -d $'\0' file;
do
OUTFILE=`echo $file | sed -e "s,$INDIR,$OUTDIR,g"`
if [ ! -d "$file" ]; then
echo "Encrypting $file"
"$PROJECT_DIR/crypt" -e -k $ENC_KEY -i "$file" -o "$OUTFILE"
fi
done < <(find "$INDIR" -type f -print0)
于 2013-06-16T08:23:41.277 回答