当前位置: 首页 > news >正文

Shell脚本实践(修改文件,修改配置文件,执行jar包)

1、前言

需要编写一个shell脚本支持

1、修改.so文件

2、修改配置文件

3、执行jar包

2、代码解析

2.1、修改.so文件

so_file_dir="/opt/casb/xxx/lib"

# 处理.so文件
cd "$so_file_dir" || { echo "错误: 无法进入目录 $so_file_dir"; exit 1; }
if [ -e "libCSCipherJNI-release-2.3.8.so" ]; then
    echo "目标.so文件已存在"
else
    so_files=(libCSCipherJNI-release-*.so)
    if [ -e "${so_files[0]}" ]; then
        mv "${so_files[0]}" libCSCipherJNI-release-2.3.8.so
        echo "已重命名.so文件"
    else
        echo "错误: 未找到匹配的.so文件"; exit 1
    fi
fi

2.2、修改配置文件(难点在这个)

# 复制配置文件
if [ -e "$source_file" ]; then
    cp "$source_file" "$target_file"
    echo "已复制配置文件"
else
    echo "错误: 源配置文件不存在"; exit 1
fi

# 替换配置项
cp "$target_file" "${target_file}.bak"

# 安全转义字符串中的特殊字符
escape_sed() {
    echo "$1" | sed -e 's/[\/&]/\\&/g'
}

# 替换函数(带逗号后缀)
replace_property_comma() {
    local config_name="$1"
    local config_value="$2"
    local escaped_name=$(escape_sed "$config_name")
    local escaped_value=$(escape_sed "$config_value")

    # 查找配置项(忽略等号周围空格)
    local existing_line=$(grep -E "^[[:space:]]*$escaped_name[[:space:]]*=[[:space:]]*" "$target_file")

    if [ -n "$existing_line" ]; then
        # 提取当前配置项的值部分(考虑等号周围的空格)
        current_value=$(echo "$existing_line" | sed -E "s/^[[:space:]]*$escaped_name[[:space:]]*=[[:space:]]*//")

        # 如果当前值和要设置的值不同,才进行替换
        if [ "$current_value" != ",$escaped_value,,,,,," ]; then
            # 使用更灵活的正则表达式匹配(忽略等号周围空格)
            sed -i.bak -E "s/^([[:space:]]*$escaped_name[[:space:]]*=[[:space:]]*).*/\1,$escaped_value,,,,,,,/" "$target_file"
            echo "✓ 已更新: $config_name=,$escaped_value"
        else
            echo "配置项 $config_name 值未改变,无需更新"
        fi
    else
        echo "⚠️ 配置项 $config_name 不存在,跳过修改"
    fi
}

# 替换函数(直接为值,不带逗号)
replace_property_value() {
    local config_name="$1"
    local config_value="$2"
    local escaped_name=$(escape_sed "$config_name")
    local escaped_value=$(escape_sed "$config_value")

    # 查找配置项(忽略等号周围空格)
    local existing_line=$(grep -E "^[[:space:]]*$escaped_name[[:space:]]*=[[:space:]]*" "$target_file")

    if [ -n "$existing_line" ]; then
        # 提取当前配置项的值部分(考虑等号周围的空格)
        current_value=$(echo "$existing_line" | sed -E "s/^[[:space:]]*$escaped_name[[:space:]]*=[[:space:]]*//")

        # 如果当前值和要设置的值不同,才进行替换
        if [ "$current_value" != "$escaped_value" ]; then
            # 使用更灵活的正则表达式匹配(忽略等号周围空格)
            sed -i.bak -E "s/^([[:space:]]*$escaped_name[[:space:]]*=[[:space:]]*).*/\1$escaped_value/" "$target_file"
            echo "✓ 已更新: $config_name=$escaped_value"
        else
            echo "配置项 $config_name 值未改变,无需更新"
        fi
    else
        echo "⚠️ 配置项 $config_name 不存在,跳过修改"
    fi
}

# 根据模式执行不同配置
case "$MODE" in
    en)
        echo "==== 配置加密模式 ===="

        # 设置加密参数(前4个带逗号,后2个不带)
        replace_property_comma "export.columns.keyId" "$paramA"
        replace_property_comma "export.columns.metadata" "$paramB"
        replace_property_comma "export.columns.algorithm" "$paramC"
        replace_property_comma "export.columns.iv" "$paramD"
        replace_property_value "EN_DE_CRYPT_MODE" "0"
        replace_property_value "RENAME_SUFFIX" "plain.csv"

        ACTION="加密"
        ;;
    de)
        echo "==== 配置解密模式 ===="

        # 设置解密参数(前4个带逗号,后2个不带)
        replace_property_comma "export.columns.keyId" "$paramA"
        replace_property_comma "export.columns.metadata" "$paramB"
        replace_property_comma "export.columns.algorithm" "$paramC"
        replace_property_comma "export.columns.iv" "$paramD"
        replace_property_value "EN_DE_CRYPT_MODE" "1"
        replace_property_value "RENAME_SUFFIX" "cipher.csv"

        ACTION="解密"
        ;;
    *)
        echo "错误: 未知模式 '$MODE' (支持: en=加密, de=解密)"
        exit 1
        ;;
