这里贴出来的是可通用的C#与jav的DES加密类,希望对大家管用直接复制即可用 
C#DES加密解密类

    1. ///<summary><![CDATA[加密解密帮助类]]></summary>
    2. public class Help_Encrypt
    3. {
    4. ///<summary><![CDATA[字符串DES加密函数]]></summary>
    5. ///<param name="str"><![CDATA[被加密字符串 ]]></param>
    6. ///<param name="key"><![CDATA[密钥 ]]></param>
    7. ///<returns><![CDATA[加密后字符串]]></returns>
    8. public static string Encode(string str, string key)
    9. {
    10. try
    11. {
    12. DESCryptoServiceProvider provider = new DESCryptoServiceProvider();
    13. provider.Key = Encoding.ASCII.GetBytes(key.Substring(0, 8));
    14. provider.IV = Encoding.ASCII.GetBytes(key.Substring(0, 8));
    15. byte[] bytes = Encoding.GetEncoding("GB2312").GetBytes(str);
    16. MemoryStream stream = new MemoryStream();
    17. CryptoStream stream2 = new CryptoStream(stream, provider.CreateEncryptor(), CryptoStreamMode.Write);
    18. stream2.Write(bytes, 0, bytes.Length);
    19. stream2.FlushFinalBlock();
    20. StringBuilder builder = new StringBuilder();
    21. foreach (byte num in stream.ToArray())
    22. {
    23. builder.AppendFormat("{0:X2}", num);
    24. }
    25. stream.Close();
    26. return builder.ToString();
    27. }
    28. catch (Exception) { return "xxxx"; }
    29. }
    30. ///<summary><![CDATA[字符串DES解密函数]]></summary>
    31. ///<param name="str"><![CDATA[被解密字符串 ]]></param>
    32. ///<param name="key"><![CDATA[密钥 ]]></param>
    33. ///<returns><![CDATA[解密后字符串]]></returns>
    34. public static string Decode(string str, string key)
    35. {
    36. try
    37. {
    38. DESCryptoServiceProvider provider = new DESCryptoServiceProvider();
    39. provider.Key = Encoding.ASCII.GetBytes(key.Substring(0, 8));
    40. provider.IV = Encoding.ASCII.GetBytes(key.Substring(0, 8));
    41. byte[] buffer = new byte[str.Length / 2];
    42. for (int i = 0; i < (str.Length / 2); i++)
    43. {
    44. int num2 = Convert.ToInt32(str.Substring(i * 2, 2), 0x10);
    45. buffer[i] = (byte)num2;
    46. }
    47. MemoryStream stream = new MemoryStream();
    48. CryptoStream stream2 = new CryptoStream(stream, provider.CreateDecryptor(), CryptoStreamMode.Write);
    49. stream2.Write(buffer, 0, buffer.Length);
    50. stream2.FlushFinalBlock();
    51. stream.Close();
    52. return Encoding.GetEncoding("GB2312").GetString(stream.ToArray());
    53. }
    54. catch (Exception) { return ""; }
    55. }
    56. }
    57. JAVADES加密解密类
    58. package com.bgxt.messages;
    59. import java.io.UnsupportedEncodingException;
    60. import java.security.*;
    61. import javax.crypto.Cipher;
    62. import javax.crypto.SecretKey;
    63. import javax.crypto.SecretKeyFactory;
    64. import javax.crypto.spec.DESKeySpec;
    65. import javax.crypto.spec.IvParameterSpec;
    66. /**
    67. * 字符串工具集合
    68. * @author Liudong
    69. */
    70. public class StringUtils {
    71. private static final String PASSWORD_CRYPT_KEY = XmlUtil.getConfig().getPasswdKey().substring(0,8);
    72. //private final static String DES = "DES";
    73. //private static final byte[] desKey;
    74. //解密数据
    75. public static String decrypt(String message,String key) throws Exception {
    76. byte[] bytesrc =convertHexString(message);
    77. Cipher cipher = Cipher.getInstance("DES/CBC/PKCS5Padding");
    78. DESKeySpec desKeySpec = new DESKeySpec(key.getBytes("UTF-8"));
    79. SecretKeyFactory keyFactory = SecretKeyFactory.getInstance("DES");
    80. SecretKey secretKey = keyFactory.generateSecret(desKeySpec);
    81. IvParameterSpec iv = new IvParameterSpec(key.getBytes("UTF-8"));
    82. cipher.init(Cipher.DECRYPT_MODE, secretKey, iv);
    83. byte[] retByte = cipher.doFinal(bytesrc);
    84. return new String(retByte);
    85. }
    86. public static byte[] encrypt(String message, String key)
    87. throws Exception {
    88. Cipher cipher = Cipher.getInstance("DES/CBC/PKCS5Padding");
    89. DESKeySpec desKeySpec = new DESKeySpec(key.getBytes("UTF-8"));
    90. SecretKeyFactory keyFactory = SecretKeyFactory.getInstance("DES");
    91. SecretKey secretKey = keyFactory.generateSecret(desKeySpec);
    92. IvParameterSpec iv = new IvParameterSpec(key.getBytes("UTF-8"));
    93. cipher.init(Cipher.ENCRYPT_MODE, secretKey, iv);
    94. return cipher.doFinal(message.getBytes("UTF-8"));
    95. }
    96. public static String encrypt(String value){
    97. String result="";
    98. try{
    99. value=java.net.URLEncoder.encode(value, "utf-8");
    100. result=toHexString(encrypt(value, PASSWORD_CRYPT_KEY)).toUpperCase();
    101. }catch(Exception ex){
    102. ex.printStackTrace();
    103. return "";
    104. }
    105. return result;
    106. }
    107. public static byte[] convertHexString(String ss)
    108. {
    109. byte digest[] = new byte[ss.length() / 2];
    110. for(int i = 0; i < digest.length; i++)
    111. {
    112. String byteString = ss.substring(2 * i, 2 * i + 2);
    113. int byteValue = Integer.parseInt(byteString, 16);
    114. digest[i] = (byte)byteValue;
    115. }
    116. return digest;
    117. }
    118. public static String toHexString(byte b[]) {
    119. StringBuffer hexString = new StringBuffer();
    120. for (int i = 0; i < b.length; i++) {
    121. String plainText = Integer.toHexString(0xff & b[i]);
    122. if (plainText.length() < 2)
    123. plainText = "0" + plainText;
    124. hexString.append(plainText);
    125. }
    126. return hexString.toString();
    127. }
    128. public static void main(String[] args) throws Exception {
    129. String value="01";
    130. System.out.println("加密数据:"+value);
    131. System.out.println("密码为:"+XmlUtil.getConfig().getPasswdKey());
    132. String a=encrypt( value);
    133. System.out.println("加密后的数据为:"+a);
    134. }
    135. }

