位置: 编程技术 - 正文

Linux 中的 Openssl命令及实例代码(Linux 中的time函数)

编辑:rootadmin

推荐整理分享Linux 中的 Openssl命令及实例代码(Linux 中的time函数),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:Linux 中的time函数,Linux 中的进程标识符(PID)是什么?,Linux 中的信号处理操作,Linux 中的time函数,Linux 中的 lo:0,Linux 中的 lo:0,Linux 中的各项 CPU 利用率是这样算出来的,Linux 中的查看日志命令,内容如对您有帮助,希望把文章链接给更多的朋友!

openssl命令的格式是"openssl command command-options args",command部分有很多种命令,这些命令需要依赖于openssl命令才能执行,所以称为伪命令(pseudo-command),每个伪命令都有各自的功能,大部分command都可以直接man command查看命令的用法和功能。

OpenSSL是一个强大的安全套接字层密码库,囊括主要的密码算法、常用的密钥和证书封装管理功能及SSL协议,并提供丰富的应用程序供测试或其它目的使用。在OpenSSL被曝出现严重安全漏洞后,发现多数通过SSL协议加密的网站使用名为OpenSSL的开源软件包。由于这是互联网应用最广泛的安全传输方法,被网银、在线支付、电商网站、门户网站、电子邮件等重要网站广泛使用,所以该漏洞影响范围广大。

OpenSSL有两种运行模式:交互模式和批处理模式。

直接输入openssl回车进入交互模式,输入带命令选项的openssl进入批处理模式。

OpenSSL整个软件包大概可以分成三个主要的功能部分:密码算法库、SSL协议库以及应用程序。OpenSSL的目录结构自然也是围绕这三个功能部分进行规划的。

对称加密算法

OpenSSL一共提供了8种对称加密算法,其中7种是分组加密算法,仅有的一种流加密算法是RC4。这7种分组加密算法分别是AES、DES、Blowfish、CAST、IDEA、RC2、RC5,都支持电子密码本模式(ECB)、加密分组链接模式(CBC)、加密反馈模式(CFB)和输出反馈模式(OFB)四种常用的分组密码加密模式。其中,AES使用的加密反馈模式(CFB)和输出反馈模式(OFB)分组长度是位,其它算法使用的则是位。事实上,DES算法里面不仅仅是常用的DES算法,还支持三个密钥和两个密钥3DES算法。

非对称加密算法

OpenSSL一共实现了4种非对称加密算法,包括DH算法、RSA算法、DSA算法和椭圆曲线算法(EC)。DH算法一般用户密钥交换。RSA算法既可以用于密钥交换,也可以用于数字签名,当然,如果你能够忍受其缓慢的速度,那么也可以用于数据加密。DSA算法则一般只用于数字签名。

信息摘要算法

OpenSSL实现了5种信息摘要算法,分别是MD2、MD5、MDC2、SHA(SHA1)和RIPEMD。SHA算法事实上包括了SHA和SHA1两种信息摘要算法,此外,OpenSSL还实现了DSS标准中规定的两种信息摘要算法DSS和DSS1。

密钥和证书管理

密钥和证书管理是PKI的一个重要组成部分,OpenSSL为之提供了丰富的功能,支持多种标准。

首先,OpenSSL实现了ASN.1的证书和密钥相关标准,提供了对证书、公钥、私钥、证书请求以及CRL等数据对象的DER、PEM和BASE的编解码功能。OpenSSL提供了产生各种公开密钥对和对称密钥的方法、函数和应用程序,同时提供了对公钥和私钥的DER编解码功能。并实现了私钥的PKCS#和PKCS#8的编解码功能。OpenSSL在标准中提供了对私钥的加密保护功能,使得密钥可以安全地进行存储和分发。

在此基础上,OpenSSL实现了对证书的X.标准编解码、PKCS#格式的编解码以及PKCS#7的编解码功能。并提供了一种文本数据库,支持证书的管理功能,包括证书密钥产生、请求产生、证书签发、吊销和验证等功能。