esac

2.3、执行jar包

# 执行 Java 程序
echo "==== 开始执行$ACTION ===="
cd "$target_dir" || { echo "错误: 无法进入目录 $target_dir"; exit 1; }
if [ -e "$users_csv_file" ]; then
    java -jar decryption*.jar user.properties users.csv
else
    echo "错误: 数据文件 $users_csv_file 不存在"; exit 1
fi

echo "==== $ACTION操作已完成 ===="

3、修改配置文件遇到问题:配置项在配置文件里有,但是就是找不到

EN_DE_CRYPT_MODE = 0

RENAME_SUFFIX = plain.csv 

3.1、原因

因为=号的前后空格导致,需要匹配空格才行。

3.2、解决方法

关键点回顾

  1. 空格处理:使用 [[:space:]]* 正则表达式匹配任意数量的空格,包括制表符和换行符
  2. 值提取:改进了值提取逻辑,确保能正确获取等号后的实际值
  3. 替换精度:在替换时保留了原有的空格格式,只修改值部分

# 替换函数(带逗号后缀)
replace_property_comma() {
    local config_name="$1"
    local config_value="$2"
    local escaped_name=$(escape_sed "$config_name")
    local escaped_value=$(escape_sed "$config_value")
    
    # 查找配置项(忽略等号周围空格)
    local existing_line=$(grep -E "^[[:space:]]*$escaped_name[[:space:]]*=[[:space:]]*" "$target_file")
    
    if [ -n "$existing_line" ]; then
        # 提取当前配置项的值部分(考虑等号周围的空格)
        current_value=$(echo "$existing_line" | sed -E "s/^[[:space:]]*$escaped_name[[:space:]]*=[[:space:]]*//")
        
        # 如果当前值和要设置的值不同,才进行替换
        if [ "$current_value" != ",$escaped_value,,,,,," ]; then
            # 使用更灵活的正则表达式匹配(忽略等号周围空格)
            sed -i.bak -E "s/^([[:space:]]*$escaped_name[[:space:]]*=[[:space:]]*).*/\1,$escaped_value,,,,,,,/" "$target_file"
            echo "✓ 已更新: $config_name=,$escaped_value"
        else
            echo "配置项 $config_name 值未改变,无需更新"
        fi
    else
        echo "⚠️ 配置项 $config_name 不存在,跳过修改"
    fi
}

4、Shell脚本实践

4.1、shell脚本全文

