MD5/Base64加密算法

package com.john.j2se.util;     
/**    
 * MD5加密算法 ,是一种单向加密算法。  
 */    
import java.security.MessageDigest;     
    
public class MD5Util {     
    public final static String MD5(String s) {     
        char hexDigits[] = { '0', '1', '2', '3', '4',     
                             '5', '6', '7', '8', '9',     
                             'A', 'B', 'C', 'D', 'E', 'F'};     
        try {     
            byte[] btInput = s.getBytes();     
            MessageDigest mdInst = MessageDigest.getInstance("MD5");     
            mdInst.update(btInput);     
            byte[] md = mdInst.digest();     
            int j = md.length;     
            char str[] = new char[j * 2];     
            int k = 0;     
            for (int i = 0; i < j; i++) {     
                byte byte0 = md[i];     
                str[k++] = hexDigits[byte0 >>> 4 & 0xf];     
                str[k++] = hexDigits[byte0 & 0xf];     
            }     
            return new String(str);     
        }     
        catch (Exception e) {     
            e.printStackTrace();     
            return null;     
        }     
    }     



/**
 * Base64 是一种双向加密算法
 */
import java.io.UnsupportedEncodingException;    
  
public class Base64 {    
    private 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', '+', '/' };    
   
    private 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, -1, -1, -1, -1, -1, -1, 62, -1, -1, -1, 63,    
    52, 53, 54, 55, 56, 57, 58, 59, 60, 61, -1, -1, -1, -1, -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 };

  //编码     
    public static String encode(byte[] data) {     
        StringBuffer sb = new StringBuffer();     
        int len = data.length;     
        int i = 0;     
        int b1, b2, b3;     
        while (i < len) {     
            b1 = data[i++] & 0xff;     
            if (i == len)     
            {     
                sb.append(base64EncodeChars[b1 >>> 2]);     
                sb.append(base64EncodeChars[(b1 & 0x3) << 4]);     
                sb.append("==");     
                break;     
            }     
            b2 = data[i++] & 0xff;     
            if (i == len)     
            {     
                sb.append(base64EncodeChars[b1 >>> 2]);     
                sb.append(base64EncodeChars[((b1 & 0x03) << 4) | ((b2 & 0xf0) >>> 4)]);     
                sb.append(base64EncodeChars[(b2 & 0x0f) << 2]);     
                sb.append("=");     
                break;     
            }     
            b3 = data[i++] & 0xff;     
            sb.append(base64EncodeChars[b1 >>> 2]);     
            sb.append(base64EncodeChars[((b1 & 0x03) << 4) | ((b2 & 0xf0) >>> 4)]);     
            sb.append(base64EncodeChars[((b2 & 0x0f) << 2) | ((b3 & 0xc0) >>> 6)]);     
            sb.append(base64EncodeChars[b3 & 0x3f]);     
        }     
        return sb.toString();     
    }     
    //解码     
    public static byte[] decode(String str) throws UnsupportedEncodingException {     
        StringBuffer sb = new StringBuffer();     
        byte[] data = str.getBytes("US-ASCII");     
        int len = data.length;     
        int i = 0;     
        int b1, b2, b3, b4;     
        while (i < len) {     
            /* b1 */    
            do {     
                b1 = base64DecodeChars[data[i++]];     
            } while (i < len && b1 == -1);     
            if (b1 == -1) break;     
            /* b2 */    
            do {     
                b2 = base64DecodeChars[data[i++]];               
           } while (i < len && b2 == -1);     
            if (b2 == -1) break;    
            sb.append((char)((b1 << 2) | ((b2 & 0x30) >>> 4)));    
            /* b3 */   
            do {    
                b3 = data[i++];    
                if (b3 == 61) return sb.toString().getBytes("iso8859-1");    
                b3 = base64DecodeChars[b3];    
            } while (i < len && b3 == -1);    
            if (b3 == -1) break;    
            sb.append((char)(((b2 & 0x0f) << 4) | ((b3 & 0x3c) >>> 2)));    
            /* b4 */   
            do {    
                b4 = data[i++];    
                if (b4 == 61) return sb.toString().getBytes("iso8859-1");    
                b4 = base64DecodeChars[b4];    
            } while (i < len && b4 == -1);    
            if (b4 == -1) break;    
            sb.append((char)(((b3 & 0x03) << 6) | b4));    
        }    
        return sb.toString().getBytes("iso8859-1");    
    }    
}  



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
ABAP是一种SAP开发语言,其在企业级应用的开发和运行中发挥着不可替代的作用。在实际的开发和业务流程中,数据的加密与保护是非常重要的,因此在ABAP的开发中,MD5Base64算法的应用也变得越来越广泛。 MD5是一种常见的加密算法,可以将任意长度的消息摘要成固定长度的128位数据,具有不可逆转的特点,因此对于数据的保护有着非常好的效果。在ABAP中,可以通过使用Function module “SSFC_STRING_HASH”实现MD5加密,具体操作如下: 1.需要使用IMPORT参数algorithm(值为’MD5’) 2.调用函数时,需要将需要加密的消息传递给EXPORT变量“hashval”,这个变量的类型是RAW,或者是CHAR,长度为16。 示例代码如下: DATA: lv_text TYPE string VALUE 'ABAP MD5加密', lv_algo TYPE ssfc_apps_algo_md5, lv_hash TYPE ssfc_raw16. lv_algo = 'MD5'. CALL FUNCTION 'SSFC_STRING_HASH' EXPORTING algorithm = lv_algo string = lv_text IMPORTING hashval = lv_hash. 在得到MD5值之后,可以将其与Base64加密算法结合使用,对数据进行进一步保护和传输。Base64编码可以将二进制数据转化成一种可读性很高的ASCII字符组合,具有不可逆的特征,因此在传输数据中的广泛应用非常必要。 在ABAP中,可以通过使用Function module “SCMS_BASE64_ENCODE_STR”的方法实现Base64编码,将加密后的数据转换成可读性更高的字符创类型数据传输出去,具体操作如下: 示例代码如下: DATA: lv_base64 TYPE string. CALL FUNCTION 'SCMS_BASE64_ENCODE_STR' EXPORTING text = lv_hash IMPORTING b64 = lv_base64. 可以看到,在ABAP的开发中,MD5Base64加密算法的应用,可以更好地保护数据,保障企业的信息安全,在实际开发中具有非常重要的作用。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值