本博文列出了.NET下常用的非对称加密算法,并将它们制作成小DEMO,希望能对大家有所帮助。

RSA
[csharp]
static string EnRSA(string data,string publickey) 

    RSACryptoServiceProvider rsa = new RSACryptoServiceProvider();  
    byte[] cipherbytes;  
    rsa.FromXmlString(publickey);  
    cipherbytes = rsa.Encrypt(Encoding.UTF8.GetBytes(data), false);  
    return Convert.ToBase64String(cipherbytes); 
     

 
static string DeRSA(string data,string privatekey) 

    
    RSACryptoServiceProvider rsa = new RSACryptoServiceProvider();  
    byte[] cipherbytes; rsa.FromXmlString(privatekey);  
    cipherbytes = rsa.Decrypt(Convert.FromBase64String(data), false);  
    return Encoding.UTF8.GetString(cipherbytes); 
}

调用代码
[csharp]
  Console.WriteLine("RSA非对称加密"); 
Byte[] iv = CreateKey(16); 
Byte[] key = CreateKey(27); 
string inputRSA_1 = inputString(); 
RSA rsa = RSA.Create(); 
 
string enData = EnRSA(inputRSA_1,rsa.ToXmlString(false)); 
 
 
Console.WriteLine("加密后的数据:{0}", enData); 
Console.WriteLine("解密后的数据:{0}", DeRSA(enData,rsa.ToXmlString(true)));

DSA(数字签名)
[csharp]
 static string EnDSA(string data,string publickey) 
   { 
       DSA dsa = DSA.Create(); 
       Byte[] result; 
       dsa.FromXmlString(publickey); 
       SHA1 sha1 = SHA1.Create(); 
       result = dsa.CreateSignature(sha1.ComputeHash(Convert.FromBase64String(data))); 
       return Convert.ToBase64String(result); 
 
        
   } 
 
   static bool DeDSA(string data,string privatekey,string originalData) 
   { 
       //Byte[] result; 
       DSA dsa = DSA.Create(); 
       dsa.FromXmlString(privatekey); 
       SHA1 sha1 = SHA1.Create(); 
       return dsa.VerifySignature(sha1.ComputeHash(Convert.FromBase64String(originalData)),Convert.FromBase64String(data)); 
 
   } 
调用代码
[csharp]
  Console.WriteLine("DSA数字签名"); 
string inputDSA_1 = inputString(); 
string inputDSA_2 = inputDSA_1; 
DSA dsa = DSA.Create(); 
string enData = EnDSA(inputDSA_1, dsa.ToXmlString(true)); 
 
Console.WriteLine("加密后的数据:{0}", enData); 
Console.WriteLine("解密后的数据:{0}", DeDSA(enData, dsa.ToXmlString(false), inputDSA_2));

ECDsa
[csharp]
 
static string EnECDsa(string data, CngKey key) 
 { 
     ECDsaCng ecdsa = new ECDsaCng(key); 
      
      
     SHA1 sha1 = SHA1.Create(); 
     byte[] result; 
 
     result = ecdsa.SignHash(sha1.ComputeHash(Convert.FromBase64String(data))); 
 
     return Convert.ToBase64String(result); 
 
 } 
 
 static bool DeECDsa(string data, CngKey key,string originalData) 
 { 
     ECDsaCng ecdsa = new ECDsaCng(key); 
     SHA1 sha1 = SHA1.Create(); 
 
     return ecdsa.VerifyHash(sha1.ComputeHash(Convert.FromBase64String(originalData)), Convert.FromBase64String(data)); 
 }

调用代码
[csharp]
  Console.WriteLine("ECDsa数字签名"); 
string inputDSA_1 = inputString(); 
string inputDSA_2 = inputDSA_1; 
CngKey key = CngKey.Create(CngAlgorithm.ECDsaP256); 
 
string enData = EnECDsa(inputDSA_1, key); 
 
Console.WriteLine("加密后的数据:{0}", enData); 
Console.WriteLine("解密后的数据:{0}", DeECDsa(enData, key, inputDSA_2));

