vb的GUID生成算法
 源代码推荐:vb的GUID生成算法
源代码推荐:vb的GUID生成算法 
 
 
 'RETURNS:  GUID if successful; blank string otherwise.
'RETURNS:  GUID if successful; blank string otherwise.  
 'Unlike the GUIDS in the registry, this function returns GUID
'Unlike the GUIDS in the registry, this function returns GUID  
 'without "-" characters.  See comments for how to modify if you
'without "-" characters.  See comments for how to modify if you  
 'want the dash.
'want the dash.  
 
 
 Public Function GUID() As String
Public Function GUID() As String  
 Dim lRetVal As Long
    Dim lRetVal As Long  
 Dim udtGuid As GUID
    Dim udtGuid As GUID  
 
      
 Dim sPartOne As String
    Dim sPartOne As String  
 Dim sPartTwo As String
    Dim sPartTwo As String  
 Dim sPartThree As String
    Dim sPartThree As String  
 Dim sPartFour As String
    Dim sPartFour As String  
 Dim iDataLen As Integer
    Dim iDataLen As Integer  
 Dim iStrLen As Integer
    Dim iStrLen As Integer  
 Dim iCtr As Integer
    Dim iCtr As Integer  
 Dim sAns As String
    Dim sAns As String  
 
     
 On Error GoTo errorhandler
    On Error GoTo errorhandler  
 sAns = ""
    sAns = ""  
 
      
 lRetVal = CoCreateGuid(udtGuid)
    lRetVal = CoCreateGuid(udtGuid)  
 
      
 If lRetVal = 0 Then
    If lRetVal = 0 Then  
 
      
 'First 8 chars
       'First 8 chars  
 sPartOne = Hex$(udtGuid.PartOne)
        sPartOne = Hex$(udtGuid.PartOne)  
 iStrLen = Len(sPartOne)
        iStrLen = Len(sPartOne)  
 iDataLen = Len(udtGuid.PartOne)
        iDataLen = Len(udtGuid.PartOne)  
 sPartOne = String((iDataLen * 2) - iStrLen, "0") _
        sPartOne = String((iDataLen * 2) - iStrLen, "0") _  
 & Trim$(sPartOne)
        & Trim$(sPartOne)  
 
          
 'Next 4 Chars
        'Next 4 Chars  
 sPartTwo = Hex$(udtGuid.PartTwo)
        sPartTwo = Hex$(udtGuid.PartTwo)  
 iStrLen = Len(sPartTwo)
        iStrLen = Len(sPartTwo)  
 iDataLen = Len(udtGuid.PartTwo)
        iDataLen = Len(udtGuid.PartTwo)  
 sPartTwo = String((iDataLen * 2) - iStrLen, "0") _
        sPartTwo = String((iDataLen * 2) - iStrLen, "0") _  
 & Trim$(sPartTwo)
        & Trim$(sPartTwo)  
 
             
 'Next 4 Chars
        'Next 4 Chars  
 sPartThree = Hex$(udtGuid.PartThree)
        sPartThree = Hex$(udtGuid.PartThree)  
 iStrLen = Len(sPartThree)
        iStrLen = Len(sPartThree)  
 iDataLen = Len(udtGuid.PartThree)
        iDataLen = Len(udtGuid.PartThree)  
 sPartThree = String((iDataLen * 2) - iStrLen, "0") _
        sPartThree = String((iDataLen * 2) - iStrLen, "0") _  
 & Trim$(sPartThree)   'Next 2 bytes (4 hex digits)
        & Trim$(sPartThree)   'Next 2 bytes (4 hex digits)  
 
             
 'Final 16 chars
        'Final 16 chars  
 For iCtr = 0 To 7
        For iCtr = 0 To 7  
 sPartFour = sPartFour & _
            sPartFour = sPartFour & _  
 Format$(Hex$(udtGuid.PartFour(iCtr)), "00")
            Format$(Hex$(udtGuid.PartFour(iCtr)), "00")  
 Next
        Next  
 
 
 'To create GUID with "-", change line below to:
     'To create GUID with "-", change line below to:  
 'sAns = sPartOne & "-" & sPartTwo & "-" & sPartThree _
     'sAns = sPartOne & "-" & sPartTwo & "-" & sPartThree _  
 '& "-" & sPartFour
     '& "-" & sPartFour  
 
         
 sAns = sPartOne & sPartTwo & sPartThree & sPartFour
       sAns = sPartOne & sPartTwo & sPartThree & sPartFour  
 
              
 End If
        End If  
 
          
 GUID = sAns
        GUID = sAns  
 Exit Function
Exit Function  
 
 
 
 
 errorhandler:
errorhandler:  
 'return a blank string if there's an error
'return a blank string if there's an error  
 Exit Function
Exit Function  
 End Function
End Function  
 
 
    
                    
                     
                    
                 
                    
                 
                
            
         
         浙公网安备 33010602011771号
浙公网安备 33010602011771号