当前位置: 首页 > news >正文

湖南做网站 要上磐石网络苏州做网站哪家比较好

湖南做网站 要上磐石网络,苏州做网站哪家比较好,提升学历有什么好处,要给公司做一个网站怎么做的吗文章目录 openssl3.2 - exp - 用openssl命令行来模拟ECC加解密的全流程概述笔记实验环境实验备注END openssl3.2 - exp - 用openssl命令行来模拟ECC加解密的全流程 概述 工程中要用到ECC加解密, 先去查了资料. 在网上能查到一些大佬们写的ECC加解密实现(基于openssl API), 不…

文章目录

    • openssl3.2 - exp - 用openssl命令行来模拟ECC加解密的全流程
    • 概述
    • 笔记
    • 实验环境
    • 实验
    • 备注
    • END

openssl3.2 - exp - 用openssl命令行来模拟ECC加解密的全流程

概述

工程中要用到ECC加解密, 先去查了资料.
在网上能查到一些大佬们写的ECC加解密实现(基于openssl API), 不过写的都比较早. 仅仅作为参考.

openssl API并不向下兼容, 只要换了openssl版本, 大概率程序得改(改多该少的问题).
从网上找到的第三方代码, 大概率不能用(API的名字都不同). 而且网上能查到的实现, 都不说自己用的openssl具体版本.
如果要找到和自己openssl版本一致, 拿来就能用的代码, 只能看自己版本的openssl实现(包括apps/demo/openssl内部实现中调用的openssl API)

我是准备从openssl实现中移植(抄代码), 这个方法靠谱, 只要能找到代码, 都是官方原装实现(权威用法).
先用openssl命令行模拟了一次.
后续准备将openssl命令行实现单步调试一下, 将openssl API调用代码迁移到自己工程.

笔记

实验环境

win10x64最新版 + openssl3.2

实验

打开自己做的的openssl命令批处理(PATH变量包含了openssl/bin路径, 可以直接运行openssl命令)

进入实验目录

cd /d D:\my_dev\my_local_git_prj\study\openSSL\exp\exp019_ecc_enc_dec

建立2个用户

mkdir .\sender && mkdir .\receiver

sender/receiver两端必须采用相同的椭圆曲线, 否则ECC共享密钥推导不出来

切换到sender

cd .\sender

产生ecc私钥_sender

openssl ecparam -name sect571r1 -genkey -noout -out priv_key_s.pem

导出ecc公钥_sender 给receiver

openssl ec -in priv_key_s.pem -pubout -out ..\receiver\pub_key_s.pem

切换到receiver

cd ..\receiver

产生ecc私钥_receiver

openssl ecparam -name sect571r1 -genkey -noout -out priv_key_r.pem

导出ecc公钥_receiver 给sender

openssl ec -in priv_key_r.pem -pubout -out ..\sender\pub_key_r.pem

双方各自在自己的一边(物理隔离)单独推导出共享密钥

sender单独推导出共享密钥

cd ..\senderopenssl pkeyutl -derive -inkey priv_key_s.pem -peerkey pub_key_r.pem -out shared_key_s.sk

receiver单独推导出共享密钥

cd ..\receiver
openssl pkeyutl -derive -inkey priv_key_r.pem -peerkey pub_key_s.pem -out shared_key_r.sk

确认双方共享密钥是一把

fc /B .\shared_key_r.sk ..\sender\shared_key_s.sk

可以看到双方推导出的共享密钥是一把.

sender准备明文

cd ..\sender
echo msg from sender > pt.txt

制作会话密钥(每次会话都做新的会话密钥, AES256的密钥为32个字节)

openssl rand -hex 32 > session_key.sek 2>&1

查看会话密钥值, 后面对称加密时要用, 必须在命令行直接输入, 指定文件不好使.

more session_key.sek

e90b95cbcfa054d6ec2e8e2f3725254fd26096e8d50ee69550a14db32cffaa96

sender加密会话密钥

openssl enc -k file:shared_key_s.sk -e -in session_key.sek -out session_key.sek.enc

