C#加密解密算法

加密|解密|算法

/*************************字符串加密算法***********************/
public string EncryptString(string str)
  {
   char[] Base64Code=new char[]{'a','b','c','d','e','f','g','h','i','j','k','l','m','n','o','p','q','r','s','t','u','v','w','x','y','z','A','B','C','D','E','F','G','H','I','J','K','L','M','N','O','P','Q','R','S','T','U','V','W','X','Y','Z','0','1','2','3','4','5','6','7','8','9','+','/','='};
   byte empty=(byte)0;
   System.Collections.ArrayList byteMessage=new  System.Collections.ArrayList(System.Text.Encoding.Default.GetBytes(str));
   System.Text.StringBuilder outmessage;
   int messageLen=byteMessage.Count;
   int page=messageLen/3;
   int use=0;
   if((use=messageLen%3)>0)
   {
    for(int i=0;i<3-use;i++)
     byteMessage.Add(empty);
    page++;
   }
   outmessage=new System.Text.StringBuilder(page*4);
   for(int i=0;i<page;i++)
   {
    byte[] instr = new byte[3];
    instr[0]=(byte)byteMessage[i*3];
    instr[1]=(byte)byteMessage[i*3+1];
    instr[2]=(byte)byteMessage[i*3+2];
    int[] outstr=new int[4];
    outstr[0]=instr[0]>>2;
 
    outstr[1]=((instr[0]&0x03)<<4)^(instr[1]>>4);
    if(!instr[1].Equals(empty))
     outstr[2]=((instr[1]&0x0f)<<2)^(instr[2]>>6);
    else
     outstr[2]=64;
    if(!instr[2].Equals(empty))
     outstr[3]=(instr[2]&0x3f);
    else
     outstr[3]=64;
    outmessage.Append(Base64Code[outstr[0]]);
    outmessage.Append(Base64Code[outstr[1]]);
    outmessage.Append(Base64Code[outstr[2]]);
    outmessage.Append(Base64Code[outstr[3]]);
   }
   return outmessage.ToString();
  }
/**************************************************字符串解密算法**************************************************/
public string DecryptString(string str)
              {
   if((str.Length%4)!=0)
   {
    throw new ArgumentException("不是正确的BASE64编码,请检查。","str");
   }
   if(!System.Text.RegularExpressions.Regex.IsMatch(str,"^[A-Z0-9/+=]*$",System.Text.RegularExpressions.RegexOptions.IgnoreCase))
   {
    throw new ArgumentException("包含不正确的BASE64编码,请检查。","str");
   }
   string Base64Code="abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789+/=";
   int page=str.Length/4;
   System.Collections.ArrayList outMessage=new System.Collections.ArrayList(page*3);
   char[] message=str.ToCharArray();
   for(int i=0;i<page;i++)
   {
    byte[] instr=new byte[4];
    instr[0]=(byte)Base64Code.IndexOf(message[i*4]);
    instr[1]=(byte)Base64Code.IndexOf(message[i*4+1]);
    instr[2]=(byte)Base64Code.IndexOf(message[i*4+2]);
    instr[3]=(byte)Base64Code.IndexOf(message[i*4+3]);
    byte[] outstr=new byte[3];
    outstr[0]=(byte)((instr[0]<<2)^((instr[1]&0x30)>>4));
    if(instr[2]!=64)
    {
     outstr[1]=(byte)((instr[1]<<4)^((instr[2]&0x3c)>>2));
    }
    else
    {
     outstr[2]=0;
    }
    if(instr[3]!=64)
    {
     outstr[2]=(byte)((instr[2]<<6)^instr[3]);
    }
    else
    {
     outstr[2]=0;
    }
    outMessage.Add(outstr[0]);
    if(outstr[1]!=0)
     outMessage.Add(outstr[1]);
    if(outstr[2]!=0)
     outMessage.Add(outstr[2]);
   }
   byte[] outbyte=(byte[])outMessage.ToArray(Type.GetType("System.Byte"));
   return System.Text.Encoding.Default.GetString(outbyte);
  
  }
文件的加密解密说明:
  
    在对文件进行加密解密时,先将文件的内容读取到一个字符串变量中,然后对字符串加密,最后再把加密后的字符串写入到文件中。详见:
