php crypt in python

大半年没有更新博客,朋友们在我博客的留言和提问我也都有看到,鲜少回复,感到十分抱歉。我以为我快要离开IT行业了,近两年一直在做外包,每天都在赶进度赶进度,感到疲惫的同时,也开始怀疑自己是否对这个行业有足够的热情,是否有足够的天分。但是我知道,我其实还是喜欢挑战,那种搞定问题后的喜悦,每个程序员应该都会觉得很享受吧。我不确定自己还会在这条路上走多久,但当下,愿意走的时候还会好好走。

切入正题,今天遇到一个问题,记录一下。

手上有一批用户名密码,密码是用PHP中的crypt()方法加密过的。而现在,我要在Python的环境里验证这个密码,看看用户提交的密码与现有的加密后的密码是否匹配。怎么办?首先要知道PHP里面对密码的加密和验证是怎么做的。

加密:
$PWD = crypt($PASSWORD)

验证:
if(crypt($PASSWORD,$PWD) ==  $PWD)

在PHP中,crypt方法到底用什么算法加密(DES还是MD5)会根据操作系统环境的不同而不同的。python中也有crypt方法,我直接按一样的方式使用这个方法,可惜并不奏效。那么要想,现有的系统中,到是用了DES还是MD5还是其它呢?这个判断方法我没有深究,我在网上看到,不同加密算法出来的加密结果,格式上会有分别,如下:

<?php
if (CRYPT_STD_DES == 1) {
    echo 'Standard DES: ' . crypt('rasmuslerdorf', 'rl') . "\n";
}

if (CRYPT_EXT_DES == 1) {
    echo 'Extended DES: ' . crypt('rasmuslerdorf', '_J9..rasm') . "\n";
}

if (CRYPT_MD5 == 1) {
    echo 'MD5:          ' . crypt('rasmuslerdorf', '$1$rasmusle$') . "\n";
}

if (CRYPT_BLOWFISH == 1) {
    echo 'Blowfish:     ' . crypt('rasmuslerdorf', '$2a$07$rasmuslerd...........$') . "\n";
}
?>

我的密码格式是如:$1$7F..C32.$fLd0lxCK.ea3nhEuKcTIP0,我根据格式判断,现在系统是使用了MD5的算法。

于是问题的关键字就变成 python crypt md5。我找到了下面的方法:

from passlib.hash import md5_crypt
verifyed = md5_crypt.verify(passwd, cryptedpwd)

passwd是用户提交的明文密码,cryptedpwd是PHP里加密过的密码,如果验证通过,verifyed就会为true。

使用passlib.hash这个模块,需要先安装passlib,我一般使用easy_install安装:easy_install pass lib

OK,记录到此。

### 关于 filechecker_revenge 的分析 filechecker_revenge 是一种用于特定场景下的文件校验工具,通常涉及复杂的逻辑处理和安全机制。对于该工具的技术信息及其源码分析如下: #### 文件读取与路径解析 在给定的代码片段中,存在一段尝试改变当前工作目录并展示某个随机文件源码的操作[^1]: ```php if(chdir(chr(ord(strrev(crypt(serialize(array()))))))) show_source(array_rand(array_flip(scandir(getcwd())))); ``` 这段代码通过一系列函数调用来实现更改工作目录以及显示指定目录下某文件的内容。然而,此行为可能并非预期中的访问根目录而是受限于Web服务器环境配置所影响的结果。 #### IDA Pro 中的NOP操作 针对二进制文件或可执行程序逆向工程过程中遇到的异常字节序列(如 EBFF),可以利用IDA Pro内置脚本语言——IDAPython 进行批量替换为 NOP (No Operation)指令即 `90` 字节来修复此类问题[^2]: ```python for seg_ea in Segments(): for head in Heads(seg_ea, SegEnd(seg_ea)): if Byte(head) == 0xEB and Byte(head + 1) == 0xFF: PatchByte(head, 0x90) ``` #### FileChecker Revenge 使用方法概述 FileChecker Revenge 主要应用于验证文件完整性及检测潜在篡改情况,在实际应用中有以下几个方面值得注意: - **初始化设置**:确保安装依赖库,并按照官方文档完成必要的参数配置。 - **核心功能测试**:运行预设命令以检验基本功能是否正常运作,例如计算哈希值、对比签名等。 - **高级特性探索**:深入研究其提供的API接口或其他扩展模块,以便更好地集成到现有项目当中去。 为了更全面地了解这个工具的具体细节,建议查阅官方发布的最新版本说明和技术手册获取最权威的信息资源。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值