文档章节

java 简单的加解密操作

不要问我-我是谁
 不要问我-我是谁
发布于 2016/03/14 15:45
字数 548
阅读 38
收藏 1
import java.io.ByteArrayOutputStream;

/**
 * @see 这是一个加解密的工具类 
 * 加密中包含中文时,先进行其他编码,URLEncoder.encode(str) 然后在进行加密操作
 * 解密完成后再使用URLDecoder.decode 解码
 * @version 1.0.0
 * @since 2016-3-14 15:39:33
 * @author zuoxin.xiao email:xiao574182979@126.com
 */
public final class EncryptUtil {
    
    public static char[] base64EncodeChars = new char[] { 'A', 'B', 'C', 'D',
            'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q',
            'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z', 'a', 'b', 'c', 'd',
            'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q',
            'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z', '0', '1', '2', '3',
            '4', '5', '6', '7', '8', '9', '+', '/','=','%' };

    public static byte[] base64DecodeChars = new byte[] { -1, -1, -1, -1, -1,
            -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
            -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 65, -1,
            -1, -1, -1, -1, 62, -1, -1, -1, 63, 52, 53, 54, 55, 56, 57, 58, 59,
            60, 61, -1, -1, -1, 64, -1, -1, -1, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9,
            10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, -1,
            -1, -1, -1, -1, -1, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37,
            38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, -1, -1, -1,
            -1, -1 };
    /**
     * @see  加密中包含中文时,先进行其他编码,URLEncoder.encode(str) 然后在进行加密操作
     * @param value
     * @return
     */
    public static String encode(String value){
        String output = "";
        char chr1,chr2 = 0,chr3=0 ;
        int enc1, enc2, enc3, enc4;
        int i = 0;
        
        do{
            char[] values = value.toCharArray();
            chr1 = values[i++];
            boolean isChr2Error = false;
            boolean isChr3Error = false;
            try {
                chr2 = values[i++];
            } catch (Exception e) {
                isChr2Error = true;
            }
            
            try {
                chr3 = values[i++];
            } catch (Exception e) {
                isChr3Error = true;
            }
            
            enc1 = chr1 >> 2;
            enc2 = ((chr1 & 3) << 4) | (chr2 >> 4);
            enc3 = ((chr2 & 15) << 2) | (chr3 >> 6);
            enc4 = chr3 & 63;
            
            if(isChr2Error){
                enc3 = enc4 = 64;
            } else if(isChr3Error){
                enc4 = 64;
            }
            
            output = output + base64EncodeChars[enc1] + base64EncodeChars[enc2]
                    + base64EncodeChars[enc3] + base64EncodeChars[enc4];
            
        }while( i < value.length());
        
        return output;
    }
    
    
    /**
     * @see 解密 若包含中文时完成后再使用URLDecoder.decode 解码
     * 
     * @param str
     * @return
     */
    public static byte[] decode(String str) {
        byte[] data = str.getBytes();
        int len = data.length;
        ByteArrayOutputStream buf = new ByteArrayOutputStream(len);
        int i = 0;
        int b1, b2, b3, b4;

        while (i < len) {
            do {
                b1 = base64DecodeChars[data[i++]];
            } while (i < len && b1 == -1);
            if (b1 == -1) {
                break;
            }

            do {
                b2 = base64DecodeChars[data[i++]];
            } while (i < len && b2 == -1);
            if (b2 == -1) {
                break;
            }
            buf.write((int) ((b1 << 2) | ((b2 & 0x30) >>> 4)));

            do {
                b3 = data[i++];
                if (b3 == 61) {
                    return buf.toByteArray();
                }
                b3 = base64DecodeChars[b3];
            } while (i < len && b3 == -1);
            if (b3 == -1) {
                break;
            }
            buf.write((int) (((b2 & 0x0f) << 4) | ((b3 & 0x3c) >>> 2)));

            do {
                b4 = data[i++];
                if (b4 == 61) {
                    return buf.toByteArray();
                }
                b4 = base64DecodeChars[b4];
            } while (i < len && b4 == -1);
            if (b4 == -1) {
                break;
            }
            
            buf.write( (((b3 & 0x03) << 6) | b4));
        }
        return buf.toByteArray();
    }
}


