2012-02-25 10 views
8

Robię zadanie przesyłania plików. Chcę wygenerować skróty SHA256 i CRC32. Czy ktoś może mi pomóc, jak mam wygenerować te hash? Chcę sprawić, by działał na iOS.Jak wygenerować SHA256 i CRC32 w ios

+2

Czy próbowałeś go uruchomić? – Dani

+0

@Dani tak, zrobiłem. – NSCry

Odpowiedz

32

SHA256 jest dostępny w CommonCrypto. CRC32 nie jest hash, to cykliczna kontrola nadmiarowa.

Przykład Kod:

#import <CommonCrypto/CommonDigest.h> 

NSData *dataIn = [@"Now is the time for all good computers to come to the aid of their masters." dataUsingEncoding:NSASCIIStringEncoding]; 
NSMutableData *macOut = [NSMutableData dataWithLength:CC_SHA256_DIGEST_LENGTH]; 

CC_SHA256(dataIn.bytes, dataIn.length, macOut.mutableBytes); 

NSLog(@"dataIn: %@", dataIn); 
NSLog(@"macOut: %@", macOut); 

NSLog Wydajność:
dataIn: < 4e6f7720 69732074 68652074 696d6520 666f7220 616c6c20 676f6f64 20636f6d 70757465 72732074 6f20636f 6d652074 6f207468 65206169 64206f66 20746865 6972206d 61737465 72732e>

macOut: < 53f89cf6 7ebfbe56 89f1f76a 3843dfd1 09d68c5b a938dcd2 9a12004e 108260cb>

+0

ok.Ale chcę uzyskać wartość CRC32 jakichkolwiek danych.Czy istnieje jakikolwiek sposób, aby uzyskać go w ios? – NSCry

+0

Chcę pracować dla ios.In ios nie znajduję w strukturze zabezpieczeń – NSCry

+0

Tak, Apple się zmienia, ale testowałem to z SDK iOS 5.0. Co do crc32, jest dostępny w wielu bibliotekach, takich jak zlib. – zaph

-4

nie istnieją aplikacje, które mogą generować Hash dla iOS

To powinno działać .... to dla Mac

http://itunes.apple.com/us/app/digiprint/id473233587?mt=12

+5

Dobra próba bycia pomocnym Yagnesh, ale myślę, że oryginalny plakat pyta o programowe generowanie liczb SHA256 i CRC32 dla własnego programu, który ładuje. –

+0

@MichaelDautermann tak, masz rację. czy masz jakieś sugestie? – NSCry

+0

[możesz uzyskać pomocne wskazówki tutaj w powiązanym pytaniu/odpowiedzi] (http://stackoverflow.com/questions/1847281/commoncrypto-is-no-longer-part-of-thone-sdk-where-else -can-i-easily-get-a), @ARC. –

1

W obu przypadkach n wykorzystywać to sens:

https://gist.github.com/paul-delange/6808278

i przykład

NSString* crc32 = (__bridge NSString*)TGDFileHashCreateWithPath((__bridge CFStringRef)filepath, TGDFileHashDefaultChunkSizeForReadingData, TGDChecksumAlgorithmCRC32); 
+0

Cudownie. Dziękuję Ci. – Drakes

0

tej metody generowania crc32c używanego przez gcloud iOS z filePath. Jeśli chcesz standardowego crc32 po prostu odkomentuj drugą wartość dla CRC32_POLYNOMIAL.

Odczytuje plik podany w 512 KB fragmentach, więc może być używany na dużych plikach.

- (NSString*) crc32c:(NSString*)filepath{ 

    /// using crc code from 
    // http://classroomm.com/objective-c/index.php?action=printpage;topic=2891.0 
    // by rgronlie 


    //this is the standard crc32 polynomial 
    //uint32_t CRC32_POLYNOMIAL = 0xEDB88320; 

    //this is the crc32c one 
    uint32_t CRC32_POLYNOMIAL = 0x82F63B78L; 
    uint32_t CRC32C_SEED = 0xFFFFFFFFL; 

    // create and populate a lookup table 
    uint32_t* pCRCTable = malloc(sizeof(uint32_t) * 256); 

    for (uint32_t i = 0; i <= 255; i++) 
    { 
     uint32_t crc32 = i; 
     for (uint32_t j = 8; j > 0; j--) 
     { 
      if ((crc32 & 1) == 1) 
       crc32 = (crc32 >> 1)^CRC32_POLYNOMIAL; 
      else 
       crc32 >>= 1; 
     } 
     pCRCTable[i] = crc32; 
    } 

    // get a handle to the file 
    NSFileHandle *filehandle = [NSFileHandle fileHandleForReadingAtPath:filepath]; 

    if(filehandle == NULL){ 
     NSLog(@"failed to create file handle"); 
     return nil; 
    } 

    // a buffer to read into 
    NSData* databuffer; 

    uint32_t crc = CRC32C_SEED; 

    // read the file in chunks of 512KB 

    while(true){ 
     databuffer = [filehandle readDataOfLength: 512 * 1024]; 

     // if there is nothing left finish 
     if([databuffer length] == 0){ 
      break; 
     } 
     // otherwise run each chunk through the lookup table 
     uint8_t *pBytes = (uint8_t *)[databuffer bytes]; 
     uint32_t length = [databuffer length]; 

     while (length--) 
     { 
      crc = (crc>>8)^pCRCTable[(crc & 0xFF)^*pBytes++]; 
     } 
    } 

    // clean up 
    [filehandle closeFile]; 
    free(pCRCTable); 

    // this is the result 
    uint32_t hash = crc^0xFFFFFFFFL; 

    // reverse it for endianness 
    uint32_t hash_reversed = CFSwapInt32HostToBig(hash); 
    // as raw bytes 
    NSData* hash_data = [NSData dataWithBytes: &hash_reversed length: sizeof(hash_reversed)]; 
    // return base64 encoded 
    return [hash_data base64EncodedStringWithOptions:0]; 
}