JAVA代码
import java.security.Key;
import java.security.SecureRandom;import javax.crypto.Cipher;
import javax.crypto.KeyGenerator;import sun.misc.BASE64Decoder;
import sun.misc.BASE64Encoder;public class DesSecurity {
    
  Key key;  public DesSecurity(String str) {
    setKey(str);//生成密匙
  }  public DesSecurity() {
    setKey("h5UzDCc(JqFrs50L");
  }  /**
   * 根据参数生成KEY
   */
  public void setKey(String strKey) {
      try {
        KeyGenerator _generator = KeyGenerator.getInstance("DES");
        _generator.init(new SecureRandom(strKey.getBytes()));
        this.key = _generator.generateKey();
        _generator = null;
      } catch (Exception e) {
        throw new RuntimeException(
            "Error initializing SqlMap class. Cause: " + e);
      }
  }  /**
   * 加密String明文输入,String密文输出
   */
  public String getEncString(String strMing) {
      byte[] byteMi = null;
      byte[] byteMing = null;
      String strMi = "";
      BASE64Encoder base64en = new BASE64Encoder();
      try {
        byteMing = strMing.getBytes("UTF8");
        byteMi = this.getEncCode(byteMing);
        strMi = base64en.encode(byteMi);
      } catch (Exception e) {
        throw new RuntimeException(
            "Error initializing SqlMap class. Cause: " + e);
      } finally {
        base64en = null;
        byteMing = null;
        byteMi = null;
      }
      return strMi;
  }  /**
   * 解密 以String密文输入,String明文输出
   * @param strMi
   * @return
   */
  public String getDesString(String strMi) {
      BASE64Decoder base64De = new BASE64Decoder();
      byte[] byteMing = null;
      byte[] byteMi = null;
      String strMing = "";
      try {
        byteMi = base64De.decodeBuffer(strMi);
        byteMing = this.getDesCode(byteMi);
        strMing = new String(byteMing, "UTF8");
      } catch (Exception e) {
        throw new RuntimeException(
            "Error initializing SqlMap class. Cause: " + e);
      } finally {
        base64De = null;
        byteMing = null;
        byteMi = null;
      }
      return strMing;
  }  /**
   * 加密以byte[]明文输入,byte[]密文输出
   * @param byteS
   * @return
   */
  private byte[] getEncCode(byte[] byteS) {
      byte[] byteFina = null;
      Cipher cipher;
      try {
        cipher = Cipher.getInstance("DES");
        cipher.init(Cipher.ENCRYPT_MODE, key);
        byteFina = cipher.doFinal(byteS);
      } catch (Exception e) {
        throw new RuntimeException(
            "Error initializing SqlMap class. Cause: " + e);
      } finally {
        cipher = null;
      }
      return byteFina;
  }  /**
   * 解密以byte[]密文输入,以byte[]明文输出
   * @param byteD
   * @return
   */
  private byte[] getDesCode(byte[] byteD) {
      Cipher cipher;
      byte[] byteFina = null;
      try {
        cipher = Cipher.getInstance("DES");
        cipher.init(Cipher.DECRYPT_MODE, key);
        byteFina = cipher.doFinal(byteD);
      } catch (Exception e) {
        throw new RuntimeException(
            "Error initializing SqlMap class. Cause: " + e);
      } finally {
        cipher = null;
      }
      return byteFina;
  }  public static void main(String args[]) {
      DesSecurity des = new DesSecurity();
      // 设置密钥
      des.setKey("12345678");      String str1 = "12345678";
      //DES加密
      String str2 = des.getEncString(str1);
      String deStr = des.getDesString(str2);
      System.out.println("密文:" + str2);
      //DES解密
      System.out.println("明文:" + deStr);
  }
}

解决方案 »

  1.   

    C#代码/// <summary>
            /// 加密字符串
            /// 注意:密钥必须为8位
            /// </summary>
            /// <param name="strText">字符串</param>
            /// <param name="encryptKey">密钥</param>
            public byte[] DesEncrypt(byte[] inputByteArray)
            {
                byte[] byKey = null;
                
                byKey = System.Text.Encoding.UTF8.GetBytes(this.decryptKey.Substring(0, 8));
                DESCryptoServiceProvider des = new DESCryptoServiceProvider();
                
                MemoryStream ms = new MemoryStream();
                des.Key = byKey;
                
                CryptoStream cs = new CryptoStream(ms, des.CreateEncryptor(), CryptoStreamMode.Write);
                cs.Write(inputByteArray, 0, inputByteArray.Length);
                cs.FlushFinalBlock();
                return ms.ToArray();
            }
            
              public string decryptKey;
              
                          string s = "12345678";
                byte[] bs = System.Text.Encoding.UTF8.GetBytes(s);            decryptKey = "12345678";            byte[] jjj = DesEncrypt(bs);
      

  2.   

    能不能请高手们,根据我的JAVA代码,写一个C#的版本呢?