Java、C#双语版配套AES加解密示例

转载 2017年01月03日 13:36:12
这年头找个正经能用的东西那是真难,网上一搜索一大堆,正经能用的没几个,得,最后还是得靠自己,正巧遇上需要AES加解密的地方了,而且还是Java和C#间的相互加解密操作,这里做个备忘

  这里采用的加解密使用base64转码方法,ECB模式,PKCS5Padding填充,密码必须是16位,否则会报错哈

  模式:Java的ECB对应C#的System.Security.Cryptography.CipherMode.ECB

  填充方法:Java的PKCS5Padding对应C#System.Security.Cryptography.PaddingMode.PKCS7

  Java和C#版的加解密是互通的,也就是能相互加解密,编码明确指定了采用UTF-8,有需要其他编码方法的请自行扩展

Java版

复制代码
package nb.tmall.util;

import java.security.NoSuchAlgorithmException;
import java.security.SecureRandom;

import javax.crypto.*;
import javax.crypto.spec.SecretKeySpec;

import sun.misc.*;

@SuppressWarnings("restriction")
public class EncryptUtil {

    public static String aesEncrypt(String str, String key) throws Exception {
        if (str == null || key == null) return null;
        Cipher cipher = Cipher.getInstance("AES/ECB/PKCS5Padding");
        cipher.init(Cipher.ENCRYPT_MODE, new SecretKeySpec(key.getBytes("utf-8"), "AES"));
        byte[] bytes = cipher.doFinal(str.getBytes("utf-8"));
        return new BASE64Encoder().encode(bytes);
    }

    public static String aesDecrypt(String str, String key) throws Exception {
        if (str == null || key == null) return null;
        Cipher cipher = Cipher.getInstance("AES/ECB/PKCS5Padding");
        cipher.init(Cipher.DECRYPT_MODE, new SecretKeySpec(key.getBytes("utf-8"), "AES"));
        byte[] bytes = new BASE64Decoder().decodeBuffer(str);
        bytes = cipher.doFinal(bytes);
        return new String(bytes, "utf-8");
    }
}
复制代码

C#版

复制代码
using System;
using System.Security.Cryptography;
using System.Text;

namespace CSharp.Util.Security
{
   
        /// <summary>
        ///  AES 加密
        /// </summary>
        /// <param name="str"></param>
        /// <param name="key"></param>
        /// <returns></returns>
        public static string AesEncrypt(string str, string key)
        {
            if (string.IsNullOrEmpty(str)) return null;
            Byte[] toEncryptArray = Encoding.UTF8.GetBytes(str);

            System.Security.Cryptography.RijndaelManaged rm = new System.Security.Cryptography.RijndaelManaged
            {
                Key = Encoding.UTF8.GetBytes(key),
                Mode = System.Security.Cryptography.CipherMode.ECB,
                Padding = System.Security.Cryptography.PaddingMode.PKCS7
            };

            System.Security.Cryptography.ICryptoTransform cTransform = rm.CreateEncryptor();
            Byte[] resultArray = cTransform.TransformFinalBlock(toEncryptArray, 0, toEncryptArray.Length);

            return Convert.ToBase64String(resultArray, 0, resultArray.Length);
        }

        /// <summary>
        ///  AES 解密
        /// </summary>
        /// <param name="str"></param>
        /// <param name="key"></param>
        /// <returns></returns>
        public static string AesDecrypt(string str, string key)
        {
            if (string.IsNullOrEmpty(str)) return null;
            Byte[] toEncryptArray = Convert.FromBase64String(str);

            System.Security.Cryptography.RijndaelManaged rm = new System.Security.Cryptography.RijndaelManaged
            {
                Key = Encoding.UTF8.GetBytes(key),
                Mode = System.Security.Cryptography.CipherMode.ECB,
                Padding = System.Security.Cryptography.PaddingMode.PKCS7
            };

            System.Security.Cryptography.ICryptoTransform cTransform = rm.CreateDecryptor();
            Byte[] resultArray = cTransform.TransformFinalBlock(toEncryptArray, 0, toEncryptArray.Length);

            return Encoding.UTF8.GetString(resultArray);
        }
    }
}
复制代码

 

转自:http://www.cnblogs.com/lzrabbit/p/3639503.html

AES通用加密算法(C#)

  • 2017年08月23日 16:11
  • 70KB
  • 下载

AES 加密算法的 C 语言实现

这个AES 的C 语言实现,是从linux 中port 而来,放在这里方便自己日后使用。 很容易把这个code 转为为C++ 的封装。       aes.h a#ifndef __AES...
  • jasontome
  • jasontome
  • 2012年04月14日 10:51
  • 865

AES的C#实现(用ECB和CBC模式分别完成加密解密)

  • 2016年07月27日 16:59
  • 50KB
  • 下载

C# 实现AES算法

本文所使用的AES为官方提供的原型类 本文主要讲如何调用 并不涉及 具体原理 这里为调用 using System; using System.Collections.Generic; us...
  • lkjasdgfh
  • lkjasdgfh
  • 2015年05月12日 17:34
  • 1008

用C#实现AES加密算法

http://blog.csdn.net/asxinyu_usst/article/details/4924207 好久没有逛论坛了,找工作比较累啊。毕业就意味这失业。也好久没写文章了,今天到论...
  • mituan1234567
  • mituan1234567
  • 2014年03月17日 15:31
  • 401

AES128算法

转自http://blog.sina.com.cn/s/blog_60cf051301015orf.html 在网上找了一大堆资料,总有把AES加密有点弄懂了。这里推荐一个人写的博客...
  • ctelinla
  • ctelinla
  • 2016年08月01日 10:52
  • 584

[转帖]C#使用AES加密算法源代码

本文的代码下载:msdnmag200311AES.exe (143KB)本文假设你熟悉 C# 和 位(bit)操作。 摘要   AES(The Advanced Encryption St___and...
  • zhirom
  • zhirom
  • 2009年06月24日 12:02
  • 1597

C# 实现的 AES 加密算法

1. [代码]AESEncryptionUtility.cs
  • znb769525443
  • znb769525443
  • 2014年07月17日 16:38
  • 387

C#中使用DES和AES加密解密

C#中使用DES和AES加密解密2008-01-12 09:37using System;using System.Text;using System.Security.Cryptography;us...
  • wyaspnet
  • wyaspnet
  • 2009年07月07日 19:31
  • 2009

Java、C#双语版配套AES加解密示例

这年头找个正经能用的东西那是真难,网上一搜索一大堆,正经能用的没几个,得,最后还是得靠自己,正巧遇上需要AES加解密的地方了,而且还是Java和C#间的相互加解密操作,这里做个备忘   这里采用...
  • weiling_shen
  • weiling_shen
  • 2014年09月28日 16:51
  • 540
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:Java、C#双语版配套AES加解密示例
举报原因:
原因补充:

(最多只允许输入30个字)