我在Visual Basic中的Windows應用程序窗體項目中運行此代碼。這段代碼應該給我一個字節數組的CRC-32字節,但不管我做什麼我都不能輸出任何字節。對不起,如果有什麼東西真的很明顯,我在這裏失蹤,但我已經試過「MsgBox」,「立即屏幕」與「debug.print」,我也嘗試打印文本框中的字節,但沒有結果。如果你能幫助我,我很感激。這個Visual Basic代碼爲什麼不產生任何結果?
Public Class Form1
Public Sub Main()
Dim lCrc32Value As Long
On Error Resume Next
lCrc32Value = InitCrc32()
lCrc32Value = AddCrc32("This is the original message!", _
lCrc32Value)
'Debug.Print(Hex$(GetCrc32(lCrc32Value)))
TextBox1.Text = (Hex$(GetCrc32(lCrc32Value))).ToString
End Sub
'// Then declare this array variable Crc32Table
Private Crc32Table(255) As Long
'// Then all we have to do is write public functions like
'these...
Public Function InitCrc32(Optional ByVal Seed As Long = _
&HEDB88320, Optional ByVal Precondition As _
Long = &HFFFFFFFF) As Long
'// Declare counter variable iBytes,
'counter variable iBits,
'value variables lCrc32 and lTempCrc32
Dim iBytes As Integer, iBits As Integer, lCrc32 As Long
Dim lTempCrc32 As Long
'// Turn on error trapping
On Error Resume Next
'// Iterate 256 times
For iBytes = 0 To 255
'// Initiate lCrc32 to counter variable
lCrc32 = iBytes
'// Now iterate through each bit in counter byte
For iBits = 0 To 7
'// Right shift unsigned long 1 bit
lTempCrc32 = lCrc32 And &HFFFFFFFE
lTempCrc32 = lTempCrc32 \ &H2
lTempCrc32 = lTempCrc32 And &H7FFFFFFF
'// Now check if temporary is less than zero and then
'mix Crc32 checksum with Seed value
If (lCrc32 And &H1) <> 0 Then
lCrc32 = lTempCrc32 Xor Seed
Else
lCrc32 = lTempCrc32
End If
Next
'// Put Crc32 checksum value in the holding array
Crc32Table(iBytes) = lCrc32
Next
'// After this is done, set function value to the
'precondition value
InitCrc32 = Precondition
End Function
'// The function above is the initializing function, now
'we have to write the computation function
Public Function AddCrc32(ByVal Item As String, _
ByVal Crc32 As Long) As Long
'// Declare following variables
Dim bCharValue As Byte, iCounter As Integer, lIndex As Long
Dim lAccValue As Long, lTableValue As Long
'// Turn on error trapping
On Error Resume Next
'// Iterate through the string that is to be checksum-computed
For iCounter = 1 To Len(Item)
'// Get ASCII value for the current character
bCharValue = Asc(Mid$(Item, iCounter, 1))
'// Right shift an Unsigned Long 8 bits
lAccValue = Crc32 And &HFFFFFF00
lAccValue = lAccValue \ &H100
lAccValue = lAccValue And &HFFFFFF
'// Now select the right adding value from the
'holding table
lIndex = Crc32 And &HFF
lIndex = lIndex Xor bCharValue
lTableValue = Crc32Table(lIndex)
'// Then mix new Crc32 value with previous
'accumulated Crc32 value
Crc32 = lAccValue Xor lTableValue
Next
'// Set function value the the new Crc32 checksum
AddCrc32 = Crc32
End Function
'// At last, we have to write a function so that we
'can get the Crc32 checksum value at any time
Public Function GetCrc32(ByVal Crc32 As Long) As Long
'// Turn on error trapping
On Error Resume Next
'// Set function to the current Crc32 value
GetCrc32 = Crc32 Xor &HFFFFFFFF
End Function
'// And for testing the routines above...
End Class
如果性能很重要,你應該考慮切換到SHA256甚至MD5 - CRC32已經過時了,甚至不再產生可靠的傳輸層有效性信息。您確實應該使用AT LEAST MD5,它可供所有人使用,網址爲http://msdn.microsoft.com/de-de/library/system.security.cryptography.hmacmd5(v=vs.110).aspx – specializt
全部那些On Error Resume Next似乎只是爲了隱藏錯誤。並且請設置OPTION STRICT ON,並在將長整型轉換爲整數時發現代碼中存在很多錯誤 – Steve
@Steve:如果可以的話,我會提供+10的評論。 –