赛迪网 > IT技术 DELPHI > 文章
  IT资讯搜索
 
IT产品搜索
[程序开发][网管世界][网络安全][数据库技术]
[操作系统][嘉宾聊天·在线访谈][活动集锦]
[精彩专题][Symantec专区][订阅IT技术周刊]
[开发论坛][网管论坛][安全论坛][数据库论坛]
[操作系统论坛][Sybase专区][IBM dW技术专区]
[病毒求助][病毒与漏洞播报][文档·源码下载]

提供一个基于C++的加密/解密算法

发布时间:2006.01.10 21:19     来源:赛迪论坛    作者:Sabine

提供一个基于.net SymmetricAlgorithm 类的、带私钥的加密/解密算法的包装类。使用方法:

SymmCrypto de = new SymmCrypto(SymmCrypto.SymmProvEnum.DES);
Response.Write(x.Decrypting(de.Encrypting("ok","yyy"),"yyy"));

类的实现C#编码

using System;
using System.Security.Cryptography;
using System.IO;
using System.Text;

namespace eMeng
{
  /// <summary>
  /// SymmCrypto 的摘要说明。
  /// SymmCrypto类实现.NET框架下的加密和解密服务。
  /// 原作者: Frank Fang : fangfrank@hotmail.com
  /// </summary>
  public class SymmCrypto
  {
      public enum SymmProvEnum : int
      {
        DES, RC2, Rijndael
      }

    private SymmetricAlgorithm mobjCryptoService;

    /// <remarks>
    /// 使用.Net SymmetricAlgorithm 类的构造器.
    /// </remarks>
    public SymmCrypto(SymmProvEnum NetSelected)
    {
      switch (NetSelected)
      {
        case SymmProvEnum.DES:
          mobjCryptoService = new DESCryptoServiceProvider();
          break;
        case SymmProvEnum.RC2:
          mobjCryptoService = new RC2CryptoServiceProvider();
          break;
        case SymmProvEnum.Rijndael:
          mobjCryptoService = new RijndaelManaged();
          break;
      }
    }

    /// <remarks>
    /// 使用自定义SymmetricAlgorithm类的构造器.
    /// </remarks>
    public SymmCrypto(SymmetricAlgorithm ServiceProvider)
    {
      mobjCryptoService = ServiceProvider;
    }

    /// <remarks>
    /// Depending on the legal key size limitations of 
    /// a specific CryptoService provider and length of 
    /// the private key provided, padding the secret key 
    /// with space character to meet the legal size of the algorithm.
    /// </remarks>
    private byte[] GetLegalKey(string Key)
    {
      string sTemp;
      if (mobjCryptoService.LegalKeySizes.Length > 0)
      {
        int lessSize = 0, moreSize = mobjCryptoService.LegalKeySizes[0].MinSize;
        // key sizes are in bits
        while (Key.Length * 8 > moreSize)
        {
          lessSize = moreSize;
          moreSize += mobjCryptoService.LegalKeySizes[0].SkipSize;
        }
        sTemp = Key.PadRight(moreSize / 8, ' ');
      }
      else
        sTemp = Key;

      // convert the secret key to byte array
      return ASCIIEncoding.ASCII.GetBytes(sTemp);
    }

    public string Encrypting(string Source, string Key)
    {
      byte[] bytIn = System.Text.ASCIIEncoding.ASCII.GetBytes(Source);
      // create a MemoryStream so that the process can be done without I/O files
      System.IO.MemoryStream ms = new System.IO.MemoryStream();

      byte[] bytKey = GetLegalKey(Key);

      // set the private key
      mobjCryptoService.Key = bytKey;
      mobjCryptoService.IV = bytKey;

      // create an Encryptor from the Provider Service instance
      ICryptoTransform encrypto = mobjCryptoService.CreateEncryptor();

      // create Crypto Stream that transforms a stream using the encryption
      CryptoStream cs = new CryptoStream(ms, encrypto, CryptoStreamMode.Write);

      // write out encrypted content into MemoryStream
      cs.Write(bytIn, 0, bytIn.Length);
      cs.FlushFinalBlock();
            
      // get the output and trim the '\0' bytes
      byte[] bytOut = ms.GetBuffer();
      int i = 0;
      for (i = 0; i < bytOut.Length; i++)
        if (bytOut[i] == 0)
          break;
                    
      // convert into Base64 so that the result can be used in <a href="http://dev.21tx.com/dotnet/xml/" target="_blank">XML</a>
      return System.Convert.ToBase64String(bytOut, 0, i);
    }

    public string Decrypting(string Source, string Key)
    {
      // convert from Base64 to binary
      byte[] bytIn = System.Convert.FromBase64String(Source);
      // create a MemoryStream with the input
      System.IO.MemoryStream ms = new System.IO.MemoryStream(bytIn, 0, bytIn.Length);

      byte[] bytKey = GetLegalKey(Key);

      // set the private key
      mobjCryptoService.Key = bytKey;
      mobjCryptoService.IV = bytKey;

      // create a Decryptor from the Provider Service instance
      ICryptoTransform encrypto = mobjCryptoService.CreateDecryptor();
 
      // create Crypto Stream that transforms a stream using the decryption
      CryptoStream cs = new CryptoStream(ms, encrypto, CryptoStreamMode.Read);

      // read out the result from the Crypto Stream
      System.IO.StreamReader sr = new System.IO.StreamReader( cs );
      return sr.ReadToEnd();
    }
  }
}

(T127)


[ 发表评论 ] 字体[  ] [ 打印 ] [ 进入博客 ] [ 进入论坛 ]  [ 推荐给朋友 ]
  相关文章
· C#中实现DataGrid双向排序 (01-10) · C++之父Bjarne谈C++在2005年 (01-10)
· 周末巨献:有可能挑战Java优势的四种技术 (12-09) · 黑客新手基础知识16问答 (12-02)
· 网络安全术语解释 (12-01) · Java理论与实践:再谈Urban性能之传言 (11-15)
· 使用Sniffer捕获加密包和非加密包 (09-28) · 移形幻影大法 C++程序员快速学习C#之二 (09-07)
· 移形幻影大法 C++程序员快速学习C#之三 (09-07) · 移形幻影大法 C++程序员快速学习C#之一 (09-06)
  客户需求反馈表
* 姓  名:
更多资料  了解方案  认识厂商
* 单位名称:
* 联系电话:
* 电子邮件:
  赛迪推荐  
  手机·资费 ·新品·导购·评测·手机资费·宽带
手机搜索  诺基亚 N73 MOTO Z6
  IT产品 ·笔记本·台式机·服务器·打印·投影
IT产品搜索 
  IT技术 ·开发·网管·安全·数据库·操作系统
  信息化 ·热点·专题·访谈·周刊·方案案例
[政务][电信][金融][农业][制造业][中小企业]
[CIO][ERP][协同][IT管理][中间件][电子商务]
[政策][地方][专家][评估][辞典][博客][社区]
· 专题:一路畅通构想曲——让出行不再遭遇堵车
· CIO工作亲历:企业ERP选型不能忽视"选人关"
· 综述:信息化建设给中国监狱带来的各种变化
· 金融业风险管理和法规遵从有五点需考虑的因素
· 保险业CIO关注:该如何建立统一高效的CRM体系
· 调查显示:多数CIO对IT规划仍存在困惑和误解
  博客·论坛 ·曾剑秋·项立刚·Java学习·网管