Linux自建CA并颁发证书的shell脚本

2024-04-10 01:08

本文主要是介绍Linux自建CA并颁发证书的shell脚本,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

创建私有CA

  1. 创建CA所需要的文件
#生成证书索引数据库文件
touch /etc/pki/CA/index.txt
#指定第一个颁发证书的序列号
echo 01 > /etc/pki/CA/serial
  1. 生成CA私钥
cd /etc/pki/CA/
(umask 066; openssl genrsa -out private/cakey.pem 2048)
  1. 生成CA自签名证书
openssl req -new -x509 -key /etc/pki/CA/private/cakey.pem -days 3650 -out /etc/pki/CA/cacert.pem
  • 选项说明
-new:生成新证书签署请求
-x509:专用于CA生成自签证书
-key:生成请求时用到的私钥文件
-days n:证书的有效期限
-out /PATH/TO/SOMECERTFILE: 证书的保存路径
  1. 为特定APP项目或网站生成自签名证书
openssl req -utf8 -newkey rsa:1024 -subj "/CN=www.sunmy.pro" -keyout sunapp.key -nodes -x509 -out sunapp.crt
  1. 查看生成的证书内容
openssl x509 -in sunapp.crt -noout -text

申请证书并颁发证书

  1. 为需要使用证书的主机生成生成私钥
(umask 066; openssl genrsa -out /data/test.key 2048)
  1. 为需要使用证书的主机生成证书申请文件
openssl req -new -key /data/test.key -out /data/test.csr
  1. 在CA签署证书并将证书颁发给请求者
  • 要求 国家,省,公司名称三项必须和CA一致
openssl ca -in /data/test.csr -out /etc/pki/CA/certs/test.crt -days 100
  1. 查看证书中的信息:
openssl x509 -in /PATH/FROM/CERT_FILE -noout -text|issuer|subject|serial|dates
#查看指定编号SERIAL的证书状态
openssl ca -status SERIAL

吊销证书

  • 一个项目下线了,就可以将其证书进行吊销处理
  1. 在客户端获取要吊销的证书的编号serial
openssl x509 -in /PATH/FROM/CERT_FILE -noout -serial -subject
  1. 第一次更新证书吊销列表前,指定第一个吊销证书的编号,曾经做过无需再做
echo 01 > /etc/pki/CA/crlnumber
  1. 核验并执行吊销证书
  • 在CA上,根据客户提交的serial与subject信息,对比检验是否与index.txt文件中的信息一致
openssl ca -revoke /etc/pki/CA/newcerts/SERIAL.pem
  1. 更新证书吊销列表
openssl ca -gencrl -out /etc/pki/CA/crl.pem
  1. 查看crl文件
openssl crl -in /etc/pki/CA/crl.pem -noout -text

自动创建CA并为用户颁发证书的小shell脚本

  • 这个脚本并不完善,一次只能为一个用户创建证书,
  • 需要将创建证书的地方改成读取输入的值,然后灵活的为输入的域名创建证书才行啊!
#!/bin/bash
# 2021-09-09
SUBJ_CA="/C=CN/ST=BJ/L=BJ/O=SunMY/OU=Linux/CN=ca.sunmy.pro/emailAddress=root@sunmy.pro"
SUBJ_MA="/C=CN/ST=BJ/L=BJ/O=SunMY/OU=Linux/CN=www.sunmy.pro/emailAddress=master@sunmy.pro"DIR=/etc/pki/CAcreate_rootCA(){[ -d ${DIR} ] || mkdir -p $DIR/{certs,crl,private,newcerts} &> /dev/null[ -e ${DIR}/index.txt ] || touch $DIR/index.txt[ -e ${DIR}/serial ] || echo  01 > $DIR/serial[ -e ${DIR}/cacert.pem ] || openssl req  -x509 \-newkey rsa:2048 \-subj ${SUBJ_CA} \-keyout ${DIR}/private/cakey.pem \-nodes \-days 3650 \-out ${DIR}/cacert.pem
}create_CA(){openssl req -newkey rsa:2048 \-subj ${SUBJ_MA} \-nodes \-keyout master.key \-out master.csropenssl x509 -req -in master.csr \-CA ${DIR}/cacert.pem \-CAcreateserial \-CAkey ${DIR}/private/cakey.pem \-days 365 \-out master.crt
}caRevoke(){[ -e ${DIR}/crlnumber ] || echo 01 > ${DIR}/crlnumberopenssl ca -revoke ${DIR}/newcerts/$1openssl ca -grencrl -out ${DIR}/crl.pem
}PS3="请选择(1-4):"
MENU="
创建自签名CA证书
为用户签发证书
证书吊销
退出
"
select menu in $MENU;do
case $REPLY in
1)create_rootCA;;
2)create_CA;;
3)read -p "请输入要吊销的证书:" CERTcaRevoke $CERT;;
4)break;;
*)echo "输入错误,请重新输入!";;
esac
done