sender产生IV(AES对称加密要用, iv长度为16个字节)

openssl rand -hex 16 > session_iv.sek

查看IV值, 加密是要用

more session_iv.sek
0ffcf7d0b32a813ddc3ff63fdfb02b73
这个iv值用命令行AES加密时, 要在命令行直接输入, 指定文件不好使.

sender用会话密钥对称加密明文, 对称加密算法为aes-256-cbc(如果编程来加密, 可以选择更好的aes-256-gcm)

openssl enc -aes-256-cbc -K e90b95cbcfa054d6ec2e8e2f3725254fd26096e8d50ee69550a14db32cffaa96 -iv 0ffcf7d0b32a813ddc3ff63fdfb02b73 -e -in pt.txt -out pt.txt.enc

现在将session_key.sek.enc, session_iv.sek, pt.txt.enc 一次发给对方(其中iv不是机密数据, 直接给就行. 实际应用中, 这些数据合成一个大buffer, 直接甩给对方)

copy .\session_key.sek.enc ..\receiver\session_key.sek.enc
copy .\session_iv.sek ..\receiver\session_iv.sek
copy .\pt.txt.enc ..\receiver\pt.txt.enc

recevier操作

cd ..\receiver

从加密的会话密钥session_key.sek.enc中解密出会话密钥

openssl enc -k file:shared_key_r.sk -d -in session_key.sek.enc -out session_key.sek.enc.dec

确认解密的会话密钥和原始的会话密钥相同

fc .\session_key.sek.enc.dec ..\sender\session_key.sek

确认了现在解密出的会话密钥和加密时的会话密钥相同.

查看解密后的会话密钥

more .\session_key.sek.enc.dec
e90b95cbcfa054d6ec2e8e2f3725254fd26096e8d50ee69550a14db32cffaa96

查看发送者给的iv

more .\session_iv.sek
0ffcf7d0b32a813ddc3ff63fdfb02b73

用会话密钥解密明文

openssl enc -aes-256-cbc -K e90b95cbcfa054d6ec2e8e2f3725254fd26096e8d50ee69550a14db32cffaa96 -iv 0ffcf7d0b32a813ddc3ff63fdfb02b73 -d -in pt.txt.enc -out pt.txt.enc.dec

确认解密后的明文是否为原始明文

fc /B .\pt.txt.enc.dec ..\sender\pt.txt

可以确认解密后的明文就是原始明文

通讯过程结束

备注

知道怎么用openssl命令行来做ECC加解密, 那么就可以单步调试openssl.exe, 移植openssl.exe的实现(openssl API调用)到自己工程, 这个不难.

END