事实上,OpenSSL提供的CA应用程序就是一个小型的证书管理中心(CA),实现了证书签发的整个流程和证书管理的大部分机制。

实例

1、消息摘要算法应用例子

用SHA1算法计算文件file.txt的哈西值,输出到stdout:

用SHA1算法计算文件file.txt的哈西值,输出到文件digest.txt:

用DSS1(SHA1)算法为文件file.txt签名,输出到文件dsasign.bin。签名的private key必须为DSA算法产生的,保存在文件dsakey.pem中。

用dss1算法验证file.txt的数字签名dsasign.bin,验证的private key为DSA算法产生的文件dsakey.pem。

用sha1算法为文件file.txt签名,输出到文件rsasign.bin,签名的private key为RSA算法产生的文件rsaprivate.pem。

# 用sha1算法验证file.txt的数字签名rsasign.bin,验证的public key为RSA算法生成的rsapublic.pem。

2、对称加密应用例子

Linux 中的 Openssl命令及实例代码(Linux 中的time函数)

对称加密应用例子,用DES3算法的CBC模式加密文件plaintext.doc,加密结果输出到文件ciphertext.bin。

用DES3算法的OFB模式解密文件ciphertext.bin,提供的口令为trousers,输出到文件plaintext.doc。注意:因为模式不同,该命令不能对以上的文件进行解密。

用Blowfish的CFB模式加密plaintext.doc,口令从环境变量PASSWORD中取,输出到文件ciphertext.bin。

给文件ciphertext.bin用base编码,输出到文件base.txt。

用RC5算法的CBC模式加密文件plaintext.doc,输出到文件ciphertext.bin,salt、key和初始化向量(iv)在命令行指定。

3、Diffie-Hellman应用例子

使用生成因子2和随机的-bit的素数产生D0ffie-Hellman参数,输出保存到文件dhparam.pem

从dhparam.pem中读取Diffie-Hell参数,以C代码的形式,输出到stdout。

4、DSA应用例子应用例子

生成位DSA参数集,并输出到文件dsaparam.pem。

使用参数文件dsaparam.pem生成DSA私钥匙,采用3DES加密后输出到文件dsaprivatekey.pem

使用私钥匙dsaprivatekey.pem生成公钥匙,输出到dsapublickey.pem

从dsaprivatekey.pem中读取私钥匙,解密并输入新口令进行加密,然后写回文件dsaprivatekey.pem

5、RSA应用例子

产生位RSA私匙,用3DES加密它,口令为trousers,输出到文件rsaprivatekey.pem

从文件rsaprivatekey.pem读取私匙,用口令trousers解密,生成的公钥匙输出到文件rsapublickey.pem

用公钥匙rsapublickey.pem加密文件plain.txt,输出到文件cipher.txt

使用私钥匙rsaprivatekey.pem解密密文cipher.txt,输出到文件plain.txt

用私钥匙rsaprivatekey.pem给文件plain.txt签名,输出到文件signature.bin

用公钥匙rsapublickey.pem验证签名signature.bin,输出到文件plain.txt

从X.证书文件cert.pem中获取公钥匙,用3DES加密mail.txt,输出到文件mail.enc

从X.证书文件cert.pem中获取接收人的公钥匙,用私钥匙key.pem解密S/MIME消息mail.enc,结果输出到文件mail.txt

cert.pem为X.证书文件,用私匙key,pem为mail.txt签名,证书被包含在S/MIME消息中,输出到文件mail.sgn

验证S/MIME消息mail.sgn,输出到文件mail.txt,签名者的证书应该作为S/MIME消息的一部分包含在mail.sgn中

总结

以上所述是小编给大家介绍的Linux 中的 Openssl命令及实例代码,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对积木网网站的支持!

Linux 中的Logwatch命令 logwatch命令是一个可定制和可插入式的日志监视系统,它通过遍历给定时间范围内的系统日志文件而产生日志报告。logwatch默认每天执行一次,可以从/etc