#!/bin/bash# 检查模式参数
if [ $# -lt 5 ]; thenecho "错误: 需要指定操作模式和4个参数"echo "用法: $0 en|de <A> <B> <C> <D>"exit 1
fiMODE="$1"
paramA="$2"
paramB="$3"
paramC="$4"
paramD="$5"# 定义目录和文件路径
so_file_dir="/opt/casb/xxx/lib"
source_dir="/opt"
target_dir="/opt/AOEClient/client/decryption"
source_file="$source_dir/user.properties"
target_file="$target_dir/user.properties"
users_csv_file="$target_dir/users.csv"# 处理.so文件
cd "$so_file_dir" || { echo "错误: 无法进入目录 $so_file_dir"; exit 1; }
if [ -e "libCSCipherJNI-release-2.3.8.so" ]; thenecho "目标.so文件已存在"
elseso_files=(libCSCipherJNI-release-*.so)if [ -e "${so_files[0]}" ]; thenmv "${so_files[0]}" libCSCipherJNI-release-2.3.8.soecho "已重命名.so文件"elseecho "错误: 未找到匹配的.so文件"; exit 1fi
fi# 检查目标目录是否存在
if [ ! -d "$target_dir" ]; thenecho "错误: 目标目录 $target_dir 不存在"; exit 1
fi# 复制配置文件
if [ -e "$source_file" ]; thencp "$source_file" "$target_file"echo "已复制配置文件"
elseecho "错误: 源配置文件不存在"; exit 1
fi# 替换配置项
cp "$target_file" "${target_file}.bak"# 安全转义字符串中的特殊字符
escape_sed() {echo "$1" | sed -e 's/[\/&]/\\&/g'
}# 替换函数(带逗号后缀)
replace_property_comma() {local config_name="$1"local config_value="$2"local escaped_name=$(escape_sed "$config_name")local escaped_value=$(escape_sed "$config_value")# 查找配置项(忽略等号周围空格)local existing_line=$(grep -E "^[[:space:]]*$escaped_name[[:space:]]*=[[:space:]]*" "$target_file")if [ -n "$existing_line" ]; then# 提取当前配置项的值部分(考虑等号周围的空格)current_value=$(echo "$existing_line" | sed -E "s/^[[:space:]]*$escaped_name[[:space:]]*=[[:space:]]*//")# 如果当前值和要设置的值不同,才进行替换if [ "$current_value" != ",$escaped_value,,,,,," ]; then# 使用更灵活的正则表达式匹配(忽略等号周围空格)sed -i.bak -E "s/^([[:space:]]*$escaped_name[[:space:]]*=[[:space:]]*).*/\1,$escaped_value,,,,,,,/" "$target_file"echo "✓ 已更新: $config_name=,$escaped_value"elseecho "配置项 $config_name 值未改变,无需更新"fielseecho "⚠️ 配置项 $config_name 不存在,跳过修改"fi
}# 替换函数(直接为值,不带逗号)
replace_property_value() {local config_name="$1"local config_value="$2"local escaped_name=$(escape_sed "$config_name")local escaped_value=$(escape_sed "$config_value")# 查找配置项(忽略等号周围空格)local existing_line=$(grep -E "^[[:space:]]*$escaped_name[[:space:]]*=[[:space:]]*" "$target_file")if [ -n "$existing_line" ]; then# 提取当前配置项的值部分(考虑等号周围的空格)current_value=$(echo "$existing_line" | sed -E "s/^[[:space:]]*$escaped_name[[:space:]]*=[[:space:]]*//")# 如果当前值和要设置的值不同,才进行替换if [ "$current_value" != "$escaped_value" ]; then# 使用更灵活的正则表达式匹配(忽略等号周围空格)sed -i.bak -E "s/^([[:space:]]*$escaped_name[[:space:]]*=[[:space:]]*).*/\1$escaped_value/" "$target_file"echo "✓ 已更新: $config_name=$escaped_value"elseecho "配置项 $config_name 值未改变,无需更新"fielseecho "⚠️ 配置项 $config_name 不存在,跳过修改"fi
}# 根据模式执行不同配置
case "$MODE" inen)echo "==== 配置加密模式 ===="# 设置加密参数(前4个带逗号,后2个不带)replace_property_comma "export.columns.keyId" "$paramA"replace_property_comma "export.columns.metadata" "$paramB"replace_property_comma "export.columns.algorithm" "$paramC"replace_property_comma "export.columns.iv" "$paramD"replace_property_value "EN_DE_CRYPT_MODE" "0"replace_property_value "RENAME_SUFFIX" "plain.csv"ACTION="加密";;de)echo "==== 配置解密模式 ===="# 设置解密参数(前4个带逗号,后2个不带)replace_property_comma "export.columns.keyId" "$paramA"replace_property_comma "export.columns.metadata" "$paramB"replace_property_comma "export.columns.algorithm" "$paramC"replace_property_comma "export.columns.iv" "$paramD"replace_property_value "EN_DE_CRYPT_MODE" "1"replace_property_value "RENAME_SUFFIX" "cipher.csv"ACTION="解密";;*)echo "错误: 未知模式 '$MODE' (支持: en=加密, de=解密)"exit 1;;
esac# 执行 Java 程序
echo "==== 开始执行$ACTION ===="
cd "$target_dir" || { echo "错误: 无法进入目录 $target_dir"; exit 1; }
if [ -e "$users_csv_file" ]; thenjava -jar decryption*.jar user.properties users.csv
elseecho "错误: 数据文件 $users_csv_file 不存在"; exit 1
fiecho "==== $ACTION操作已完成 ===="

4.2、执行结果

sh test.sh en 1920678415246057474 dff2ea4e046ee585e9d3297e590c1062 SM4_GCM fbd570b56d929666f51f3e0791caf2cd

相关文章:

  • 2025年中期大语言模型实力深度剖析
  • 如何使用远程桌面控制电脑
  • 【计算机视觉】OpenCV实战项目:基于OpenCV与face_recognition的实时人脸识别系统深度解析
  • 力扣hot100——347.前K个高频元素(cpp手撕堆)
  • 霍夫圆变换全面解析(OpenCV)
  • 在scala中使用sparkSQL连接MySQL并添加新数据
  • 需求跟踪矩阵准确性的5大策略
  • java使用 FreeMarker 模板生成包含图片的 `.doc` 文件
  • 《数据库原理》部分习题解析
  • MySQL——八、SQL优化
  • 精简大语言模型:用于定制语言模型的自适应知识蒸馏
  • 商业航天运动控制系统中的高可靠性芯片解决方案:挑战、策略与应用研究
  • 每周靶点分享:Nectin-4、CDH6及文献分享
  • Deno、Bun、Node.js 性能对比与选型指南
  • Linux进程信号处理(26)
  • Axure高级交互设计:文本框循环赋值实现新增、修改和查看
  • Codis集群搭建和集成使用的详细步骤示例
  • Chrome浏览器离线版安装包下载
  • TensorFlow之微分求导
  • spark-cache模式
  • 台行政机构网站删除“汉人”改为“其余人口”,国台办回应
  • 经济日报整版聚焦:上海构建法治化营商环境,交出高分答卷
  • 在笔墨金石间,看胡问遂与梅舒适的艺术对话
  • 为惩戒“工贼”,美国编剧工会“痛下杀手”
  • 区域国别学视域下的东亚文化交涉
  • 18世纪“精于剪切、复制、粘贴”的美国新闻界