news 2026/6/17 21:47:00

Ubuntu 22.04 开发环境 CA 证书签发完整笔记(完整版)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Ubuntu 22.04 开发环境 CA 证书签发完整笔记(完整版)

Ubuntu 22.04 开发环境 CA 证书签发完整笔记

开发环境

  • 前端: Vue3+TS+Vite+ESM
  • 后端:NestJS
  • 数据库:MySQL+Redis
  • 虚拟机OS:Ubuntu 22.04 LTS

工作拓扑

开发环境参数(VS Code)

  • 版本: 1.106.3 (Universal)
  • Electron: 37.7.0
  • ElectronBuildId: 12781156
  • Chromium: 138.0.7204.251
  • Node.js: 22.20.0
  • V8: 13.8.258.32-electron.0
  • OS: Darwin arm64 24.6.0

目录介绍

  • CA核心目录:/opt/ca/root/(根CA私钥、证书、签发记录存放)

  • 服务端目录:/opt/ca/server/(服务端私钥、CSR、证书存放)

  • 客户端目录:/opt/ca/server/client/(客户端私钥、CSR、证书存放)

  • 目标:生成根CA证书、NestJS服务端证书、Vue3客户端p12证书,完成验证与本地下载


一、前置准备

1. 检查OpenSSL版本(需1.1.1及以上)

openssl version

解释:Ubuntu 22.04默认已装,无需额外安装;若未装,执行以下命令(离线环境需提前下载deb包):

sudo apt update && sudo apt install openssl -y

2. 创建标准化CA目录结构(权限先行)

创建完整目录并配置安全权限(私钥目录仅root可读,避免泄露):

# 根CA核心目录(私钥严格保护) mkdir -p /opt/ca/root/{private,certs,csr,newcerts} chmod 700 /opt/ca/root/private # 仅root可进入 chown -R root:root /opt/ca/root # 目录归属root # 服务端(NestJS)目录 mkdir -p /opt/ca/server/{private,certs,csr} chmod 700 /opt/ca/server/private chown -R root:root /opt/ca/server # 客户端(Vue3)目录 mkdir -p /opt/ca/server/client/{private,certs,csr} chmod 700 /opt/ca/server/client/private chown -R root:root /opt/ca/server/client # 初始化CA签发必需文件(记录签发信息) touch /opt/ca/root/index.txt # 证书签发索引日志 echo 1000 > /opt/ca/root/serial # 证书序列号起始值(避免重复)

验证:执行以下命令确认目录结构完整:

ls -l /opt/ca/root/

预期输出:包含private/、certs/、csr/、newcerts/、index.txt、serial


二、步骤1:生成根CA私钥与自签证书

1. 生成根CA私钥(AES256加密)

进入根CA目录,生成加密私钥:

# 进入根CA目录 cd /opt/ca/root/ # 生成2048位AES256加密私钥 openssl genrsa -aes256 -out private/ca-root.key.pem 2048 # 权限锁死:仅root可读 chmod 400 private/ca-root.key.pem

交互说明:提示“Enter pass phrase”时,输入根CA密码(如CaRoot@2025!),务必牢记

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/17 7:44:45

Llama-Factory是否支持模型剪枝?轻量化部署方案

Llama-Factory是否支持模型剪枝?轻量化部署方案 在大语言模型(LLM)快速演进的今天,越来越多的企业和开发者希望将强大的生成能力落地到实际业务中。然而,动辄数十GB显存需求、上百亿参数规模的模型让许多团队望而却步—…

作者头像 李华
网站建设 2026/6/13 9:49:21

56、Linux网络服务配置与安全指南

Linux网络服务配置与安全指南 1. 探索练习 在网络配置和管理中,我们常常会遇到各种实际问题,以下是一些探索性的练习,帮助我们更好地理解和应用网络知识。 1. 子网划分问题 :假设公司使用A类网络100.0.0.0/8,若要将此网络划分为11个子网以匹配11个部门,需要为网络上…

作者头像 李华
网站建设 2026/6/15 13:16:58

Redis 的内存回收机制详解

Redis 的内存回收机制详解 Redis 是基于内存的高性能数据库,但内存资源有限。当单节点内存过大时,不仅会增加成本,还可能影响 RDB/AOF 持久化 和 主从同步 的性能与稳定性。 为此,Redis 提供了完善的内存管理机制,主…

作者头像 李华
网站建设 2026/6/16 18:50:15

MCP协议中的OAuth2集成实战指南:从零构建安全认证体系

MCP协议中的OAuth2集成实战指南:从零构建安全认证体系 【免费下载链接】mcp-for-beginners This open-source curriculum is designed to teach the concepts and fundamentals of the Model Context Protocol (MCP), with practical examples in .NET, Java, and P…

作者头像 李华
网站建设 2026/6/16 1:11:23

基于微信小程序的垃圾分类信息系统毕业设计项目源码

基于微信小程序的垃圾分类信息系统,直击居民“分类标准记混、查询繁琐、投放不精准”与社区“宣传低效、数据难统计”的双重痛点,依托微信小程序“免安装、高触达、强传播”的优势,构建“智能查询知识科普互动激励”的一体化垃圾分类服务平台…

作者头像 李华
网站建设 2026/6/17 3:51:23

ChatTTS-ui Docker部署完全指南:GPU与CPU版本一键配置

ChatTTS-ui Docker部署完全指南:GPU与CPU版本一键配置 【免费下载链接】ChatTTS-ui 匹配ChatTTS的web界面和api接口 项目地址: https://gitcode.com/GitHub_Trending/ch/ChatTTS-ui 还在为AI语音合成项目ChatTTS-ui的复杂环境配置而头疼吗?CUDA版…

作者头像 李华