位置: 编程技术 - 正文

Linux下OpenSSL的DSA与RSA非对称加密解析(openssl/sha.h)

编辑:rootadmin

推荐整理分享Linux下OpenSSL的DSA与RSA非对称加密解析(openssl/sha.h),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:linux openssl使用,openssl dh,openssl -k,openssl sha,openssl dgst -sha1,openssl dh,openssl dsa,openssl dsa,内容如对您有帮助,希望把文章链接给更多的朋友!

在日常系统管理工作中,需要作一些加解密的工作,通过openssl工具包就能完成我们很多需求!1. openssl RSA 加解密RSA是基于数论中大素数的乘积难分解理论上的非对称加密法,使用公私钥的方法进行加解密公钥 用于加密,它是向所有人公开的 ; 私钥用于解密,只有密文的接收者持有生成一个密钥(私钥)复制代码代码如下: [root@hunterfu ~]# openssl genrsa -out private.key 注意: 需要注意的是这个文件包含了公钥和密钥两部分,也就是说这个文件即可用来加密也可以用来解密,后面的是生成密钥的长度.通过密钥文件private.key 提取公钥复制代码代码如下: [root@hunterfu ~]# openssl rsa -in private.key -pubout -out pub.key使用公钥加密信息复制代码代码如下: [root@hunterfu ~]# echo -n "" | openssl rsautl -encrypt -inkey pub.key -pubin >encode.result使用私钥解密信息复制代码代码如下: [root@hunterfu ~]#cat encode.result | openssl rsautl -decrypt -inkey private.key 至此,一次RSA加密解密的过程已经完成!

Linux下OpenSSL的DSA与RSA非对称加密解析(openssl/sha.h)

2. openssl DSA签名与验证和RSA加密解密过程相反,在DSA数字签名和认证中,发送者使用自己的私钥对文件或消息进行签名,接受者收到消息后使用发送者的公钥来验证签名的真实性DSA只是一种算法,和RSA不同之处在于它不能用作加密和解密,也不能进行密钥交换,只用于签名,它比RSA要快很多.生成一个密钥(私钥)复制代码代码如下: [root@hunterfu ~]# openssl dsaparam -out dsaparam.pem [root@hunterfu ~]# openssl gendsa -out privkey.pem dsaparam.pem生成公钥复制代码代码如下: [root@hunterfu ~]# openssl dsa -in privkey.pem -out pubkey.pem -pubout [root@hunterfu ~]# rm -fr dsaparam.pem使用私钥签名复制代码代码如下: [root@hunterfu ~]# echo -n "" | openssl dgst -dss1 -sign privkey.pem > sign.result使用公钥验证复制代码代码如下: [root@hunterfu ~]# echo -n "" | openssl dgst -dss1 -verify pubkey.pem -signature sign.result Verified OK至此,一次DSA签名与验证过程完成!

3. 总结及注意事项注意: 由于信息经过加密或者签名后,都变成不可读模式,为了方便终端查看和传输使用(url提交数据,需要作urlencode操作),可以使用base进行编码openssl enc -base -A :将加密后的信息使用base编码 openssl enc -d -base -A : 将信息使用base反编码java中此私钥需要转换下格式才能使用:复制代码代码如下: [root@hunterfu ~]# openssl pkcs8 -topk8 -nocrypt -in private.key -outform PEM -out java_private.key当然openssl 是一个很实用的加密工具包,还有很多东西值得学习和总结,以后有空再说!

通过Linux系统将Windows系统迁移到到新的磁盘上 1.概述这篇文章将告诉你如何再linux系统下,将安装好的windows版本复制到新的磁盘上(新的磁盘大于等于window镜像大小)2.使用到的工具livecd工具,可以

在Linux系统中批量删除多个文件的方法总结 当我们在linux系统中要删除数万或者数十万甚至数百万的文件时使用rm-rf*就不太好用,因为要等待很长一段时间。在这种情况之下我们可以使用linux系统

设置自动清理Linux系统中n天前的文件的方法 服务器每周会产生一次全局备份文件,大小约G左右,需要定期清理。工作时间网站访问大,服务器I/O高的时候删除大数据会对服务器状态产生不好的

标签: openssl/sha.h

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

上一篇:在USB磁盘上制作Linux的GRUB引导的方法(windows u盘制作)

下一篇:通过Linux系统将Windows系统迁移到到新的磁盘上(将哪一linux文件系统引入)

  • 应交税费转出未交增值税借贷方表示什么
  • 职工薪酬支出及纳税调整
  • 持有至到期投资核算内容
  • 简易征收预缴税款可以抵扣吗
  • 研发辅助账科目设置
  • 购入生产线属于固定资产吗
  • 经营范围没有的可以开票吗
  • 单一窗口报关单
  • 银行账户利息怎么记账
  • 加工企业怎么记账
  • 发票章没盖在盖章处
  • 分期收款开具发票可以吗
  • 私车公用产生的过路费开个人发票还是公司发票
  • 汽车公司场地租金怎么算
  • 以前年度亏损本季度盈利所得税申报
  • 个人股东从公司借款合法吗
  • 公司借给个人的款项会计分录
  • 购买商品成本要支付哪些成本
  • 委托加工费的增值税计入成本吗
  • 材料票可以直接在税务局开吗
  • 商品出口消费税计算方法
  • 研发支出费用如何计算应交所得税?
  • 公司年终分红如何入账
  • 费用计入资产
  • 会计事务所成本核算方法
  • 注册表修改系统安装日期
  • linux环境什么意思
  • php如何解决异常处理
  • 所得税到底按会计分录吗
  • 收到对方公司开出发票如何做账
  • mac os x v10.10
  • PHP:pg_connection_busy()的用法_PostgreSQL函数
  • 年终奖发放问题
  • phpwhile用法
  • php出栈函数
  • php如何实现
  • php连接mysql数据库步骤正确的是
  • 资产负债表各项目年初余额栏内各项数字
  • 滤波方案
  • 单位向职工出租房子
  • 爬虫技术是做什么的
  • 处置固定资产净收益属于利得吗
  • sqlserver导入导出数据库
  • 结转成本是什么凭证
  • 公司开发新产品的建议
  • mysql如何调优
  • 扫码开票怎么弄
  • 产品出口认证
  • 冲红发票如何做账务处理
  • 总资产利润率一般为多少
  • 可抵扣暂时性差异产生的情况有
  • 企业代办业务有哪些
  • 简易征收计算企业所得税怎么算
  • 劳务公司拿什么挣钱
  • 福利费取得的专票不能抵扣账怎么做
  • 在途物资和材料采购的区别
  • 建筑企业其他业务收入范围
  • sqlgun
  • apple watch手表怎么看型号
  • 重装系统要懂什么
  • linux www服务器配置
  • elccest.exe是间谍广告程序吗 elccest进程有什么作用
  • git打标签命令
  • 初始学历是什么意思
  • unity projector
  • jquery lt
  • angularjs2
  • boostrapping
  • linux中shell脚本实验总结
  • js动态执行代码
  • JavaScript中的this指向
  • javascript的基本规范
  • jQuery+ajax实现实用的点赞插件代码
  • android 动画特效
  • 个体工商户税务年报网上怎么申报
  • 深圳龙华街道办电话
  • 税控盘税务数字证书密码是什么
  • 发票开了,税务局上查不到信息是怎么回事
  • 微观经济学的十大原理
  • 无锡市社保局电话是多少
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设