在Ubuntu上,OpenSSL是一个强大的加密工具包,提供了许多命令行工具来执行各种加密任务。以下是一些常用的OpenSSL命令:
1. 生成密钥对openssl genrsa -out private.key 2048
:生成一个2048位的RSA私钥。openssl rsa -in private.key -pubout -out public.pem
:从私钥生成公钥。2. 创建证书签名请求(CSR)openssl req -new -key private.key -out request.csr
:创建一个新的CSR。3. 生成自签名证书openssl req -x509 -new -nodes -key private.key -sha256 -days 365 -out certificate.crt
:生成一个有效期为365天的自签名证书。4. 查看证书信息openssl x509 -in certificate.crt -text -noout
:显示证书的详细信息。5. 加密和解密文件openssl enc -aes-256-cbc -salt -in plaintext.txt -out encrypted.txt
:使用AES-256-CBC算法加密文件。openssl enc -d -aes-256-cbc -in encrypted.txt -out decrypted.txt
:解密文件。6. 生成和验证数字签名openssl dgst -sha256 -sign private.key -out signature.bin plaintext.txt
:使用私钥对文件进行签名。openssl dgst -sha256 -verify public.pem -signature signature.bin plaintext.txt
:验证文件的签名。7. 生成随机数据openssl rand -base64 32
:生成32字节的随机数据并编码为base64。8. 管理证书链openssl verify -CAfile ca.crt certificate.crt
:验证证书是否由指定的CA签发。9. 转换证书格式openssl x509 -in certificate.crt -outform DER -out certificate.der
:将PEM格式的证书转换为DER格式。10. 管理私钥openssl rsa -in private.key -check
:检查私钥的有效性。openssl rsa -in private.key -passin pass:yourpassword -out new_private.key
:使用密码保护私钥。11. SSL/TLS测试openssl s_client -connect example.com:443
:连接到指定服务器并显示SSL/TLS握手信息。openssl s_server -www -accept 443 -cert certificate.crt -key private.key
:启动一个简单的SSL/TLS服务器。12. 生成和验证消息摘要openssl dgst -sha256 plaintext.txt
:生成文件的SHA-256摘要。openssl dgst -sha256 -verify hash.txt -signature signature.bin plaintext.txt
:验证文件的摘要是否匹配。这些命令只是OpenSSL功能的一部分,具体使用时可以根据需求进行调整和组合。在使用这些命令时,请确保了解每个选项的含义和潜在的安全风险。