MD5加密

MD5的工具类:http://seefan.3322.org/article/showArticle.jsp?id=240

package com.seefan.util;

import java.security.MessageDigest;

public class MD5Util {

 public static String Encode(String instr) {
  String re = null;
  if (instr == null)
   return null;
  char hexDigits[] = { // 用来将字节转换成 16 进制表示的字符
  '0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'a', 'b', 'c', 'd',
    'e', 'f' };
  try {
   java.security.MessageDigest md = java.security.MessageDigest
     .getInstance("MD5");
   md.update(instr.getBytes());
   byte tmp[] = md.digest(); // MD5 的计算结果是一个 128 位的长整数,
   // 用字节表示就是 16 个字节
   char str[] = new char[32]; // 每个字节用 16 进制表示的话,使用两个字符,
   // 所以表示成 16 进制需要 32 个字符
   int k = 0; // 表示转换结果中对应的字符位置
   for (int i = 0; i < 16; i++) { // 从第一个字节开始,对 MD5 的每一个字节
    // 转换成 16 进制字符的转换
    byte byte0 = tmp[i]; // 取第 i 个字节
    str[k++] = hexDigits[byte0 >>> 4 & 0xf]; // 取字节中高 4 位的数字转换,
    // >>> 为逻辑右移,将符号位一起右移
    str[k++] = hexDigits[byte0 & 0xf]; // 取字节中低 4 位的数字转换
   }
   re = new String(str); // 换后的结果转换为字符串

  } catch (Exception e) {
   e.printStackTrace();
  }
  return re;
 }

 public static String Encode2(String instr) {
  String re = null;
  if (instr == null)
   return null;
  try {
   MessageDigest md = MessageDigest.getInstance("MD5");
   re = new String(md.digest(instr.getBytes()));
  } catch (Exception e) {
   e.printStackTrace();
  }
  return re;
 }

 public static void main(String[] args) {
  System.out.print(MD5Util.Encode("AusITcim#1485"));
 }

}

MD5加密-对POS卡号码进行加密 :http://www.cnblogs.com/jdonson/archive/2009/06/23/1509418.html

 

package com.datacomo.pcm.ejb.systemcore.util;

import java.security.MessageDigest;
import java.util.Random;
public class Md5Encrtypt {

 /**
  * MD5加密算法
  *
  * @param s
  *            加密数字
  * @return 加密后的值
  */
 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[] strTemp = s.getBytes();
   MessageDigest mdTemp = MessageDigest.getInstance("MD5");
   mdTemp.update(strTemp);
   byte[] md = mdTemp.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) {
   return null;
  }
 }

 /**
  * 去除字母
  *
  * @param number
  *            加密后的值
  * @return 去除字母后的值
  */
 public static String getNumber(String number) {
  StringBuffer mun = new StringBuffer();
  char[] cha = number.toCharArray();
  for (int i = 0; i < number.length(); i++) {
   if (Character.isDigit(cha[i])) {
    mun.append(cha[i]);
   }
  }
  return mun.toString();
 }

 /**
  * 生成随机数
  *
  * @param count
  * @return
  */
 public static String random(int count) {
  String mun = "";
  Random random = new Random();
  for (int i = 0; i < count; i++) {
   mun += random.nextInt(10);
  }
  return mun;
 }

 /**
  * 获得加密后的POS卡号码
  *
  * @param posNum
  *            pos卡号码
  * @return 加密后的POS卡号码
  */
 public static String getMd5Encrtypt(String posNum) {
  StringBuffer PosNumber = new StringBuffer();
  PosNumber.append(posNum);
  String md5PosNum = Md5Encrtypt.MD5(posNum);
  String md5Num = Md5Encrtypt.getNumber(md5PosNum);
  if (md5Num.length() > 18) {
   md5Num = md5Num.substring(0, 18);
   PosNumber.append(md5Num);
  } else if (md5Num.length() < 18) {
   int num = 18 - md5Num.length();
   String randomNum = Md5Encrtypt.random(num);
   PosNumber.append(md5Num);
   PosNumber.append(randomNum);
  } else if (md5Num.length() == 18) {
   PosNumber.append(md5Num);
  }
  return PosNumber.toString();
 }

 /**
  * @param args
  */
 public static void main(String[] args) {
  Md5Encrtypt md5Encrtypt = new Md5Encrtypt();
  String posNum = md5Encrtypt.getMd5Encrtypt("12345678901223");
  System.out.println("加密后的卡号为:" + posNum);

 }

}

### 使用Python中的`hashlib`模块实现MD5加密 在Python中,可以利用内置的`hashlib`库轻松完成MD5加密操作。以下是具体的方法: #### 导入必要的模块 为了使用MD5加密功能,首先需要导入`hashlib`模块[^1]。 ```python import hashlib ``` #### 创建MD5对象并更新数据 通过调用`hashlib.md5()`创建一个MD5哈希对象,并使用`.update(data)`方法传入待加密的数据。注意,`data`必须是字节类型(bytes),因此如果输入的是字符串,则需先将其编码为字节串。 ```python data = "example_password".encode('utf-8') # 将字符串转换为字节类型 md5_hash = hashlib.md5() md5_hash.update(data) ``` #### 获取加密结果 可以通过`.hexdigest()`方法获取最终的十六进制表示形式的MD5值。 ```python encrypted_result = md5_hash.hexdigest() print(encrypted_result) # 输出:2346bc9edbf3f7dbe0dc9d3f8c0ddc7a ``` 完整的代码如下所示: ```python import hashlib def encrypt_md5(input_string): data = input_string.encode('utf-8') md5_hash = hashlib.md5() md5_hash.update(data) encrypted_result = md5_hash.hexdigest() return encrypted_result # 测试函数 password = "example_password" result = encrypt_md5(password) print(f"The MD5 hash of '{password}' is {result}") ``` 上述代码定义了一个名为`encrypt_md5`的函数,用于接收任意字符串作为参数,并返回该字符串对应的MD5散列值。 --- 关于加盐处理,可以在原始密码基础上附加一段随机字符后再进行MD5加密,从而增加安全性[^2]^。例如: ```python import hashlib import os def salt_encrypt_md5(input_string, salt=os.urandom(16).hex()): combined_data = (input_string + salt).encode('utf-8') md5_hash = hashlib.md5() md5_hash.update(combined_data) encrypted_result = md5_hash.hexdigest() return encrypted_result, salt # 测试带盐加密 password = "example_password" hashed_value, used_salt = salt_encrypt_md5(password) print(f"Salted Hash: {hashed_value}, Salt Used: {used_salt}") ``` 此脚本不仅完成了基本的MD5加密,还引入了动态生成的盐值以增强保护力度。 --- ### 注意事项 尽管MD5是一种广泛应用的摘要算法,但由于其存在碰撞风险,现已不推荐单独依赖它来进行敏感信息安全保障工作[^4]。对于现代应用而言,建议采用更安全的替代方案如SHA-256或其他强健型哈希技术。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值