2011-12-12 19 views
6
ben xcode kullanıyorum

ile düzgün çalışmıyor ve bu benim sha512 yöntemdir:Objective-C SHA2 karma ASCII olmayan

-(NSString*) sha512:(NSString*)input 
{ 
    const char *cstr = [input cStringUsingEncoding:NSUTF8StringEncoding]; 
    NSData *data = [NSData dataWithBytes:cstr length:input.length]; 

    uint8_t digest[CC_SHA512_DIGEST_LENGTH]; 

    CC_SHA512(data.bytes, data.length, digest); 

    NSMutableString* output = [NSMutableString stringWithCapacity:CC_SHA512_DIGEST_LENGTH * 2]; 

    for (int i = 0; i < CC_SHA512_DIGEST_LENGTH; i++) { 
     [output appendFormat:@"%02x", digest[i]]; 
    } 

    return output; 
} 

ben girişi "test" geçmek deneyin döndürür: "ee26b0dd4af7e749aa1a8ee3c10ae9923f618980772e473f8819a5d4940e0db27ac185f8a0e1d5f84f88bc887fd67b143732c304cc5fa9ad8e6f57f50028a8ff Diğer sha512 hash araçlarıyla eşleşen " " (Java programım ve "http://hash.online-convert.com/sha512-generator" dahil). Ancak, "é" gibi ascii olmayan karakterleri girdiğimde, diğer tüm sha512 araçlarından farklı bir şey döndürür. giriş "é" için , benim metot bize: "60313f8521d3016916d876f7ad11cf42a30dfd4ff9bc557f1e2f90e0d37c56b76ab5e42c8a16db20c18086b0d769c08542429c262cc21ee4fba02bfc689a4797" diğer araçları dönüş "9e2ad28633f24451bd4f3c1cb20586a21a44c3aeedbdc01b9cc8fa72917ea7bd689c82b8bf1fef89b911cf8cc46fa2c1ccc10087b2094fd4d3350ecd88526a2c" (yine benim Java programı ve "http://hash.online-convert.com/sha512-generator" dahil).

Hiçbir şeyimi özledim mi? Bununla ilgili bir fikrin var mı? Teşekkürler!

cevap

4

bu gibi NSData nesne oluşturun:

NSData *data = [input dataUsingEncoding:NSUTF8StringEncoding]; 

Sadece çift kontrol ve böyle düzgün çalışır.

+2

Sorun, '- [NSString length]' karakterinin belirli bir kodlamada bu karakterleri temsil etmek için gereken bayt sayısı değil, dizedeki karakter sayısıdır. "é" bir karakterdir, ancak hem bir e hem de bir akut vurgu işareti içerdiği bilgileri kodlayan bazı kodlamalarda birden fazla baytı alabilir. –

+0

Teşekkürler! işe yarıyor! – evanwong

İlgili konular