MD5不是加密

https://draveness.me/whys-the-design-password-with-md5/ 参考为什么这么设计

  • Message-Digest Algorithm 5:信息摘要算法

  • MD5 并不是一种加密算法,我们也可以叫它哈希函数

  • 世界上最常见的20个密码,类似建立一个彩虹表进行碰撞,以达到解密的效果。

    RANK 2021 MD5值(32位小写)
    1 123456 e10adc3949ba59abbe56e057f20f883e
    2 123456789 25f9e794323b453885f5181f1b624d0b
    3 12345 827ccb0eea8a706c4c34a16891f84e7b
    4 qwerty d8578edf8458ce06fbc5bb76a58c5ca4
    5 password 5f4dcc3b5aa765d61d8327deb882cf99
    6 12345678 25d55ad283aa400af464c76d713c07ad
    7 111111 96e79218965eb72c92a549dd5a330112
    8 123123 4297f44b13955235245b2497399d7a93
    9 1234567890 e807f1fcf82d132f9bb018ca6738a19f
    10 1234567 fcea920f7412b5da7be0cf42b8c93759
    11 qwerty123 3fc0a7acf087f549ac2b266baf94b8b1
    12 000000 670b14728ad9902aecba32e22fa4f6bd
    13 1q2w3e 3fde6bb0541387e4ebdadf7c2ff31123
    14 aa12345678 d4f2a60315eef2b600cf0240ac0c37ad
    15 abc123 e99a18c428cb38d5f260853678922e03
    16 password1 7c6a180b36896a0a8c02787eeafb0e4c
    17 1234 81dc9bdb52d04dc20036dbd8313ed055
    18 qwertyuiop 6eea9b7ef19179a06954edd0f6c05ceb
    19 123321 c8837b23ff8aaa8a2dde915473ce0991
    20 password123 482c811da5d5b4bc6d497ffa98491e38
  • 为什么说MD5不是加密呢?

    • 数据源是无穷尽的,而 MD5密文是有限的。所以不存在MD5解密。
    • MD5 哈希的信息无法被还原,只依靠 MD5 是无法完成加密的。
  • 哈希加盐salt

    • 在原始字符串的基础上增加一个字符串,得到一个新的"密码"。
    • /etc/passwd早期就是这么存储密码的
  • 密码的破解(哈希碰撞)

    • 攻击者其实不需要知道用户的密码是什么,他只需要找到一个值 value,这个值加盐后的哈希与密码加盐后的哈希完全一致就能登录用户的账号
    • 可以了解下hashcat(github搜)

Python中的MD5"加密"

  • 加密

    import hashlib
    ori_pwd = '123456'
    byte_ori_pwd = ori_pwd.encode('utf-8') #bytes对象
    print(hashlib.md5(byte_ori_pwd).hexdigest())
    #e10adc3949ba59abbe56e057f20f883e 都是这个
    print(hashlib.md5(b'123456').hexdigest())
  • 得到的是32位小写,如果要32位大写、16位大小写,那就简单处理下

    import hashlib
    ori_pwd = '123456'
    byte_ori_pwd = ori_pwd.encode('utf-8')
    print('32位小写: ',hashlib.md5(byte_ori_pwd).hexdigest())
    print('32位大写: ',hashlib.md5(byte_ori_pwd).hexdigest().upper())
    print('16位小写: ',hashlib.md5(byte_ori_pwd).hexdigest()[8:-8])
    print('16位大写: ',hashlib.md5(byte_ori_pwd).hexdigest()[8:-8].upper())
  • 加盐

    import hashlib
    def get_md5(ori_str:str,salt:str='',mode:str='1') -> str:
    """
    获取字符串的MD加密后的信息
    :param ori_str: 原始字符串
    :param salt: 盐值
    :param mode: 1=32小 2=32大 3=16小 4=16大
    :return: MD5后的字符串
    """
    md5_password = hashlib.md5((ori_str+salt).encode('utf-8')).hexdigest()
    if mode == '1':
    return md5_password
    if mode == '2':
    return md5_password.upper()
    if mode == '3':
    return md5_password[8:-8]
    if mode == '4':
    return md5_password[8:-8].upper()
    raise Exception(f'unsupport mode {mode},only support 1,2,3,4(1=32小 2=32大 3=16小 4=16大)')
    print('不加盐:',get_md5('123456'))
    print('加盐:',get_md5('123456',salt='nanjing'))
    print('不加盐:',get_md5('123456'))
    print('不加盐16位小写:',get_md5('123456',salt='nanjing',mode='3'))
    print('不加盐16位小写:',get_md5('123456',salt='nanjing',mode='5'))

