-
Notifications
You must be signed in to change notification settings - Fork 146
/
Copy pathMD5ex.cpp
97 lines (90 loc) · 2.67 KB
/
MD5ex.cpp
1
2
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
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
#include "MD5ex.h"
MD5ex::MD5ex()
{
}
int MD5ex::GenerateSignature(vector<unsigned char> key, vector<unsigned char> message, unsigned char ** signature)
{
*signature = new unsigned char[16];
MD5_CTX original;
MD5_Init(&original);
int totalLen = key.size() + message.size();
unsigned char * tohash = new unsigned char[totalLen];
for(unsigned int x = 0; x < key.size(); x++)
{
tohash[x] = key[x];
}
for(unsigned int x = 0; x < message.size(); x++)
{
tohash[x + key.size()] = message[x];
}
MD5_Update(&original, tohash, totalLen);
delete [] tohash;
MD5_Final(*signature, &original);
return 1;
}
bool MD5ex::ValidateSignature(vector<unsigned char> key, vector<unsigned char> message, unsigned char * signature)
{
MD5_CTX original;
MD5_Init(&original);
int totalLen = key.size() + message.size();
unsigned char * tohash = new unsigned char[totalLen];
for(unsigned int x = 0; x < key.size(); x++)
{
tohash[x] = key[x];
}
for(unsigned int x = 0; x < message.size(); x++)
{
tohash[x + key.size()] = message[x];
}
MD5_Update(&original, tohash, totalLen);
delete [] tohash;
unsigned char hash[16];
MD5_Final(hash, &original);
if(memcmp(hash, signature, 16) == 0)
{
return true;
}
return false;
}
vector<unsigned char> * MD5ex::GenerateStretchedData(vector<unsigned char> originalMessage, int keylength, unsigned char * hash, vector<unsigned char> added, unsigned char ** newSig)
{
vector<unsigned char> * ret = new vector<unsigned char>();
for(unsigned int x = 0; x < originalMessage.size(); x++)
ret->push_back(originalMessage[x]);
int tailLength = ret->size() + keylength;
tailLength *= 8;
ret->push_back(0x80);
while((ret->size() + keylength) % 64 != 56)
{
ret->push_back(0x00);
}
ret->push_back((tailLength) & 0xFF);
ret->push_back((tailLength >> 8) & 0xFF);
ret->push_back((tailLength >> 16) & 0xFF);
ret->push_back((tailLength >> 24) & 0xFF);
ret->push_back(0x00);
ret->push_back(0x00);
ret->push_back(0x00);
ret->push_back(0x00);
MD5_CTX stretch;
MD5_Init(&stretch);
stretch.Nl = (ret->size() + keylength) * 8;
stretch.A = hash[0] | (hash[1] << 8) | (hash[2] << 16) | (hash[3] << 24);
stretch.B = hash[4] | (hash[5] << 8) | (hash[6] << 16) | (hash[7] << 24);
stretch.C = hash[8] | (hash[9] << 8) | (hash[10] << 16) | (hash[11] << 24);
stretch.D = hash[12] | (hash[13] << 8) | (hash[14] << 16) | (hash[15] << 24);
char * toadd = new char[added.size()];
for(unsigned int x = 0; x < added.size(); x++)
{
toadd[x] = added[x];
}
MD5_Update(&stretch, toadd, added.size());
*newSig = new unsigned char[16];
MD5_Final(*newSig, &stretch);
delete [] toadd;
for(unsigned int x = 0; x < added.size(); x++)
{
ret->push_back(added.at(x));
}
return ret;
}