Ver Mensaje Individual
  #2 (permalink)  
Antiguo 04/11/2008, 07:53
Avatar de Muzztein
Muzztein
 
Fecha de Ingreso: agosto-2002
Ubicación: Hangar 18
Mensajes: 1.703
Antigüedad: 22 años, 8 meses
Puntos: 16
Respuesta: Funcion MD5 de php en ASP ?

Código PHP:

Private Const BITS_TO_A_BYTE 8
Private Const BYTES_TO_A_WORD 4
Private Const BITS_TO_A_WORD 32

Private m_lOnBits(30)
Private 
m_l2Power(30)
 
    
m_lOnBits(0) = CLng(1)
    
m_lOnBits(1) = CLng(3)
    
m_lOnBits(2) = CLng(7)
    
m_lOnBits(3) = CLng(15)
    
m_lOnBits(4) = CLng(31)
    
m_lOnBits(5) = CLng(63)
    
m_lOnBits(6) = CLng(127)
    
m_lOnBits(7) = CLng(255)
    
m_lOnBits(8) = CLng(511)
    
m_lOnBits(9) = CLng(1023)
    
m_lOnBits(10) = CLng(2047)
    
m_lOnBits(11) = CLng(4095)
    
m_lOnBits(12) = CLng(8191)
    
m_lOnBits(13) = CLng(16383)
    
m_lOnBits(14) = CLng(32767)
    
m_lOnBits(15) = CLng(65535)
    
m_lOnBits(16) = CLng(131071)
    
m_lOnBits(17) = CLng(262143)
    
m_lOnBits(18) = CLng(524287)
    
m_lOnBits(19) = CLng(1048575)
    
m_lOnBits(20) = CLng(2097151)
    
m_lOnBits(21) = CLng(4194303)
    
m_lOnBits(22) = CLng(8388607)
    
m_lOnBits(23) = CLng(16777215)
    
m_lOnBits(24) = CLng(33554431)
    
m_lOnBits(25) = CLng(67108863)
    
m_lOnBits(26) = CLng(134217727)
    
m_lOnBits(27) = CLng(268435455)
    
m_lOnBits(28) = CLng(536870911)
    
m_lOnBits(29) = CLng(1073741823)
    
m_lOnBits(30) = CLng(2147483647)
    
    
m_l2Power(0) = CLng(1)
    
m_l2Power(1) = CLng(2)
    
m_l2Power(2) = CLng(4)
    
m_l2Power(3) = CLng(8)
    
m_l2Power(4) = CLng(16)
    
m_l2Power(5) = CLng(32)
    
m_l2Power(6) = CLng(64)
    
m_l2Power(7) = CLng(128)
    
m_l2Power(8) = CLng(256)
    
m_l2Power(9) = CLng(512)
    
m_l2Power(10) = CLng(1024)
    
m_l2Power(11) = CLng(2048)
    
m_l2Power(12) = CLng(4096)
    
m_l2Power(13) = CLng(8192)
    
m_l2Power(14) = CLng(16384)
    
m_l2Power(15) = CLng(32768)
    
m_l2Power(16) = CLng(65536)
    
m_l2Power(17) = CLng(131072)
    
m_l2Power(18) = CLng(262144)
    
m_l2Power(19) = CLng(524288)
    
m_l2Power(20) = CLng(1048576)
    
m_l2Power(21) = CLng(2097152)
    
m_l2Power(22) = CLng(4194304)
    
m_l2Power(23) = CLng(8388608)
    
m_l2Power(24) = CLng(16777216)
    
m_l2Power(25) = CLng(33554432)
    
m_l2Power(26) = CLng(67108864)
    
m_l2Power(27) = CLng(134217728)
    
m_l2Power(28) = CLng(268435456)
    
m_l2Power(29) = CLng(536870912)
    
m_l2Power(30) = CLng(1073741824)

Private Function 
LShift(lValueiShiftBits)
    If 
iShiftBits 0 Then
        LShift 
lValue
        
Exit Function
    ElseIf 
iShiftBits 31 Then
        
If lValue And 1 Then
            LShift 
= &H80000000
        
Else
            
LShift 0
        End 
If
        Exit Function
    ElseIf 
iShiftBits Or iShiftBits 31 Then
        Err
.Raise 6
    End 
If

    If (
lValue And m_l2Power(31 iShiftBits)) Then
        LShift 
= ((lValue And m_lOnBits(31 - (iShiftBits 1))) * m_l2Power(iShiftBits)) Or &H80000000
    
Else
        
LShift = ((lValue And m_lOnBits(31 iShiftBits)) * m_l2Power(iShiftBits))
    
End If
End Function

Private Function 
RShift(lValueiShiftBits)
    If 
iShiftBits 0 Then
        RShift 
lValue
        
Exit Function
    ElseIf 
iShiftBits 31 Then
        
If lValue And &H80000000 Then
            RShift 