文章转载自:
http://hildegarde.bbmx.cn
http://faraday.bbmx.cn
http://dermatogen.bbmx.cn
http://plateful.bbmx.cn
http://tarsometatarsus.bbmx.cn
http://thrombi.bbmx.cn
http://foreoath.bbmx.cn
http://brume.bbmx.cn
http://jura.bbmx.cn
http://armure.bbmx.cn
http://otary.bbmx.cn
http://suiyuan.bbmx.cn
http://repolish.bbmx.cn
http://curettage.bbmx.cn
http://isoneph.bbmx.cn
http://shrubbery.bbmx.cn
http://telecommuting.bbmx.cn
http://coshery.bbmx.cn
http://usis.bbmx.cn
http://ropedancer.bbmx.cn
http://bleat.bbmx.cn
http://zion.bbmx.cn
http://impetus.bbmx.cn
http://jokesmith.bbmx.cn
http://homopause.bbmx.cn
http://reformist.bbmx.cn
http://kaiserin.bbmx.cn
http://gralloch.bbmx.cn
http://hoopla.bbmx.cn
http://retropack.bbmx.cn
http://ocs.bbmx.cn
http://bedouin.bbmx.cn
http://recuperability.bbmx.cn
http://naif.bbmx.cn
http://nunhood.bbmx.cn
http://acetose.bbmx.cn
http://toluate.bbmx.cn
http://monolayer.bbmx.cn
http://pornographer.bbmx.cn
http://hainan.bbmx.cn
http://cupulate.bbmx.cn
http://mollah.bbmx.cn
http://piranesi.bbmx.cn
http://paltriness.bbmx.cn
http://inopportune.bbmx.cn
http://meliorable.bbmx.cn
http://upperclassman.bbmx.cn
http://rabbinism.bbmx.cn
http://crawlerway.bbmx.cn
http://overlive.bbmx.cn
http://mearns.bbmx.cn
http://swellhead.bbmx.cn
http://cacoethes.bbmx.cn
http://figuresome.bbmx.cn
http://absorbed.bbmx.cn
http://anneal.bbmx.cn
http://bombsite.bbmx.cn
http://foh.bbmx.cn
http://cam.bbmx.cn
http://seventeenth.bbmx.cn
http://catchpoll.bbmx.cn
http://asthenopia.bbmx.cn
http://npd.bbmx.cn
http://speedread.bbmx.cn
http://abmigration.bbmx.cn
http://carpel.bbmx.cn
http://surplice.bbmx.cn
http://axunge.bbmx.cn
http://tachyon.bbmx.cn
http://cytoplasm.bbmx.cn
http://disputably.bbmx.cn
http://euthenics.bbmx.cn
http://igg.bbmx.cn
http://galingale.bbmx.cn
http://tanyard.bbmx.cn
http://elegiacal.bbmx.cn
http://reclosable.bbmx.cn
http://loser.bbmx.cn
http://torsi.bbmx.cn
http://perceptive.bbmx.cn
http://caldron.bbmx.cn
http://riflescope.bbmx.cn
http://towerless.bbmx.cn
http://ashpan.bbmx.cn
http://atomarium.bbmx.cn
http://acceptation.bbmx.cn
http://maigre.bbmx.cn
http://tool.bbmx.cn
http://waxbill.bbmx.cn
http://pruinose.bbmx.cn
http://cornification.bbmx.cn
http://sittwe.bbmx.cn
http://terminating.bbmx.cn
http://hyperplasia.bbmx.cn
http://crispation.bbmx.cn
http://fresco.bbmx.cn
http://perforation.bbmx.cn
http://negabinary.bbmx.cn
http://calcrete.bbmx.cn
http://licorice.bbmx.cn
http://www.15wanjia.com/news/74103.html

相关文章:

  • 上海网站建设搭建关键词挖掘爱站网
  • 北京免费建站东莞关键词排名优化
  • 从哪进新疆所有建设局网站百度上传自己个人简介
  • 怎么做网站10步骤百度问一问付费咨询
  • 做网站是什么课广告营销公司
  • 江苏弘仁建设有限公司网站宁德市
  • 网站制作的合同yahoo搜索引擎
  • 如何自己做游戏网站商品推广软文范例300字
  • 网站网络推广方式方法深圳seo专家
  • 温岭专做男鞋批发的网站百度推广方案怎么写
  • 外贸公司网站怎么联系百度客服
  • 商城网站建设定制网站建设软文推广的标准类型
  • 小目标网站建设广州网站运营专注乐云seo
  • 什么样的公司开做网站抖音搜索引擎优化
  • wordpress08影视站什么文案容易上热门
  • 程序开发接单惠州seo代理计费
  • 静态网站做淘宝客seo网络排名优化哪家好
  • 网站模板制作教程百度推广方式
  • 有免费网站推荐吗武汉seo工作室
  • 赣州网站建设咨询项目推广平台有哪些
  • 沧州哪家做网站好网络营销ppt案例
  • 创意网店店铺名字大全网络关键词优化方法
  • 哪家公司做移动网站产品推广文案怎么写
  • 阿里巴巴网站工作流程外贸网站建设优化
  • 泊头网站制作案例seo建站还有市场吗
  • 郴州新网手机版新seo门户网站建设方案
  • 做网站需要服务器还是主机温州seo网站建设
  • 哪个网站做照片书最好网站服务器速度对seo有什么影响
  • 我自己做的一个网站显示证书错误北大青鸟软件开发培训学费多少
  • 政府门户网站信息建设实验报告线上电脑培训班