这篇关于Linux自建CA并颁发证书的shell脚本的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/889705

相关文章

Linux云服务器手动配置DNS的方法步骤

《Linux云服务器手动配置DNS的方法步骤》在Linux云服务器上手动配置DNS(域名系统)是确保服务器能够正常解析域名的重要步骤,以下是详细的配置方法,包括系统文件的修改和常见问题的解决方案,需要... 目录1. 为什么需要手动配置 DNS?2. 手动配置 DNS 的方法方法 1:修改 /etc/res

Linux创建服务使用systemctl管理详解

《Linux创建服务使用systemctl管理详解》文章指导在Linux中创建systemd服务,设置文件权限为所有者读写、其他只读,重新加载配置,启动服务并检查状态,确保服务正常运行,关键步骤包括权... 目录创建服务 /usr/lib/systemd/system/设置服务文件权限:所有者读写js,其他

Linux下利用select实现串口数据读取过程

《Linux下利用select实现串口数据读取过程》文章介绍Linux中使用select、poll或epoll实现串口数据读取,通过I/O多路复用机制在数据到达时触发读取,避免持续轮询,示例代码展示设... 目录示例代码(使用select实现)代码解释总结在 linux 系统里,我们可以借助 select、

Linux挂载linux/Windows共享目录实现方式

《Linux挂载linux/Windows共享目录实现方式》:本文主要介绍Linux挂载linux/Windows共享目录实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录文件共享协议linux环境作为服务端(NFS)在服务器端安装 NFS创建要共享的目录修改 NFS 配

linux系统中java的cacerts的优先级详解

《linux系统中java的cacerts的优先级详解》文章讲解了Java信任库(cacerts)的优先级与管理方式,指出JDK自带的cacerts默认优先级更高,系统级cacerts需手动同步或显式... 目录Java 默认使用哪个?如何检查当前使用的信任库?简要了解Java的信任库总结了解 Java 信

Python爬虫HTTPS使用requests,httpx,aiohttp实战中的证书异步等问题

《Python爬虫HTTPS使用requests,httpx,aiohttp实战中的证书异步等问题》在爬虫工程里,“HTTPS”是绕不开的话题,HTTPS为传输加密提供保护,同时也给爬虫带来证书校验、... 目录一、核心问题与优先级检查(先问三件事)二、基础示例:requests 与证书处理三、高并发选型:

Linux命令rm如何删除名字以“-”开头的文件

《Linux命令rm如何删除名字以“-”开头的文件》Linux中,命令的解析机制非常灵活,它会根据命令的开头字符来判断是否需要执行命令选项,对于文件操作命令(如rm、ls等),系统默认会将命令开头的某... 目录先搞懂:为啥“-”开头的文件删不掉?两种超简单的删除方法(小白也能学会)方法1:用“--”分隔命

Linux五种IO模型的使用解读

《Linux五种IO模型的使用解读》文章系统解析了Linux的五种IO模型(阻塞、非阻塞、IO复用、信号驱动、异步),重点区分同步与异步IO的本质差异,强调同步由用户发起,异步由内核触发,通过对比各模... 目录1.IO模型简介2.五种IO模型2.1 IO模型分析方法2.2 阻塞IO2.3 非阻塞IO2.4

Linux中查看操作系统及其版本信息的多种方法

《Linux中查看操作系统及其版本信息的多种方法》在服务器运维或者部署系统中,经常需要确认服务器的系统版本、cpu信息等,在Linux系统中,有多种方法可以查看操作系统及其版本信息,以下是一些常用的方... 目录1. lsb_pythonrelease 命令2. /etc/os-release 文件3. h

linux部署NFS和autofs自动挂载实现过程

《linux部署NFS和autofs自动挂载实现过程》文章介绍了NFS(网络文件系统)和Autofs的原理与配置,NFS通过RPC实现跨系统文件共享,需配置/etc/exports和nfs.conf,... 目录(一)NFS1. 什么是NFS2.NFS守护进程3.RPC服务4. 原理5. 部署5.1安装NF