base64加密与URL

base64加密与URL
开发WEB的时候,比较常用的单向加密方式是MD5,比较常用的双向加密方法是BASE64。
常用的BASE64加密方法是JDK1.5自带的,写成Util如下:
加密
public static String base64Encode(String str) {
sun.misc.BASE64Encoder encoder = new sun.misc.BASE64Encoder();
return encoder.encodeBuffer(str.getBytes()).trim();
}

public static String base64Decode(String str) {
sun.misc.BASE64Decoder dec = new sun.misc.BASE64Decoder();
try {
   return new String(dec.decodeBuffer(str));
} catch (IOException io) {
   throw new RuntimeException(io.getMessage(), io.getCause());
}
}

这个方式不错,但是有时加密出的字符串在URL传递的时候会有问题(如=号),会被URL当做是特殊的自负而转掉,就算用
UrlEncode也不是很爽。

后来发现了一个新的改进版本的BASE64方法:

public static String base64Encode(String str) {
byte[] bytes = UrlBase64.encode(str.getBytes());
return new String(bytes);
}

public static String base64Decode(String str) {
byte[] bytes = UrlBase64.decode(str.getBytes());
return new String(bytes);
}

这里用到的包org.bouncycastle.util.encoders.UrlBase64是来自于bcprov-jdk15-136.jar
这里也贴个下载地址吧:)
http://mirrors.ibiblio.org/pub/mirrors/maven/bouncycastle/jars/bcprov-jdk15-136.jar
这种方式就能解决BASE64在URL传递中遇到的问题啦:)

 

 

 

新的解决方法:

加密算法基于Base64,但为了便于在URL中使用,对该算法进行了变异处理。加/解密的工具类封装在base64utils.jar包中(请下载),另专门有一个类URLEncypt简化字符串的加密和解密。

如下:

public static String encode(String str) {
        String ret = null;
        if (str == null || str.trim().length() == 0) return str;
        try {
            byte[] bytes = UrlBase64.encode(str.getBytes());
            ret = new String(bytes);
        } catch (Exception e) {
            e.printStackTrace();
        }
//        System.out.println("rawStr=" + str + "\nencodedStr=" + ret + "\ndecodedStr=" + decode(ret));
        return ret;
    }

    public static String decode(String str) {
        String ret = null;
        if (str == null || str.trim().length() == 0) return str;
        try {
            byte[] bytes = UrlBase64.decode(str.getBytes());
            ret = new String(bytes);
        } catch (Exception e) {
            e.printStackTrace();
        }
        return ret;
    }

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值