`
jack.zhao829
  • 浏览: 24681 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

AES加密解密

    博客分类:
  • java
阅读更多

 

import javax.crypto.Cipher;

import javax.crypto.KeyGenerator;

import javax.crypto.SecretKey;

import javax.crypto.spec.SecretKeySpec;

import java.security.SecureRandom;

 

/**

 * AES加解密算法

 */

public class AesUtils {

    //用于加密的密钥

    private static final String PASSWORD_AES_KEY="123456789";

 

    /**

     * 将url传递的参数用AES方式加密

     * @param url

     * @return

     */

    public static String aesEncryptUrl(String url){

        try{

            if(StringUtils.isEmpty(url)){

                return null;

            }

            return parseByte2HexStr(encrypt(url,PASSWORD_AES_KEY));

        }catch(Exception ex){

            if(StringUtils.isEmpty(url)){

                return null;

            }

        }

        return null;

    }

    /**

     * 将url传递的参数用AES方式解密

     * @param url

     * @return

     */

    public static String aesDecrypt(String url){

        try{

            if(StringUtils.isEmpty(url)){

                return null;

            }

            byte[] decryptFrom=parseHexStr2Byte(url);

            System.out.println("decryptFrom"+decryptFrom.length);

            byte[] deryptResult=decrypt(decryptFrom,PASSWORD_AES_KEY);

            System.out.println(deryptResult);

            return new String(deryptResult);

        }catch(Exception ex){

 

        }

        return null;

    }

    /**

     * 加密

     *

     * @param content 需要加密的内容

     * @param password  加密密码

     * @return

     */

    public static byte[] encrypt(String content, String password) {

        try {

            KeyGenerator kgen = KeyGenerator.getInstance("AES");

            SecureRandom secureRandom=SecureRandom.getInstance("SHA1PRNG");

            secureRandom.setSeed(password.getBytes("UTF-8"));

            kgen.init(128, secureRandom);

            SecretKey secretKey = kgen.generateKey();

            byte[] enCodeFormat = secretKey.getEncoded();

            SecretKeySpec key = new SecretKeySpec(enCodeFormat, "AES");

            Cipher cipher = Cipher.getInstance("AES");// 创建密码器

            byte[] byteContent = content.getBytes("utf-8");

            cipher.init(Cipher.ENCRYPT_MODE, key);// 初始化

            byte[] result = cipher.doFinal(byteContent);

            return result; // 加密

        } catch (Exception e) {

            e.printStackTrace();

        }

        return null;

    }

    /**解密

     * @param content  待解密内容

     * @param password 解密密钥

     * @return

     */

    public static  byte[] decrypt(byte[] content, String password) {

        try {

            KeyGenerator kgen = KeyGenerator.getInstance("AES");

            SecureRandom secureRandom=SecureRandom.getInstance("SHA1PRNG");

            secureRandom.setSeed(password.getBytes("UTF-8"));

            kgen.init(128, secureRandom);

            SecretKey secretKey = kgen.generateKey();

            byte[] enCodeFormat = secretKey.getEncoded();

            SecretKeySpec key = new SecretKeySpec(enCodeFormat, "AES");

            Cipher cipher = Cipher.getInstance("AES");// 创建密码器

            cipher.init(Cipher.DECRYPT_MODE, key);// 初始化

            byte[] result = cipher.doFinal(content);

            return result; // 加密

        } catch (Exception e) {

            e.printStackTrace();

        }

        return null;

    }

 

    /**将二进制转换成16进制

     * @param buf

     * @return

     */

    public static  String parseByte2HexStr(byte buf[]) {

        StringBuffer sb = new StringBuffer();

        for (int i = 0; i < buf.length; i++) {

            String hex = Integer.toHexString(buf[i] & 0xFF);

            if (hex.length() == 1) {

                hex = '0' + hex;

            }

            sb.append(hex.toUpperCase());

        }

        return sb.toString();

    }

 

    /**将16进制转换为二进制

     * @param hexStr

     * @return

     */

    public static byte[] parseHexStr2Byte(String hexStr) {

        if (hexStr.length() < 1)

            return null;

        byte[] result = new byte[hexStr.length()/2];

        for (int i = 0;i< hexStr.length()/2; i++) {

            int high = Integer.parseInt(hexStr.substring(i*2, i*2+1), 16);

            int low = Integer.parseInt(hexStr.substring(i*2+1, i*2+2), 16);

            result[i] = (byte) (high * 16 + low);

        }

        return result;

    }

}

 

分享到:
评论

相关推荐

    Qt实现AES加密解密

    这个程序应当包含了上述知识点的具体应用,你可以通过阅读源代码、编译和运行来进一步理解和学习AES加密解密的实现细节。这个实战例程可以帮助开发者更好地掌握Qt环境下的加密解密操作,提高数据安全保护能力。

    AES加密解密实验报告

    《AES加密解密实验报告》 AES,全称为高级加密标准(Advanced Encryption Standard),是密码学领域中的一个重要标准,由美国联邦政府采纳,用于替换原有的DES加密算法。AES由比利时密码学家Joan Daemen和Vincent ...

    用C语言实现的AES加密解密算法

    在本项目中,"用C语言实现的AES加密解密算法"是针对AES算法的一种C语言实现,这允许开发者在不依赖特定库的情况下,在C环境中进行数据的加密和解密操作。 首先,我们需要理解AES的工作原理。AES的核心是基于替换和...

    php+uni-app AES加密解密.rar

    在uni-app中,可以使用JavaScript的crypto-js库来实现AES加密解密。首先,你需要通过HBuilderX引入该库,然后在uni-app代码中使用: ```javascript const CryptoJS = require('crypto-js'); const key = 'your_...

    uniapp 前后端AES加密解密.rar

    本压缩包"uniapp 前后端AES加密解密.rar"正是为了解决这一问题,它包含了在uniapp环境下实现前后端AES加密解密的方法。AES(Advanced Encryption Standard),即高级加密标准,是一种广泛使用的对称加密算法,具有...

    AES加密解密 for vba

    ' 功能: AES加密解密 password&lt;==&gt;hwWpiegaWDeE8kTlb/5BQg== , 8705a989e81a583784f244e56ffe4142 ' [Str] 预备转换的byte ' [StrKey] 16位的密钥 ' [StrIv] 16位的偏移 ' [Encrypt] 加密(缺省值)还是解密 ' ...

    C语言实现的AES加密解密

    标题 "C语言实现的AES加密解密" 涉及到的是高级加密标准(Advanced Encryption Standard,简称AES),这是一种广泛使用的对称加密算法,用于保护数据的安全性。AES由NIST(美国国家标准与技术研究所)在2001年标准化...

    VB.NET实现AES加密解密

    VB.NET实现AES加密解密代码,可直接使用

    python实现AES加密解密

    本文实例为大家分享了python实现AES加密解密的具体代码,供大家参考,具体内容如下 (1)对于AES加密解密相关知识 (2)实现的功能就是输入0-16个字符,然后经过AES的加密解密最后可以得到原先的输入,运行的结果...

    本地图片AES加密解密

    "本地图片AES加密解密"是一个针对这个问题提出的技术方案,旨在保护存储在本地设备上的图片不被未经授权的第三方访问。AES(Advanced Encryption Standard)加密是一种广泛应用的对称加密算法,因其高效和安全性而...

    C# AES加密解密小工具

    本项目“C# AES加密解密小工具”提供了一个简单的AES ECB模式加密和解密实现,适用于对文本文件进行安全处理。 首先,AES是一种块密码,它将明文分成128位的块进行操作。ECB(Electronic Codebook)模式是最基础的...

    AES加密解密算法转换工具,最大支持256bit长度的密钥.rar

    AES加密解密轮转算法工具,最大支持256bit长度的密钥,明文支持HEX和字串。可供学习设计参考。

    C语言实现AES加密解密

    在C语言中实现AES加密解密是一项基础且重要的技能,特别是在嵌入式系统和低级别编程中。 AES的核心是一个名为Rijndael的密码,由比利时密码学家Joan Daemen和Vincent Rijmen设计。它的工作原理基于一系列的替换和...

    c/c++与java互通 AES加密解密

    "C/C++与Java互通AES加密解密"的主题就是这两个议题的结合。AES(Advanced Encryption Standard),即高级加密标准,是一种广泛使用的对称加密算法,提供了强效的数据保护。本话题主要探讨如何在C/C++和Java之间使用...

    AES加密解密验证工具(支持各种加密模式).exe

    AES加密解密验证工具(支持各种加密模式)

    VB6 AES加密解密文本串和文件的DLL动态库

    本篇文章将详细介绍如何在VB6环境中使用AES加密解密文本串和文件的DLL动态库。 首先,AES是一种块密码,它以128位的数据块为单位进行操作。AES支持三种不同的密钥长度:128位、192位和256位,其中128位是最常见的...

    MFC实现的AES加密解密程序

    **AES加密解密程序概述** AES(Advanced Encryption Standard),即高级加密标准,是目前广泛使用的对称加密算法,因其高效性和安全性而备受青睐。MFC(Microsoft Foundation Classes)是微软提供的一套C++库,用于...

    AES加密解密算法C# JAVA nodejs通用

    C# JAVA nodejs通用的AES加密解密算法,考虑到实际使用过程中由于客户端和服务端使用的语言不一样而又需要对数据进行加密和解密的情况,特此总结了C# JAVA nodejs通用的AES加密解密算法,供需要者参考。

    aes加密解密

    这套资源涵盖了AES加密解密在Java和JavaScript两端的应用,使得数据在客户端与服务器之间的传输更加安全。 在Java中,AES加密通常涉及以下步骤: 1. **密钥生成**:首先需要一个密钥,可以使用`javax.crypto....

    AES加密解密算法的Java实现.doc

    ### AES加密解密算法的Java实现 #### 一、引言 高级加密标准(Advanced Encryption Standard,简称AES)是一种对称加密算法,被广泛应用于数据安全领域。它是由比利时密码学家Joan Daemen和Vincent Rijmen设计,并...

Global site tag (gtag.js) - Google Analytics