生成并校验字符串的MD5

public class SignDataUtil {

    /**
     * 默认的密码字符串组合,用来将字节转换成 16 进制表示的字符
     * Apache校验下载的文件的正确性用的就是默认的这个组合
     */
    protected static char hexDigits[] = { ‘0‘, ‘1‘, ‘2‘, ‘3‘, ‘4‘, ‘5‘, ‘6‘,
            ‘7‘, ‘8‘, ‘9‘, ‘a‘, ‘b‘, ‘c‘, ‘d‘, ‘e‘, ‘f‘ };

    protected static MessageDigest messagedigest = null;

    /**
     * 生成字符串的MD5/SHA1校验值
     * @param type
     *            安全通道类型(IfPub中的scType)
     * @param buffer
     *            拼接MD5/SHA1的字符串
     * @return
     */
    public String getSignData(String type, StringBuffer buffer) {
        try {
            if (Constant.MD5TYPE.equals(type)) {
                messagedigest = MessageDigest.getInstance(Constant.MD5);
            } else if (Constant.SHA1TYPE.equals(type)) {
                messagedigest = MessageDigest.getInstance(Constant.SHA1TYPE);
            }
            // 获得MD5摘要算法的 MessageDigest 对象
            byte[] inputByteArray;

            inputByteArray = buffer.toString().getBytes("utf-8");
            messagedigest.update(inputByteArray);
            byte[] resultByteArray = messagedigest.digest();
            return this.byteArrayToHex(resultByteArray);
        } catch (NoSuchAlgorithmException e) {
            System.err.println(SignDataUtil.class.getName()
                    + "初始化失败,MessageDigest不支持MD5Util。");
            e.printStackTrace();
            return null;
        } catch (UnsupportedEncodingException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
            return null;
        }

    }

    /**
     * 把字符数组转换成签名字符串
     * @param byteArray
     * @return
     */
    private String byteArrayToHex(byte[] byteArray) {
        // new一个字符数组,这个就是用来组成结果字符串的(解释一下:一个byte是八位二进制,也就是2位十六进制字符(2的8次方等于16的2次方))
        char[] resultCharArray = new char[byteArray.length * 2];
        // 遍历字节数组,通过位运算(位运算效率高),转换成字符放到字符数组中去
        int index = 0;
        for (byte b : byteArray) {
            resultCharArray[index++] = hexDigits[b >>> 4 & 0xf];
            resultCharArray[index++] = hexDigits[b & 0xf];
        }
        // 字符数组组合成字符串返回
        System.out.println(new String(resultCharArray));
        return new String(resultCharArray);
    }

    /**
     * 判断字符串的MD5/SHA1校验码是否与一个已知的签名相匹配
     * @param type
     *            安全通道类型(IfPub中的scType)
     * @param signData
     *            已知的MD5/SHA1校验码
     * @param result
     *            要校验的字符串
     * @return
     */
    public boolean checkSignData(String type, String signData,
            StringBuffer buffer) {
        String result = this.getSignData(type, buffer);
        return signData.equals(result);
    }

}
时间: 2024-11-03 05:38:14

生成并校验字符串的MD5的相关文章

java生成字符串的MD5值

下面的代码实现了MD5值的生成: public class MD5Test2 { public static void main(String[] args) { System.out.println(MD5Test2.MD5Operation("hello")); System.out.println(MD5Test2.getMD5("hello")); } //通过java.math包的BigInteger类实现十六进制的转换 public final stat

如何在C#中生成与PHP一样的MD5 Hash Code

原文:如何在C#中生成与PHP一样的MD5 Hash Code 最近在对一个现有的系统进行C#改造,该系统以前是用PHP做的,后台的管理员登陆用的是MD5加密算法.在PHP中,要对一个字符串进行MD5加密非常简单,一行代码即可: md5("Something you want to encrypt.") 直接调用md5()方法,然后将要进行MD5加密的字符串传进去,就可以得到返回的hash code.在C#中应该也会有对应的算法吧!对吗?我首先尝试了下面的代码,结果得到的hash co

MD5算法【计算文件和字符串的MD5值】

1. MD5算法是一种散列(hash)算法(摘要算法,指纹算法),不是一种加密算法(易错).任何长度的任意内容都可以用MD5计算出散列值.MD5的前身:MD2.MD3.MD4.介绍工具:CalcMD5.zip.主要作用就是[验明"真身"],字符串文件均可(确保信息传输过程中的完整性.一致性). 2. MD5算法的特点: ????1. 长度固定 ????2. 单向性 ---- 可以通过MD5计算器来计算文件或者字符串的MD5值,但是不可以通过给出的MD5值来推算出文件或者字符串. ???

校验字符串是否是JSON格式,将不规则展示的json格式的字符串进行规则展示(json格式化)

版权声明:本文为博主原创文章,未经博主允许不得转载. 目录(?)[+] [html] view plain copy var str = {"code": "","svcname": "","version": "","component": "","category": "","requestMs

ring0-内存可读、可写、有效性、指针是否为空、深度校验字符串(随手代码)

http://blog.csdn.net/hgy413/article/details/7907057 1.如在ring3下,则要判断是否可读可写: [cpp] view plaincopy KPROCESSOR_MODE PreviousMode; ULONG PID; PreviousMode = ExGetPreviousMode(); // 如果非内核模式,就要开始检查IN的这些参数都否可读 if (PreviousMode != KernelMode) { try { ProbeFor

Android初级教程:对文件和字符串进行MD5加密工具类

转载请注明出处:http://blog.csdn.net/qq_32059827/article/details/52200008   点击打开链接 之前写过一篇博文,是针对字符串进行md5加密的.今天对其进行改进,加入针对某个文件,进行md5加密,并获取加密后的值.并把两个功能封装成了工具类,如果有需要这个算法的,可直接使用. 直接上算法封装的工具类代码: package com.itydl.utils; import java.io.File; import java.io.FileInpu

生成随机字母字符串(数字字母混和)

1.生成随机字母字符串(数字字母混和) /// 生成随机字母字符串(数字字母混和) /// /// 待生成的位数 /// 生成的字母字符串 private string GenerateCheckCode(int codeCount) { int rep = 0; string str = string.Empty; long num2 = DateTime.Now.Ticks + rep; rep++; Random random = new Random(((int)(((ulong)num

WP开发笔记——字符串 转 MD5 加密

将字符串进行MD5加密,返回加密后的字符串. 从这里下载Md5.cs文件:http://pan.baidu.com/s/1hq3gpnu. 添加到Windows Phone 7项目中,在代码里面这样调用: 1 String strPassword = "password"; 2 String strPasswordMD5 = JeffWilcox.Utilities.Silverlight.MD5.GetMd5String(strPassword); 3 MessageBox.Show

生成24位字符串ID__IdGenerator.java

此工具类用于生成24位字符串ID,唯一不重复. 直接通过 IdGenerator.get() 获取. 源码如下:(点击下载源码 - IdGenerator.java ) 1 import java.net.NetworkInterface; 2 import java.nio.ByteBuffer; 3 import java.nio.ByteOrder; 4 import java.util.Enumeration; 5 6 /** 7 * 生成24位字符串ID 8 * 9 */ 10 pub