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

Linux Bash脚本自动创建keystore和生成公钥

目录

  • 一. 需求
  • 二. 脚本实现
  • 三. 脚本重点语法解析


一. 需求

⏹现场有一个项目中使用了keystore证明书,现要求每年都需要生成一个新的keystore文件,并且根据keystore文件中的私钥生成公钥,然后将公钥提供给其他项目使用。

  • 生成keystore文件的命令很长,手动通过命令行输入不仅繁琐,而且很容易出错,因此要求写一个脚本实现
  • 要求使用Bash脚本书写,书写完毕之后,如果在windows上安装了Git for Bash的话,还可以在直接在windows上执行。

二. 脚本实现

#!/usr/bin/env bash# 判断keytool命令是否被安装
if ! command -v keytool >/dev/null 2>&1; thenecho "【keytool】命令并没有被安装, 请确认!"exit 1
fi# 判断openssl命令是否被安装
if ! command -v openssl >/dev/null 2>&1; thenecho "【openssl】命令并没有被安装, 请确认!"exit 1
fi# 获取当前脚本的绝对路径
SCRIPT_PATH="$(readlink -f "${BASH_SOURCE[0]}")"
# 根据脚本的绝对路径获取脚本所在目录的绝对路径
SCRIPT_DIR="$(dirname "$SCRIPT_PATH")"# 私钥别名
ALIAS='alias'
# 密码
PASSWD='nosecret'
# 不带后缀的文件名
FILE_NAME='test_mpl_ws_api'
# pem公钥所对应的key名称
PEM_PUBLIC_KEY='PEM_PUBLIC_KEY_PATH'
# 组织信息
DNAME_INFO='CN=KDDI, OU=IT, O=MyCompany, L=Tokyo, ST=Tokyo, C=JP'# 创建一个关联数组, 关联数组中的key和value都可以使用变量
declare -A filePathMap=(# keystore文件的绝对路径[KEYSTORE_FILE_PATH]="$SCRIPT_DIR/${FILE_NAME}.keystore"# cer公钥文件的所在路径[CER_PUBLIC_KEY_PATH]="$SCRIPT_DIR/${FILE_NAME}.cer"# pem公钥文件的所在路径["$PEM_PUBLIC_KEY"]="$SCRIPT_DIR/${FILE_NAME}.pem"
)# 进入当前脚本所在的目录
pushd "$SCRIPT_DIR" >/dev/null || exit 1# 生成一个keystore文件
keytool -genkeypair \
-alias "$ALIAS" \
-keyalg RSA \
-sigalg SHA384withRSA \
-keysize 2048 \
-validity 365 \
-keystore "${filePathMap['KEYSTORE_FILE_PATH']}" \
-dname "$DNAME_INFO" \
-storepass "$PASSWD" \
-keypass "$PASSWD"# 根据keystore文件中的私钥生成cer格式的公钥
keytool -exportcert \
-alias "$ALIAS" \
-keystore "${filePathMap['KEYSTORE_FILE_PATH']}" \
-storepass "$PASSWD" \
-file "${filePathMap['CER_PUBLIC_KEY_PATH']}"# 通过openssl命令将der格式的公钥转换为pem格式的公钥
openssl x509 \
-inform der \
-in "${filePathMap['CER_PUBLIC_KEY_PATH']}" \
-outform pem \
-out "${filePathMap["$PEM_PUBLIC_KEY"]}"# 定义一个删除文件的函数
function cleanup_files() {local -n pathMap=$1# 遍历引入的mapfor pathKey in "${!pathMap[@]}"; do# local的局部变量只能在函数内部使用local file_path="${pathMap[$pathKey]}"# 如果文件存在的话, 就删除[[ -f "$file_path" ]] && rm -- "$file_path"done
}# 删除生成的文件
sleep 5
# 调用自定义的函数, 传入关联数组, 删除文件
cleanup_files filePathMap# 返回到原目录
popd >/dev/nullread -p "→ 脚本执行结束, 按任意键结束 . . . " -n1 -s

