Bouncycastle库C#版

官网地址为:http://www.bouncycastle.org/csharp/。

http://blog.csdn.net/popozhu/article/details/5812662

http://www.xuebuyuan.com/301023.html

从PEM文件读取秘钥

PemReader r = new PemReader(new StreamReader("Files/pubkey.pem"));
AsymmetricKeyParameter pubKey = (AsymmetricKeyParameter)r.ReadObject(); PemReader r = new PemReader(new StreamReader("Files/prvkey.pem"));
AsymmetricKeyParameter prvKey = (AsymmetricKeyParameter)r.ReadObject();

加载pfx证书库、读取证书、获取秘钥

FileStream ms = new FileStream("store.p12",OpenMode.Open);
Pkcs12Store store = new Pkcs12StoreBuilder().Build();
store.Load(ms, "".ToCharArray()); //获取第一个别名
IEnumerator itor = store.Aliases.GetEnumerator();
itor.MoveNext();
string alins = itor.Current.ToString(); AsymmetricKeyParameter prvKey=null;
AsymmetricKeyParameter pubKey=null; if(sotre.IsKeyEntry(alins))
  prvKey = store.GetKey(alins).Key; cert = store.GetCertificate(alins).Certificate;
pubkey=cert.GetPublicKey();

加密、解密

AsymmetricKeyParameter prvKey=...;
AsymmetricKeyParameter pubKey=...; //公钥加密
string origin="abcd1234";
byte[] originbytes=Encoding.Default.getBytes(origin);
IBufferedCipher c = CipherUtilities.GetCipher("RSA/ECB/PKCS1Padding");
c.Init(true, pubKey);
byte[] encryBytes = c.DoFinal(origin);
string encryStr=Encoding.Default.GetString(encryBytes); //私钥解密
IBufferedCipher c = CipherUtilities.GetCipher("RSA/ECB/PKCS1Padding");
c.Init(false, prvKey);
byte[] recoverBytes=c.DoFinal(encryBytes );
string recover=Encoding.Default.GetString(recoverBytes);

签名、验证

生成与导出秘钥、证书、库

最新文章

  1. linux 常用命令学习记录
  2. python3-day4-python函数
  3. 大数据架构:flume-ng+Kafka+Storm+HDFS 实时系统组合
  4. Microsoft HoloLens 技术解谜(下)
  5. 04747_Java语言程序设计(一)_第8章_多线程
  6. UILabel头文件常见属性
  7. pojg487-3279电话号码转换(字符映射)
  8. RPC 调用简述
  9. 在线资源--图片/json等
  10. HTML5 CSS3 诱人的实例: 3D立方体旋转动画
  11. Vue 进阶之路(四)
  12. 软件测试人员必备网络知识(一):什么是cookie?
  13. JAVA WEN开发环境与搭建
  14. Petrozavodsk Winter Camp, Andrew, 2014, Dichromatic Trees
  15. Flask-论坛开发-3-数据库
  16. Ubuntu安装完成后设置root密码
  17. ng-model的用法
  18. Linux命令-工作管理命令:&,ctrl+z,jobs,fg,bg
  19. Shortest Paths
  20. 1009 产生数 2002年NOIP全国联赛普及组

热门文章

  1. atom初体验
  2. Linux用户名显示-bash-4.1$快速排查
  3. linux tricks 之 FIELD_SIZEOF.
  4. [杂]SQL Server 之命名管道连接
  5. cocos2dx游戏开发——微信打飞机学习笔记(八)——EnemyLayer的搭建
  6. maven打的jars项目,log4j不会输出日志
  7. javascript优化--13模式1(DOM和浏览器模式)
  8. 分享Kali Linux 2016.2第36周镜像虚拟机
  9. mysql之对表的操作
  10. bug记录