.NET下的加密解密大全(3):非对称加密的更多相关文章

  1. 加密解密知识 php非对称加密

    function test1(){ $config = array( "digest_alg" => "sha1", "private_key_ ...

  2. PHP中使用OpenSSL生成RSA公钥私钥及进行加密解密示例(非对称加密)

    php服务端与客户端交互.提供开放api时,通常需要对敏感的部分api数据传输进行数据加密,这时候rsa非对称加密就能派上用处了,下面通过一个例子来说明如何用php来实现数据的加密解密 先了解一下关于 ...

  3. 使用java实现对称加密解密(AES),非对称加密解密(RSA)

    对称加密:双方采用同样的秘钥进行加密和解密.特点是速度快,但是安全性没有非对称加密高 非对称加密:接收方生成的公有秘钥公布给发送方,发送方使用该公有秘钥加密之后,发送给接收方,然后接收方使用私有秘钥解 ...

  4. 各种加密解密函数(URL加密解密、sha1加密解密、des加密解密)

    原文:各种加密解密函数(URL加密解密.sha1加密解密.des加密解密) 普通hash函数如md5.sha1.base64等都是不可逆函数.虽然我们利用php可以利用这些函数写出可逆函数来.但是跨语 ...

  5. php中des加密解密 匹配C#des加密解密 对称加密

    原文:php中des加密解密 匹配C#des加密解密 对称加密 网上找来的 php des加密解密 完全匹配上一篇C# 字符串加密解密函数  可以用于C#和php通信 对数据进行加密,其中$key 是 ...

  6. AES加密解密 助手类 CBC加密模式

    "; string result1 = AESHelper.AesEncrypt(str); string result2 = AESHelper.AesDecrypt(result1); ...

  7. .NET下的加密解密大全(2):对称加密

    本博文列出了.NET下常用的对称加密算法,并将它们制作成小DEMO,希望能对大家有所帮助. 公共代码[csharp]static byte[] CreateKey(int num) {     byt ...

  8. .NET下的加密解密大全(1): 哈希加密

    .NET有丰富的加密解密API库供我们使用,本博文总结了.NET下的Hash散列算法,并制作成简单的DEMO,希望能对大家有所帮助. MD5[csharp]using System; using Sy ...

  9. Java加密解密大全

    ChinaSEI系列讲义(By 郭克华)   Java加密解密方法大全                     如果有文字等小错,请多包涵.在不盈利的情况下,欢迎免费传播. 版权所有.郭克华 本讲义经 ...

随机推荐

  1. java线程(3)-多线程死锁

    产生死锁的条件: 1.有至少一个资源不能共享2.至少有一个任务必须持有一个资源并且等待获取另一个被别的任务持有的资源3.资源不能任务抢占4.必须有循环等待 package com.thread; /* ...

  2. 教程:使用 MongoDB、WCF、OData 和 PowerBI 构建 Azure 上的商业智能解决方案

     发布于 2014-05-20 作者 陈 忠岳 目录 概述 前提条件 创建 Windows Server 2012 Datacenter 虚拟机 通过 WCF(Windows Communicat ...

  3. WPA Supplicant 用法

    本文译至:https://wiki.archlinux.org/index.php/WPA_Supplicant_%28%E7%AE%80%E4%BD%93%E4%B8%AD%E6%96%87%29 ...

  4. Eclipse插件Subclipse各版本插件下载地址以及与Subverison的对应关系

    Subclipse 1.4.x includes and requires Subversion 1.5.x client features and working copy format. Subc ...

  5. js 获取 sktime时间

    效果图如下: HTML代码: <html> <head> <script> //------------------------------------------ ...

  6. Jquery Datatables 动态列名

    Datatables中文网:http://dt.thxopen.com/index.html 尝试: <table id="sp_table" class="dis ...

  7. Oracle创建表空间、创建用户、授权用户、导入dmp备份语句

    create tablespace TOPSCF_CHS_TS datafile 'D:\TableSpace\TOPSCF_CHS_TS.dbf' size 512M  extent managem ...

  8. Java 性能优化技巧及实战

    关于Java代码的性能优化,是每个javaer都渴望掌握的本领,进而晋升为大牛的必经之路,但是对java的调优需要了解整个java的运行 机制及底层调用细节,需要多看多读多写多试,并非一朝一夕之功.本 ...

  9. 2 weekend110的mapreduce介绍及wordcount + wordcount的编写和提交集群运行 + mr程序的本地运行模式

    把我们的简单运算逻辑,很方便地扩展到海量数据的场景下,分布式运算. Map作一些,数据的局部处理和打散工作. Reduce作一些,数据的汇总工作. 这是之前的,weekend110的hdfs输入流之源 ...

  10. Yii 将对象转化成数组

    将从数据库查找的对象,转换成数组,并且以设定属性键名称,用到ArrayHelper::toArray $posts = Post::find()->limit(10)->all(); $d ...