C#用DES加密JAVA用DES解密,JAVA用DES加密C#用DES解密的实现的更多相关文章

  1. des加密解密——java加密,php解密

    最近在做项目中,遇到des加密解密的问题. 场景是安卓app端用des加密,php这边需要解密.之前没有接触过des这种加密解密算法,但想着肯定会有demo.因此百度,搜了代码来用.网上代码也是鱼龙混 ...

  2. 使用C# DES解密java DES加密的字符串

    转自 microAllen   最近需要使用C#的DES解密工具类解密字符串,但是要解密的字符串是使用java进行DES加密的,去网上查了关于C#和java关于DES加密解密的资料,发现可以相互加密解 ...

  3. des加密解密JAVA与.NET互通实例

    JAVA版本 import javax.crypto.Cipher; import javax.crypto.SecretKey; import javax.crypto.SecretKeyFacto ...

  4. DES加密解密 Java中运用

    DES全称Data Encryption Standard,是一种使用密匙加密的块算法.现在认为是一种不安全的加密算法,因为现在已经有用穷举法攻破DES密码的报道了.尽管如此,该加密算法还是运用非常普 ...

  5. Android DES加密的CBC模式加密解密和ECB模式加密解密

    DES加密共有四种模式:电子密码本模式(ECB).加密分组链接模式(CBC).加密反馈模式(CFB)和输出反馈模式(OFB). CBC模式加密: import java.security.Key; i ...

  6. Des加解密(Java端和Js端配套)解析

    一.什么是DES加密        des对称加密,对称加密,是一种比较传统的加密方式,其加密运算.解密运算使用的是同样的密钥,信息的发送者和信息的接收者在进行信息的传输与处理时,必须共同持有该密码( ...

  7. 【转】asp.net(c#)加密解密算法之sha1、md5、des、aes实现源码详解

    原文地址:http://docode.top/Article/Detail/10003 目录: 1..Net(C#)平台下Des加密解密源代码 2..Net(C#)平台下Aes加密解密源代码 3..N ...

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

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

  9. NET实现RSA AES DES 字符串 加密解密以及SHA1 MD5加密

    本文列举了    数据加密算法(Data Encryption Algorithm,DEA) 密码学中的高级加密标准(Advanced EncryptionStandard,AES)RSA公钥加密算法 ...

  10. Java加密与解密笔记(三) 非对称加密

    非对称的特点是加密和解密时使用的是不同的钥匙.密钥分为公钥和私钥,用公钥加密的数据只能用私钥进行解密,反之亦然. 另外,密钥还可以用于数字签名.数字签名跟上文说的消息摘要是一个道理,通过一定方法对数据 ...

随机推荐

  1. Oracle “CONNECT BY” 使用

    Oracle “CONNECT BY” 使用 功能说明: 语法结构如下: [ START WITH condition ] CONNECT BY [ NOCYCLE ] condition 说明: 1 ...

  2. UITableViewCell 重合问题解决方法

    这两天做ios遇到一个UITableViewCell 数据重合的问题,原因:引起这个问题的主要原因是,重用cell.之前cell上的内容未被清空,而又增加新增内容所致.从网上查了一些解决方法,比如: ...

  3. Guide to Database Migration from Microsoft SQL Server using MySQL Workbench

    http://mysqlworkbench.org/2012/07/migrating-from-ms-sql-server-to-mysql-using-workbench-migration-wi ...

  4. 1063: [Noi2008]道路设计 - BZOJ

    Description Z 国坐落于遥远而又神奇的东方半岛上,在小Z 的统治时代公路成为这里主要的交通手段.Z 国共有n 座城市,一些城市之间由双向的公路所连接.非常神奇的是Z 国的每个城市所处的经度 ...

  5. 团体程序设计天梯赛-练习集L2-003. 月饼

    L2-003. 月饼 时间限制 100 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 陈越 月饼是中国人在中秋佳节时吃的一种传统食品,不同地区有许多不 ...

  6. uva 437 hdu 1069

    dp  将石块按三个面存入队列  按底面积排序  dp就最大高度  按嵌套矩形最长路做做法 #include <iostream> #include <cstdio> #inc ...

  7. C++智能指针(auto_ptr)详解

    智能指针(auto_ptr) 这个名字听起来很酷是不是?其实auto_ptr 只是C++标准库提供的一个类模板,它与传统的new/delete控制内存相比有一定优势,但也有其局限.本文总结的8个问题足 ...

  8. hdu 2516 取石子游戏 博弈论

    很显然的nim游戏的变形,很好找规律 先手败:2,3,5,8,13…… 其他先手胜.即满足菲波拉数列. 代码如下: #include<iostream> #include<stdio ...

  9. 【BZOJ 3343 】 分块

    3343: 教主的魔法 Description 教主最近学会了一种神奇的魔法,能够使人长高.于是他准备演示给XMYZ信息组每个英雄看.于是N个英雄们又一次聚集在了一起,这次他们排成了一列,被编号为1. ...

  10. UR #13 Ernd

    考试的时候没有注意到可以将(a,b)放在二维平面上之后旋转坐标系,使得转移变成树状数组二维偏序 这样就算我想出来了第二个转移的斜率优化也没有什么卵用啊(摔西瓜 设g(i)表示当前站在第i个水果下面且第 ...