© 著作权归作者所有

不要问我-我是谁
粉丝 2
博文 17
码字总数 5066
作品 0
黄浦
程序员
私信 提问
JDK1.8.0_151的无限制强度加密策略文件变动

JDK1.8.0_151的无限制强度加密策略文件变动 JDK1.8.0151无需去官网下载 这个jar包,只需要修改这目录下的文件配置即可。 随着越来越多的第三方工具只支持 JDK8,最近公司也计划从 JDK7 升级到...

指尖Coding
03/22
93
0
有没有办法可以文件上传之前用js对文件进行加密(aes加密或者des加密都行),java后台可以根据前台传过来的秘钥对加密文件进行解密?

我现在的问题是想在浏览器上传文件之前对文件进行加密操作,java后台接收到文件之后解密文件。暂时采用strus2文件上传机制,后台是java,java端加解密已经解决,我想知道js能不能做到文件加密...

新手上路吧
2014/09/24
1K
5
C#与Java AES 加密解密

前几天对接Java接口,需要C#加密参数,Java解密。奈何网上找了一堆大同小异的加解密方法都跟Jaca加密的密文不一致,Java接口也无法解密,直到看见上面链接的第二种方法。能够正常的解密Java加...

温柔的悬念。
2018/12/09
0
0
justlive1/oxygen

oxygen 轻量级Java框架 介绍 一个轻量级Java框架 oxygen-core 核心部分 基于cglib的aop实现 提供缓存管理和基于注解的缓存,内置LocalCache和Ehcache实现,可扩展 配置管理,支持${attrs.key...

justlive1
2018/10/08
0
0
Android外部文件加解密及应用实践

有这样的应用场景,当我们把一些重要文件放到asset文件夹中时,把.apk解压是可以直接拿到这个文件的,一些涉及到重要信息的文件我们并不想被反编译拿去,这个时候需要先对文件进行加密,然后...

C6C
2018/05/08
0
0

没有更多内容

加载失败,请刷新页面

加载更多

Spring Boot + Mybatis-Plus 集成与使用(二)

前言: 本章节介绍MyBatis-Puls的CRUD使用。在开始之前,先简单讲解下上章节关于Spring Boot是如何自动配置MyBatis-Plus。 一、自动配置 当Spring Boot应用从主方法main()启动后,首先加载S...

伴学编程
昨天
7
0
用最通俗的方法讲spring [一] ──── AOP

@[TOC](用最通俗的方法讲spring [一] ──── AOP) 写这个系列的目的(可以跳过不看) 自己写这个系列的目的,是因为自己是个比较笨的人,我曾一度怀疑自己的智商不适合干编程这个行业.因为在我...

小贼贼子
昨天
7
0
Flutter系列之在 macOS 上安装和配置 Flutter 开发环境

本文为Flutter开发环境在macOS下安装全过程: 一、系统配置要求 想要安装并运行 Flutter,你的开发环境需要最低满足以下要求: 操作系统:macOS(64位) 磁盘空间:700 MB(不包含 IDE 或其余...

過愙
昨天
6
0
OSChina 周六乱弹 —— 早上儿子问我他是怎么来的

Osc乱弹歌单(2019)请戳(这里) 【今日歌曲】 @凉小生 :#今日歌曲推荐# 少点戾气,愿你和这个世界温柔以待。中岛美嘉的单曲《僕が死のうと思ったのは (曾经我也想过一了百了)》 《僕が死の...

小小编辑
昨天
2.6K
16
Excption与Error包结构,OOM 你遇到过哪些情况,SOF 你遇到过哪些情况

Throwable 是 Java 中所有错误与异常的超类,Throwable 包含两个子类,Error 与 Exception 。用于指示发生了异常情况。 Java 抛出的 Throwable 可以分成三种类型。 被检查异常(checked Exc...

Garphy
昨天
42
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部