文件操作.txt。

时间: 2024-09-27 07:53:20

C#加密解密算法的相关文章

详解.Net下的加密解密算法(6) 玩转非对称加密

本博文来聊聊怎么玩转非对称加密吧,这里主要介绍.NET算法下的3种非对称加密算法:DSA,RSA,ECDsa.上两篇博文分 别为Hash家族和非对称加密家族找到了lead,现在我们就为非对称加密技术找个合适的lead吧. 首先创建一个接口 :"IEncryptAndDecrypt",然后为上面的3中算法分别创建3个实现类并让这些类实现接口"IEncryptAndDecrypt".它们 的情况如下图: 这下我们把这些哥们都召集起来了,现在我们就给他们找一个lead:&

详解.NET下的加密解密算法(3) 非对称加密

本博文列出了.NET下常用的非对称加密算法,并将它们制作成小DEMO,希望能对大家有所帮助. RSA static string EnRSA(string data,string publickey) { RSACryptoServiceProvider rsa = new RSACryptoServiceProvider(); byte[] cipherbytes; rsa.FromXmlString(publickey); cipherbytes = rsa.Encrypt(Encoding

PHP实现加密解密算法

PHP实现加密解密的算法,如下代码: <?php    class Mcrypt    {        /**        * 解密        *         * @param string $encryptedText 已加密字符串        * @param string $key  密钥        * @return string        */        public static function _decrypt($encryptedText,$key =

详解.NET下的加密解密算法(2) 对称加密

本博文列出了.NET下常用的对称加密算法,并将它们制作成小DEMO,希望能对大家有所帮助. 公共代码 static byte[] CreateKey(int num) { byte[] result = new byte[num]; Random rand = new Random(); for (int i = 0; i < num; i++) { result[i] = (Byte)rand.Next(1, 256); } return result; } DES /// <summary

详解.NET下的加密解密算法(1) 哈希加密

.NET有丰富的加密解密API库供我们使用,本博文总结了.NET下的Hash散列算法,并制作成简单的DEMO,希望能对大家 有所帮助. MD5 using System; using System.Collections.Generic; using System.Text; using System.Security.Cryptography; namespace EncryptAndDecrypt { public class MD5 { public byte[] Hash(byte[]

简介.Net框架下的各种加密解密算法

该文章将会不断的收入.net下的加密算法,这些算法将会采用策略模式来统一管理. using System; using System.Collections.Generic; using System.Text; namespace EncryptAndDecrypt { public class EncryptAndDecrytHandler { IEncrytAndDecrypt _EncryptAndDecrypt; public EncryptAndDecrytHandler(IEncr

一组PHP可逆加密解密算法实例代码

 这篇文章主要介绍了一组PHP可逆加密解密算法实例代码,有需要的朋友可以参考一下 对于大部分密码加密,我们可以采用md5.sha1等方法.可以有效防止数据泄露,但是这些方法仅适用于无需还原的数据加密.   对于需要还原的信息,则需要采用可逆的加密解密算法.   下面一组PHP函数是实现此加密解密的方法:   加密算法如下: 代码如下: function encrypt($data, $key) {  $key = md5($key);     $x  = 0;     $len = strlen

java实现Base64加密解密算法_java

Base64是网络上最常见的用于传输8Bit字节代码的编码方式之一,大家可以查看RFC2045-RFC2049,上面有MIME的详细规范.Base64编码可用于在HTTP环境下传递较长的标识信息.例如,在Java Persistence系统Hibernate中,就采用了Base64来将一个较长的唯一标识符(一般为128-bit的UUID)编码为一个字符串,用作HTTP表单和HTTP GET URL中的参数.在其他应用程序中,也常常需要把二进制数据编码为适合放在URL(包括隐藏表单域)中的形式.

一次一密加密解密算法

static int MAX=100; static char[] key=new char[MAX]; //用于保存密钥 static int len; static char[] bitcode(char[] str) //一次一密加密算法 { int i; char[] wen; if((wen=new char[len+1])==null) { System.out.printf("申请内存失败!\n"); System.exit(1); } for(i=0;i<len;