zoukankan      html  css  js  c++  java
  • DES加密 java与.net可以相互加密解密的方法

    我.net程序员。今天和java的童鞋交互,单点登录的操作。采用了如下的加密和解密的方式。经过验证,完美结合。通过这个方法可以实现java和C#相互加密与解密 并能保持解密出来一致。

    废话少说,上代码。

    C#代码如下

        #region DESEnCode DES加密     
        public static string DESEnCode(string pToEncrypt, string sKey)     
        {  
           // string pToEncrypt1 = HttpContext.Current.Server.UrlEncode(pToEncrypt);     
            DESCryptoServiceProvider des = new DESCryptoServiceProvider();  
            byte[] inputByteArray = Encoding.GetEncoding("UTF-8").GetBytes(pToEncrypt);     
        
            //建立加密对象的密钥和偏移量      
            //原文使用ASCIIEncoding.ASCII方法的GetBytes方法      
            //使得输入密码必须输入英文文本      
            des.Key = ASCIIEncoding.ASCII.GetBytes(sKey);     
            des.IV = ASCIIEncoding.ASCII.GetBytes(sKey);     
            MemoryStream ms = new MemoryStream();     
            CryptoStream cs = new CryptoStream(ms, des.CreateEncryptor(), CryptoStreamMode.Write);     
        
            cs.Write(inputByteArray, 0, inputByteArray.Length);     
            cs.FlushFinalBlock();     
        
            StringBuilder ret = new StringBuilder();     
            foreach (byte b in ms.ToArray())     
            {     
                ret.AppendFormat("{0:X2}", b);     
            }     
            ret.ToString();     
            return ret.ToString();     
        }    
        #endregion    
      
        #region DESDeCode DES解密     
        public static string DESDeCode(string pToDecrypt, string sKey)     
        {     
            //    HttpContext.Current.Response.Write(pToDecrypt + "<br>" + sKey);     
            //    HttpContext.Current.Response.End();     
            DESCryptoServiceProvider des = new DESCryptoServiceProvider();     
        
            byte[] inputByteArray = new byte[pToDecrypt.Length / 2];     
            for (int x = 0; x < pToDecrypt.Length / 2; x++)     
            {     
                int i = (Convert.ToInt32(pToDecrypt.Substring(x * 2, 2), 16));     
                inputByteArray[x] = (byte)i;     
            }     
        
            des.Key = ASCIIEncoding.ASCII.GetBytes(sKey);     
            des.IV = ASCIIEncoding.ASCII.GetBytes(sKey);     
           MemoryStream ms = new MemoryStream();     
            CryptoStream cs = new CryptoStream(ms, des.CreateDecryptor(), CryptoStreamMode.Write);     
            cs.Write(inputByteArray, 0, inputByteArray.Length);     
            cs.FlushFinalBlock();     
        
            StringBuilder ret = new StringBuilder();     
        
           // return HttpContext.Current.Server.UrlDecode(System.Text.Encoding.Default.GetString(ms.ToArray()));  
            return System.Text.Encoding.Default.GetString(ms.ToArray());    
        }    
        #endregion  

    Java代码如下

    <span style="color: #888888;">import javax.crypto.Cipher;     
    import javax.crypto.SecretKey;     
    import javax.crypto.SecretKeyFactory;     
    import javax.crypto.spec.DESKeySpec;     
    import javax.crypto.spec.IvParameterSpec;     
        
        
    public class Des {     
        private byte[] desKey;     
        
             
        //解密数据     
        public static String decrypt(String message,String key) throws Exception {     
                  
                byte[] bytesrc =convertHexString(message);        
                Cipher cipher = Cipher.getInstance("DES/CBC/PKCS5Padding");         
                DESKeySpec desKeySpec = new DESKeySpec(key.getBytes("UTF-8"));        
                SecretKeyFactory keyFactory = SecretKeyFactory.getInstance("DES");        
                SecretKey secretKey = keyFactory.generateSecret(desKeySpec);        
                IvParameterSpec iv = new IvParameterSpec(key.getBytes("UTF-8"));     
                         
                cipher.init(Cipher.DECRYPT_MODE, secretKey, iv);           
                   
                byte[] retByte = cipher.doFinal(bytesrc);          
                return new String(retByte);      
        }     
        
        public static byte[] encrypt(String message, String key)     
                throws Exception {     
            Cipher cipher = Cipher.getInstance("DES/CBC/PKCS5Padding");     
        
            DESKeySpec desKeySpec = new DESKeySpec(key.getBytes("UTF-8"));     
        
            SecretKeyFactory keyFactory = SecretKeyFactory.getInstance("DES");     
            SecretKey secretKey = keyFactory.generateSecret(desKeySpec);     
            IvParameterSpec iv = new IvParameterSpec(key.getBytes("UTF-8"));     
            cipher.init(Cipher.ENCRYPT_MODE, secretKey, iv);     
        
            return cipher.doFinal(message.getBytes("UTF-8"));     
        }     
             
        public static byte[] convertHexString(String ss)      
        {      
        byte digest[] = new byte[ss.length() / 2];      
        for(int i = 0; i < digest.length; i++)      
        {      
        String byteString = ss.substring(2 * i, 2 * i + 2);      
        int byteValue = Integer.parseInt(byteString, 16);      
        digest[i] = (byte)byteValue;      
        }      
        
        return digest;      
        }      
        
        
        public static void main(String[] args) throws Exception {     
            String key = "11111111";     
            String value="aa";     
            String jiami=java.net.URLEncoder.encode(value, "utf-8").toLowerCase();     
                 
            System.out.println("加密数据:"+jiami);     
            String a=toHexString(encrypt(jiami, key)).toUpperCase();     
                 
             
            System.out.println("加密后的数据为:"+a);     
            String b=java.net.URLDecoder.decode(decrypt(a,key), "utf-8") ;     
            System.out.println("解密后的数据:"+b);     
        
        }     
        
             
        public static String toHexString(byte b[]) {     
            StringBuffer hexString = new StringBuffer();     
            for (int i = 0; i < b.length; i++) {     
                String plainText = Integer.toHexString(0xff & b[i]);     
                if (plainText.length() < 2)     
                    plainText = "0" + plainText;     
                hexString.append(plainText);     
            }     
                 
            return hexString.toString();     
        }     
        
    }    
    </span>  

     本人博客提供高质量代码,质量好,不做作。

  • 相关阅读:
    eNSP——配置Trunk接口
    eNSP——VLAN基础配置和Access
    C# WinForm多线程(三)---- Control.Invoke[转]
    C# 在字符串前加了$,这个 dollar 符号有什么用?美元符号是什么意思
    软件工程领域工程硕士培养方案
    C#中SHOWDIALOG()与SHOW()的区别_模态与非模态_销毁与释放
    HTTP状态代码code(错误代码集合)返回错误代码集合
    OpenCV26HoughCircles 霍夫圆变换原理及圆检测
    OpenCV25-判断一个点是否在多边形的内部_点多边形测试pointPolygonTest
    OpenCV24霍夫直线变换API介绍_3.1.0
  • 原文地址:https://www.cnblogs.com/sexintercourse/p/6063387.html
Copyright © 2011-2022 走看看