三. 脚本重点语法解析

⏹获取当前脚本绝对路径和脚本所在的文件夹

# 获取当前脚本的绝对路径
SCRIPT_PATH="$(readlink -f "${BASH_SOURCE[0]}")"
# 根据脚本的绝对路径获取脚本所在目录的绝对路径
SCRIPT_DIR="$(dirname "$SCRIPT_PATH")"

⏹Bash中虽然没有Map,但是Bash中的关联数组的特性和map类似

declare -A filePathMap=(# keystore文件的绝对路径[KEYSTORE_FILE_PATH]="$SCRIPT_DIR/${FILE_NAME}.keystore"# cer公钥文件的所在路径[CER_PUBLIC_KEY_PATH]="$SCRIPT_DIR/${FILE_NAME}.cer"# pem公钥文件的所在路径["$PEM_PUBLIC_KEY"]="$SCRIPT_DIR/${FILE_NAME}.pem"
)

⏹调用函数,传递关联数组

  • Bash 没法直接传关联数组,但你可以把数组名传进去,用 declare -n(Bash 4.3+)引用,Bash 4.3之前的旧版本的Bash并不支持。
  • -n 表示 nameref 引用。函数内部用 local -n pathMap=$1,引用只是局部的别名,原数组本身在外部仍然存在,不会意外覆盖或污染全局变量。
  • 函数结束后,局部变量的pathMap作用域消失,不影响其他变量。
function cleanup_files() {local -n pathMap=$1# 遍历引入的mapfor pathKey in "${!pathMap[@]}"; do# local的局部变量只能在函数内部使用local file_path="${pathMap[$pathKey]}"# 如果文件存在的话, 就删除[[ -f "$file_path" ]] && rm -- "$file_path"done
}# 调用自定义的函数, 传入关联数组, 删除文件
cleanup_files filePathMap
http://www.dtcms.com/a/389247.html

相关文章:

  • 数据库管理员偏爱哪些MySQL数据库连接工具?
  • 大数据毕业设计选题推荐-基于大数据的农产品交易数据分析与可视化系统-Spark-Hadoop-Bigdata
  • MySQL C API 的“连接孵化器”-`mysql_init()`
  • oracle 数据库导入dmp文件
  • 第二部分:VTK核心类详解(第28章 vtkMatrix4x4矩阵类)
  • JDK、JRE、JVM 是什么?有什么关系?【Java】
  • Visual Studio 2022创建CPP项目
  • Nginx反向代理+负载均衡
  • React Suspense底层原理揭秘
  • 关于pycharm高版本导入torch的问题
  • 【硬件研讨】【笔记本电脑】给老ThinkPad升级内存
  • 论文Review 3DGS SuGaR | CVPR 2024 | 3DGS 转 Mesh 开源方案!!
  • Makefile学习(一)- 基础规则
  • 动态代理 设计模式
  • APP小程序被攻击了该如何应对
  • 零基础从头教学Linux(Day 37)
  • ADB 在嵌入式 Linux 系统调试中的应用
  • 7HTMLCSS高级
  • 玩游戏/用设计软件提示d3dcompiler_47.dll缺失怎么修复?5步快速定位问题,高效修复不踩坑
  • HTML应用指南:利用GET请求获取全国宝马授权经销商门店位置信息
  • 《Java网络编程》第一章:基本网络概念
  • Python内存机制全解析:从基础到高级应用
  • Ubuntu24修改ssh端口
  • hadoop实现一个序列化案例
  • DBG数据库加密网关实现mySQL敏感数据动态脱敏与加密全攻略
  • 解决 Vue SPA 刷新导致 404 的问题
  • 大型语言模型 (LLMs) 的演进历程:从架构革命到智能涌现
  • 大语言模型为什么要叫【模型】
  • 教程上新丨ACL机器翻译大赛30个语种摘冠,腾讯Hunyuan-MT-7B支持33种语言翻译
  • 《C++程序设计》笔记