MD5在Python中的简单使用的更多相关文章

  1. python中一个简单的webserver

     python中一个简单的webserver 2013-02-24 15:37:49 分类: Python/Ruby 支持多线程的webserver   1 2 3 4 5 6 7 8 9 10 11 ...

  2. Python 中lambda 简单介绍

    转自:https://www.cnblogs.com/AlwaysWIN/p/6202320.html 在学习python的过程中,lambda的语法经常出现,现在将它整理一下,以备日后查看. 1.l ...

  3. 正则表达式在python中的简单使用

    正则表达式独立与编程语言,基本上所有的编程语言都实现了正则表达式的相关操作.在Python中正则表达式的表现为re模块: import re 其操作有三个方法: my_string = "h ...

  4. Python中实现简单的插件框架

    在系统设计中,经常我们希望设计一套插件机制,在不修改程序主体情况下,动态去加载附能. 我设想的插件系统: 1.通过类来实现 2.自动查找和导入 我们假设需要实现一个简单的插件系统,插件可以接收一个参数 ...

  5. elasticsearch基础及在Python中的简单使用

    目录 一. 安装java环境与elasticsearch.kibana 二. elasticsearch.kibana的部分文件说明 三. Kibana的Dev tools中ES的简单命令 四. ES ...

  6. python中HTMLParser简单理解

    找一个网页,例如https://www.python.org/events/python-events/,用浏览器查看源码并复制,然后尝试解析一下HTML,输出Python官网发布的会议时间.名称和地 ...

  7. python中最简单的多进程程序

    学着.. #!/usr/bin/env python # -*- coding: utf-8 -*- # Spawn a Process: Chapter 3: Process Based Paral ...

  8. Python中最简单快捷的输出方式

    格式化输出最简单的方式之哑巴填充公式 name=ludundun age=25 print(f'hello {name},your age is {age}') 输出内容: hello ludundu ...

  9. python中property简单使用与实现

    property简单使用 class P: """ property简单使用 """ def __init__(self,name): se ...

  10. Python中的简单实现UDP协议没有粘包问题

    服务端: import socket server=socket.socket(socket.AF_INET,socket.SOCK_DGRAM) #数据报协议->udp server.bind ...

随机推荐

  1. 如何通过free看懂内存的真实使用

    之前有位同事问过Linux系统内存free命令下各参数的区别与关系,自己也没太明白,有点尴尬.今天整理一下,供了解. free命令是Liunx操作系统中对内存进行查看和监控的一个常用命令.我们可以直接 ...

  2. OpenMP 教程(一) 深入人剖析 OpenMP reduction 子句

    OpenMP 教程(一) 深入人剖析 OpenMP reduction 子句 前言 在前面的教程OpenMP入门当中我们简要介绍了 OpenMP 的一些基础的使用方法,在本篇文章当中我们将从一些基础的 ...

  3. Pwn学习随笔

    Pwn题做题流程 使用checksec检查ELF文件保护开启的状态 IDApro逆向分析程序漏洞(逻辑复杂的可以使用动态调试) 编写python的exp脚本进行攻击 (若攻击不成功)进行GDB动态调试 ...

  4. Typora基本使用

    Typora主要功能介绍 1.语言环境 文件>>>偏好设置>>>系统语言 2.创建另一个编辑页面 ctrl+N 几乎所有软件的新建页面的快捷键都是它 3.保存文件 ...

  5. C++ 动态规划:一维动态规划,背包问题,区间动态规划

    C++ 动态规划 动态规划的定义 动态规划(Dynamic Programming,DP)是运筹学的一个分支,是求解决策过程最优化的过程.动态规划是一种在数学.管理科学.计算机科学.经济学和生物信息学 ...

  6. Qt5 如何在designer中给工具栏(QToolBar)添加分割线

    如图分割线 方法1: 在工具栏右键,选择"添加分割符" 方法2: 在对象窗口中右键 toolBar ,选择"添加分割符" 其它 删除分割符,只能在布局窗口直接右 ...

  7. python-opencv实现抖动算法

    抖动算法简单介绍 简单说就是牺牲分辨率来提高颜色数量. 通过黑点的疏密程度来进行灰度的显示. 例如墨水屏幕只能显示黑白,那么我们可以取样一部分区域矩,例如2x2的一个矩阵,来显示5个级别的灰度,用4个 ...

  8. ORCL 时间

    一.计算时间差 两个Date类型字段:START_DATE,END_DATE,计算这两个日期的时间差(分别以天,小时,分钟,秒,毫秒): 天: ROUND(TO_NUMBER(END_DATE - S ...

  9. Linux创建定时删除日志任务

    定时删除3天前的所有日志文件: 1.例:脚本对应的要删除的目录为/home/logs在home目录创建文件clearLogFiles.sh:cd /homevim clearLogFiles.sh写入 ...

  10. 【Linux】个人笔记本安装Centos并开放22端口供外网连接

    〇.参考资料 一.配置及安装内容 (一)配置 [today]低配笔记本(装centos):4+500G 个人电脑(装三个节点的虚拟机集群环境):8+628G (二)所装软件 Linux系统(可选cen ...