Linux 中的 Install命令 install命令的作用是安装或升级软件或备份数据,它的使用权限是所有用户。install命令和cp命令类似,都可以将文件/目录拷贝到指定的地点。但是,instal

Linux 中的Setfacl命令 setfacl命令是用来在命令行里设置ACL(访问控制列表)。在命令行里,一系列的命令跟随以一系列的文件名。选项-b,--remove-all:删除所有扩展的acl规则,

标签: Linux 中的time函数

本文链接地址:https://www.jiuchutong.com/biancheng/379742.html 转载请保留说明!

上一篇:Linux中的Syslog命令(linux的syslog配置)

下一篇:Linux 中的Logwatch命令(Linux 中的 lo:0)

  • 购买债券的利息会计分录
  • 一般纳税人转成小规模的条件
  • 流动性比例高好还是低好
  • 房产税城镇土地使用税减免政策
  • 外购货物用于捐赠的会计分录
  • 抵扣认证发票时间
  • 增值税纳税义务发生时间
  • 有限合伙企业如何分红
  • 收回赔款会计分录
  • 老板买增票财务怎么做账
  • 增值税申报税额填错了怎么进行填
  • 代账公司收取服务费能开增值税票吗?
  • 公司购买环保材料会计分录
  • 非营利性组织有
  • 购买固定资产货款未付
  • 个人如何申报初级医师职称
  • 年薪制12个月的计算公式
  • 收到退回去年增值税怎么做账
  • 费用销售收入占比怎么算
  • 或有事项确认预计负债的分录
  • linux的sed命令
  • 最新的会计规定出台时间
  • 计提税金怎么提
  • win7为什么这么多人用
  • win11系统摄像头黑屏
  • 如何将win11任务栏变小一点
  • win7纯净版系统安装教程
  • php数组有哪几种类型
  • yii2框架运行原理
  • 一般纳税人的进项普票怎么做账
  • 固定资产加速一次性扣除
  • 前后端分离与不分离
  • vericut9.0环境变量
  • vue uncaught typeerror
  • 小规模纳税人开普票要交税吗
  • 慈善组织接受股票捐赠流程
  • 销售成本销售收入的关系
  • 固定资产账面净值和账面价值的区别
  • 二手车减免增值税的规定
  • 个人借款利息收入缴纳个税吗
  • Python psd-tools如何转换文件
  • 劳务分包的三种形式
  • 企业保持存货的必要性
  • mysql存long
  • 金税盘电子发票下载失败
  • 原材料报废收入账务处理
  • 车辆购置税滞纳金上限
  • 超市出租摊位交什么税
  • 会计原始分录包括什么
  • 未交增值税的核算方法
  • 打印银行电子流水发到别人邮箱,能看到我的账户余额吗
  • 投资收益期末余额在借方还是贷方
  • MySQL数据库远程登录
  • centos7.6无法远程
  • win8改win7怎么改
  • windows微软官方
  • xp的兼容模式
  • ubuntu无法解压tar.gz
  • Windows系统通过注册表实现打开CMD并定位到指定文件夹
  • 000.exe病毒
  • 进程管理器命令
  • 控制面板声音设置
  • SFC无需光盘出马,硬盘搞定
  • centos搭建服务器
  • Win7安装VPN软件后无法上网是什么原因如何解决
  • Linux利用sftp命令传输文件(极少数人知道的方法)
  • win10如何打开hlp文件
  • win7空间不足c盘
  • 判断输入的日期是一年中第几天
  • js中使用组件
  • egret引擎基础入门
  • JSONLINT:python的json数据验证库实例解析
  • js跨域访问页面控件
  • 发票在税务系统查不到对方要怎么做
  • 如何查询纳税信用级别
  • 没有交税,个人税可以低房子利息嘛
  • 基层税务局长工作职责
  • 定额发票增值税怎么申报
  • 常州车辆过户手续办理
  • 安徽省滁州市税务局地址
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设