0

0

linux加密/解密工具是什么-openssl 命令使用与实例

P粉390130307

P粉390130307

发布时间:2025-08-04 09:02:12

|

813人浏览过

|

来源于php中文网

原创

linux加密/解密工具是什么-openssl 命令使用与实例

Linux openssl 命令


OpenSSL 是一款功能强大的开源加密套件,集成了多种加密算法、证书管理模块以及 SSL/TLS 协议的实现。作为 Linux 系统中处理加密操作的标准工具,它被广泛应用于各类安全任务中。

OpenSSL 的核心功能涵盖:

  • SSL 证书创建和维护
  • 文件加解密操作
  • 密钥对生成
  • SSL 连接测试
  • 哈希值计算
  • 数字签名校验

基本语法

openssl 命令的通用格式如下:

openssl command [command_options] [command_args]

说明:

  • command
    :指定要运行的 OpenSSL 子命令(例如 genrsa、req、x509 等)
  • command_options
    :子命令的选项参数
  • command_args
    :子命令所需的输入参数

常用子命令及示例

1. 生成 RSA 密钥对

生成 2048 位长度的 RSA 私钥文件:

openssl genrsa -out private.key 2048

从私钥中导出对应的公钥:

openssl rsa -in private.key -pubout -out public.key

关键参数解释:

  • -out
    :设置输出文件路径
  • 2048
    :表示密钥位数
  • -pubout
    :启用公钥输出模式

2. 创建自签名证书

生成 CSR 请求文件:

openssl req -new -key private.key -out cert.csr

创建有效期为一年的自签名证书:

openssl req -x509 -new -key private.key -days 365 -out cert.crt

主要参数含义:

  • -new
    :新建请求
  • -key
    :关联私钥文件
  • -days
    :设定证书有效天数
  • -x509
    :生成 X.509 格式证书

3. 文件加解密操作

AES-256-CBC 模式加密文件:

openssl enc -aes-256-cbc -salt -in plaintext.txt -out encrypted.enc

使用相同密钥进行解密:

GentleAI
GentleAI

GentleAI是一个高效的AI工作平台,为普通人提供智能计算、简单易用的界面和专业技术支持。让人工智能服务每一个人。

下载
openssl enc -d -aes-256-cbc -in encrypted.enc -out decrypted.txt

参数解析:

  • -aes-256-cbc
    :采用 AES-256-CBC 加密方式
  • -salt
    :加入随机盐值增强安全性
  • -in
    :源文件路径
  • -out
    :目标文件路径
  • -d
    :启动解密流程

4. 计算文件哈希摘要

SHA-256 哈希计算:

openssl dgst -sha256 filename.txt

MD5 哈希计算:

openssl dgst -md5 filename.txt

5. 测试 SSL 安全连接

查看远程服务器 SSL 证书详情:

openssl s_client -connect example.com:443 -showcerts

参数说明:

  • -connect
    :定义目标主机地址和端口
  • -showcerts
    :显示完整的证书链信息

高级用法

1. 创建 PKCS#12 格式证书包

将证书和私钥打包成 P12 文件:

openssl pkcs12 -export -in cert.crt -inkey private.key -out cert.p12

2. 查看证书内容

展示证书详细信息:

openssl x509 -in cert.crt -text -noout

3. 验证证书链有效性

执行证书链验证:

openssl verify -CAfile ca.crt cert.crt

安全建议

  1. 密钥防护:私钥文件应配置严格权限(如 600),防止未授权访问
  2. 算法选择:避免使用已被淘汰的 MD5 或 SHA1 算法
  3. 密码强度:加密操作时务必使用高强度密码
  4. 证书更新:及时替换过期的证书
  5. 熵值保障:确保系统具备足够的随机性用于加密运算

常见问题解答

Q1: 如何查询当前 OpenSSL 版本?

openssl version

Q2: 如何创建更安全的 ECC 类型密钥?

openssl ecparam -genkey -name secp384r1 -out ecc.key

Q3: 如何在不同证书格式间转换?

PEM 转 DER 格式示例:

openssl x509 -in cert.pem -outform der -out cert.der

实践练习

  1. 创建一个 4096 位的 RSA 密钥对
  2. 制作有效期为两年的自签名证书
  3. 对文本文件执行加密并用相同密钥完成解密
  4. 检查你经常访问网站的 SSL 证书详情

熟练掌握 openssl 命令能够帮助你高效完成各类加密和安全相关操作,为系统安全运维提供有力支持。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
页面置换算法
页面置换算法

页面置换算法是操作系统中用来决定在内存中哪些页面应该被换出以便为新的页面提供空间的算法。本专题为大家提供页面置换算法的相关文章,大家可以免费体验。

500

2023.08.14

SSL检测工具介绍
SSL检测工具介绍

SSL检测工具有SSL Labs、SSL Check、SSL Server Test、SSLMate、SSL/TLS Analyzer等。详细介绍:1、SSL Labs是一个由Qualys提供的在线SSL检测工具,可以评估服务器证书的部署情况、加密套件、协议支持等方面的安全性,它提供了一个详细的报告,包括证书的颁发者、有效期、安全性配置等;2、SSL Check等等。

355

2023.10.20

磁盘配额是什么
磁盘配额是什么

磁盘配额是计算机中指定磁盘的储存限制,就是管理员可以为用户所能使用的磁盘空间进行配额限制,每一用户只能使用最大配额范围内的磁盘空间。php中文网为大家提供各种磁盘配额相关的内容,教程,供大家免费下载安装。

1564

2023.06.21

如何安装LINUX
如何安装LINUX

本站专题提供如何安装LINUX的相关教程文章,还有相关的下载、课程,大家可以免费体验。

716

2023.06.29

linux find
linux find

find是linux命令,它将档案系统内符合 expression 的档案列出来。可以指要档案的名称、类别、时间、大小、权限等不同资讯的组合,只有完全相符的才会被列出来。find根据下列规则判断 path 和 expression,在命令列上第一个 - ( ) , ! 之前的部分为 path,之后的是 expression。还有指DOS 命令 find,Excel 函数 find等。本站专题提供linux find相关教程文章,还有相关

300

2023.06.30

linux修改文件名
linux修改文件名

本专题为大家提供linux修改文件名相关的文章,这些文章可以帮助用户快速轻松地完成文件名的修改工作,大家可以免费体验。

801

2023.07.05

linux系统安装教程
linux系统安装教程

linux系统是一种可以免费使用,自由传播,多用户、多任务、多线程、多CPU的操作系统。本专题提供linux系统安装教程相关的文章,大家可以免费体验。

588

2023.07.06

linux查看文件夹大小
linux查看文件夹大小

Linux是一种自由和开放源码的类Unix操作系统,存在着许多不同的Linux版本,但它们都使用了Linux内核。Linux可安装在各种计算机硬件设备中,比如手机、平板电脑、路由器、视频游戏控制台、台式计算机、大型机和超级计算机。linux怎么查看文件夹大小呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

570

2023.07.20

TypeScript类型系统进阶与大型前端项目实践
TypeScript类型系统进阶与大型前端项目实践

本专题围绕 TypeScript 在大型前端项目中的应用展开,深入讲解类型系统设计与工程化开发方法。内容包括泛型与高级类型、类型推断机制、声明文件编写、模块化结构设计以及代码规范管理。通过真实项目案例分析,帮助开发者构建类型安全、结构清晰、易维护的前端工程体系,提高团队协作效率与代码质量。

26

2026.03.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 10.6万人学习

Git 教程
Git 教程

共21课时 | 4.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号