1
        
Else
            
RShift 0
        End 
If
        Exit Function
    ElseIf 
iShiftBits Or iShiftBits 31 Then
        Err
.Raise 6
    End 
If
    
    
RShift = (lValue And &H7FFFFFFE)  m_l2Power(iShiftBits)

    If (
lValue And &H80000000Then
        RShift 
= (RShift Or (&H40000000  m_l2Power(iShiftBits 1)))
    
End If
End Function

Private Function 
RotateLeft(lValueiShiftBits)
    
RotateLeft LShift(lValueiShiftBits) Or RShift(lValue, (32 iShiftBits))
End Function

Private Function 
AddUnsigned(lXlY)
    
Dim lX4
    Dim lY4
    Dim lX8
    Dim lY8
    Dim lResult
 
    lX8 
lX And &H80000000
    lY8 
lY And &H80000000
    lX4 
lX And &H40000000
    lY4 
lY And &H40000000
 
    lResult 
= (lX And &H3FFFFFFF) + (lY And &H3FFFFFFF)
 
    If 
lX4 And lY4 Then
        lResult 
lResult Xor &H80000000 Xor lX8 Xor lY8
    
ElseIf lX4 Or lY4 Then
        
If lResult And &H40000000 Then
            lResult 
lResult Xor &HC0000000 Xor lX8 Xor lY8
        
Else
            
lResult lResult Xor &H40000000 Xor lX8 Xor lY8
        End 
If
    Else
        
lResult lResult Xor lX8 Xor lY8
    End 
If
 
    
AddUnsigned lResult
End 
Function

Private Function 
F(xyz)
    
= (And y) Or ((Not x) And z)
End Function

Private Function 
G(xyz)
    
= (And z) Or (And (Not z))
End Function

Private Function 
H(xyz)
    
= (Xor Xor z)
End Function

Private Function 
I(xyz)
    
= (Xor (Or (Not z)))
End Function

Private 
Sub FF(abcdxsac)
    
AddUnsigned(aAddUnsigned(AddUnsigned(F(bcd), x), ac))
    
RotateLeft(as)
    
AddUnsigned(ab)
End Sub

Private Sub GG(abcdxsac)
    
AddUnsigned(aAddUnsigned(AddUnsigned(G(bcd), x), ac))
    
RotateLeft(as)
    
AddUnsigned(ab)
End Sub

Private Sub HH(abcdxsac)
    
AddUnsigned(aAddUnsigned(AddUnsigned(H(bcd), x), ac))
    
RotateLeft(as)
    
AddUnsigned(ab)
End Sub

Private Sub II(abcdxsac)
    
AddUnsigned(aAddUnsigned(AddUnsigned(I(bcd), x), ac))
    
RotateLeft(as)
    
AddUnsigned(ab)
End Sub

Private Function ConvertToWordArray(sMessage)
    
Dim lMessageLength
    Dim lNumberOfWords
    Dim lWordArray
()
    
Dim lBytePosition
    Dim lByteCount
    Dim lWordCount
    
    
Const MODULUS_BITS 512
    
Const CONGRUENT_BITS 448
    
    lMessageLength 
Len(sMessage)
    
    
lNumberOfWords = (((lMessageLength + ((MODULUS_BITS CONGRUENT_BITS)  BITS_TO_A_BYTE))  (MODULUS_BITS  BITS_TO_A_BYTE)) + 1) * (MODULUS_BITS  BITS_TO_A_WORD)
    
ReDim lWordArray(lNumberOfWords 1)
    
    
lBytePosition 0
    lByteCount 
0
    
Do Until lByteCount >= lMessageLength
        lWordCount 
lByteCount  BYTES_TO_A_WORD
        lBytePosition 
= (lByteCount Mod BYTES_TO_A_WORD) * BITS_TO_A_BYTE
        lWordArray
(lWordCount) = lWordArray(lWordCount) Or LShift(Asc(Mid(sMessagelByteCount 11)), lBytePosition)
        
lByteCount lByteCount 1
    Loop

    lWordCount 
lByteCount  BYTES_TO_A_WORD
    lBytePosition 
= (lByteCount Mod BYTES_TO_A_WORD) * BITS_TO_A_BYTE

    lWordArray
(lWordCount) = lWordArray(lWordCount) Or LShift(&H80lBytePosition)

    
lWordArray(lNumberOfWords 2) = LShift(lMessageLength3)
    
lWordArray(lNumberOfWords 1) = RShift(lMessageLength29)
    
    
ConvertToWordArray lWordArray
End 
Function

Private Function 
WordToHex(lValue)
    
Dim lByte
    Dim lCount
    
    
For lCount 0 To 3
        lByte 
RShift(lValuelCount BITS_TO_A_BYTE) And m_lOnBits(BITS_TO_A_BYTE 1)
        
WordToHex WordToHex Right("0" Hex(lByte), 2)
    
Next
End 
Function