网上资料显示,下一代加密技术会围绕着AES技术进行。初出茅庐,学习编写了加密代码,如下所示

package com.bao.tools.encryption;

import java.security.SecureRandom;
import java.util.Scanner;

import javax.crypto.Cipher;
import javax.crypto.KeyGenerator;
import javax.crypto.SecretKey;
import javax.crypto.spec.SecretKeySpec;

import org.junit.Test;

/**
 * @title AES加密解密算法
 * @description 高级加密标准,对称算法,是下一代的加密算法标准,速度快,安全级别高,现在 AES 标准的一个实现是 Rijndael 算法
 * @author Administrator
 * @date 2015-7-16
 */
public class CAES {
    
    /**
     *
     * @param key(生成键字符串)
     * @param value(加密的文字字符串)
     * @param mode
     *            (true:加密;false:解密)
     * @return
     */
    public static byte[] setEncrypted(String key, byte[] value, boolean mode)throws Exception {
        if (key == null || value == null)
            return null;
        // --------- 生成密码键
        // 创建AES通用键模式
        KeyGenerator generator = KeyGenerator.getInstance("AES");
        // 初始化通用键(256位,创建随机编码键)
        generator.init(128, new SecureRandom(key.getBytes("UTF-8")));
        // 创建安全键实例
        SecretKey keys = generator.generateKey();
        // 创建密匙规范的实例
        SecretKeySpec keySpec = new SecretKeySpec(keys.getEncoded(), "AES");

// ----------开始加密/解密内容
        Cipher cipher = Cipher.getInstance("AES");// 创建AES内容加密实例
        if (mode) {
            cipher.init(Cipher.ENCRYPT_MODE, keySpec);// 加密
        } else {
            cipher.init(Cipher.DECRYPT_MODE, keySpec);// 解密
        }
        byte[] result = cipher.doFinal(value);
        return result;//注意:返回一定是byte数组,否则报 16位字节异常 !
    }

/*
     * 测试
     */
    @Test
    public void test() throws Exception {
        Scanner scanner = new Scanner(System.in);
        System.out.println("-----------AES安全加密测试-------------\n请输入主键(字符串):");
        String key = scanner.nextLine();
        System.out.println("请输入要加密的内容:");
        String value=scanner.nextLine();
        System.out.println("---------运行结果-----------");
        
        //如果要求安全系数更高且暂时不用解密,可以使用BASE64编码后再进行AES加密
//        value = CBase64.setEncrypted(value);
        
        byte[] message = setEncrypted(key, value.getBytes(), true);//执行加密方法
        System.out.println("------加密字符为:"+new String(message));//在这里将字节数组转换为字符串显示出来
                
        System.out.println("+++++++解 密 :"+new String(setEncrypted(key, message, false)));
        
        scanner.close();
    }
}
运行结果:

注明:网上找的资料,搞了大半个晚上才发现,byte存取很重要,不然会报16倍数字节异常 !

AES加密算法-128位高安全,高速度的更多相关文章

  1. C# AES的128位、192位、256位加密

    C# AES的128位.192位.256位加密   AES加密原理,这里就不解释了,自行百度.这里主要细说AES的CBC加密模式下的128位.192位.256位加密区别,参考 对称加密和分组加密中的四 ...

  2. python3.7 AES.MODE_ECB(128位) pkcs5padding 加密算法

    用惯用的写法总报TypeEerror错误,经过调试,总算成功啦,直接上代码 TypeError("Object type %s cannot be passed to C code" ...

  3. C# 128位AES 加密解密 (转)

    /// AES加密 2         /// </summary> 3         /// <param name="inputdata">输入的数据 ...

  4. .NET AES加解密(128位)

    AES加密(128位): /// <summary> /// 有密码的AES加密 /// </summary> internal static string Encrypt(s ...

  5. php AES cbc模式 pkcs7 128位加密解密(微信小程序)

    PHP AES CBC模式PKCS7 128位加密 加密: $key = '1234567812345678'; $iv = '1234567890123456'; $message = '12345 ...

  6. Microsoft(C)注册服务器(32位)CPU占用高

    Microsoft(C)注册服务器(32位)CPU占用高 摘自:https://blog.csdn.net/jtsqrj/article/details/83034252 2018年10月12日 23 ...

  7. 参考别人的代码写的aes加密,记录一下(AES,ECB模式,填充PKCS5Padding,数据块128位,偏移量无,以hex16进制输出)

    package org.jimmy.autosearch2019.test; import java.security.SecureRandom; import javax.crypto.Cipher ...

  8. SGC强制最低128位加密,公钥支持ECC加密算法的SSL证书

      Pro SSL证书,验证企业域名所有权和企业身份信息,采用SGC(服务器门控)技术强制128位以上至256位加密,属于企业OV验证级专业版(Pro) SSL证书:即使用户使用低版本浏览器(比如浏览 ...

  9. AES 加密算法的原理详解

    AES 加密算法的原理详解 本教程摘选自 https://blog.csdn.net/qq_28205153/article/details/55798628 的原理部分. AES简介 高级加密标准( ...

随机推荐

  1. mybatis(一)安装

    1.创建web项目,添加jar包 2.创建实验表user_t 3.在src下创建conf.xml文件,如下 <?xml version="1.0" encoding=&quo ...

  2. ASP.NET MVC(三)

    ASP.NET Routing 模块的责任是将传入的浏览器请求映射为特有的MVC controller actions. 请求 URL 当我们不使用路由的时候 请求 http://server/app ...

  3. PHP自动生成后台导航网址的最佳方法

    'http://www.jbxue.com'=> '脚本学堂首页', </script>

  4. 【GDI+】 线段 文字 定位的问题

    遇到一个看起来很简单的问题: 给定两个点,和一组文字,希望文字显示在线的附近并且居中显示.期望像这样的效果 进一步的抽象是: 1.根据文字的长度和高度,以及两个点,来获得文字的定位点(左上角点)的 2 ...

  5. DELPHI出现无法加载dclite50.bpl的解决办法(转)

    现象: Borland Integrated Translation Environment 加载出错 解决办法: 我的电脑--->(鼠标右键)属性--->高级--->(性能)设置- ...

  6. Linux和Windows远程桌面互连

    1.Ubuntu 连 windows    W.1 Windows设置允许远程桌面连接    U.1 Ubuntu设置 apt-get install rdesktop    U.2 Ubuntu连接 ...

  7. java对象的序列化与反序列化使用

    1.Java序列化与反序列化  Java序列化是指把Java对象转换为字节序列的过程:而Java反序列化是指把字节序列恢复为Java对象的过程. 2.为什么需要序列化与反序列化 我们知道,当两个进程进 ...

  8. 浅析Java的HashCode,以及equals

    1.JDK规定,equals相等的两个对象hashCode也必须相等,这两个方法都是从Object上面继承而来的,通过观察JDK源码可以发现Object的equals方法是对2个对象的地址(逻辑地址, ...

  9. post 405 method not allowed

    HTTP 405 错误 – 方法不被允许 (Method not allowed) 介绍 HTTP 协议定义一些方法,以指明为获取客户端(如您的浏览器或我们的 CheckUpDown 机器人)所指定的 ...

  10. DataGuard主备归档存在gap的处理办法

    DataGuard主备之间可能由于网络等原因,造成备库和主库之间的归档日志不一致,这样就产生了gap. 解决gap的步骤: 1.在备库获得gap的详细信息 2.将需要的归档日志从主库拷贝到备库 3.备 ...