Алгоритм MD5 в Objective-C - PullRequest
       85

Алгоритм MD5 в Objective-C

133 голосов
/ 06 октября 2009

Как рассчитать MD5 в Objective-C?

Ответы [ 5 ]

218 голосов
/ 03 января 2010

md5 доступно на iPhone и может быть добавлено как дополнение, например, NSString и NSData, как показано ниже.

MyAdditions.h

@interface NSString (MyAdditions)
- (NSString *)md5;
@end

@interface NSData (MyAdditions)
- (NSString*)md5;
@end

MyAdditions.m

#import "MyAdditions.h"
#import <CommonCrypto/CommonDigest.h> // Need to import for CC_MD5 access

@implementation NSString (MyAdditions)
- (NSString *)md5
{
    const char *cStr = [self UTF8String];
    unsigned char result[CC_MD5_DIGEST_LENGTH];
    CC_MD5( cStr, (int)strlen(cStr), result ); // This is the md5 call
    return [NSString stringWithFormat:
        @"%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x",
        result[0], result[1], result[2], result[3], 
        result[4], result[5], result[6], result[7],
        result[8], result[9], result[10], result[11],
        result[12], result[13], result[14], result[15]
        ];  
}
@end

@implementation NSData (MyAdditions)
- (NSString*)md5
{
    unsigned char result[CC_MD5_DIGEST_LENGTH];
    CC_MD5( self.bytes, (int)self.length, result ); // This is the md5 call
    return [NSString stringWithFormat:
        @"%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x",
        result[0], result[1], result[2], result[3], 
        result[4], result[5], result[6], result[7],
        result[8], result[9], result[10], result[11],
        result[12], result[13], result[14], result[15]
        ];  
}
@end

EDIT

Добавлен NSData md5, потому что я сам нуждался в этом и думал, что это хорошее место для сохранения этого небольшого фрагмента ...

Эти методы проверены с использованием тестовых векторов NIST MD5 в http://www.nsrl.nist.gov/testdata/

53 голосов
/ 03 июня 2013

Для этого вы можете использовать встроенную библиотеку Common Crypto. Не забудьте импортировать:

#import <CommonCrypto/CommonDigest.h>

и затем:

- (NSString *) md5:(NSString *) input
{
    const char *cStr = [input UTF8String];
    unsigned char digest[CC_MD5_DIGEST_LENGTH];
    CC_MD5( cStr, strlen(cStr), digest ); // This is the md5 call

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

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

    return  output;
}
9 голосов
/ 03 июня 2014

Если важна производительность, вы можете использовать эту оптимизированную версию. Это примерно в 5 раз быстрее, чем с stringWithFormat или NSMutableString.

Это категория NSString.

- (NSString *)md5
{
    const char* cStr = [self UTF8String];
    unsigned char result[CC_MD5_DIGEST_LENGTH];
    CC_MD5(cStr, strlen(cStr), result);

    static const char HexEncodeChars[] = { '0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'a', 'b', 'c', 'd', 'e', 'f' };
    char *resultData = malloc(CC_MD5_DIGEST_LENGTH * 2 + 1);

    for (uint index = 0; index < CC_MD5_DIGEST_LENGTH; index++) {
        resultData[index * 2] = HexEncodeChars[(result[index] >> 4)];
        resultData[index * 2 + 1] = HexEncodeChars[(result[index] % 0x10)];
    }
    resultData[CC_MD5_DIGEST_LENGTH * 2] = 0;

    NSString *resultString = [NSString stringWithCString:resultData encoding:NSASCIIStringEncoding];
    free(resultData);

    return resultString;
}
0 голосов
/ 13 марта 2015

Любая причина не использовать реализацию Apple: https://developer.apple.com/library/mac/documentation/Security/Conceptual/cryptoservices/GeneralPurposeCrypto/GeneralPurposeCrypto.html#//apple_ref/doc/uid/TP40011172-CH9-SW1

Поиск руководства по службам криптографии на сайте разработчиков Apple.

0 голосов
/ 20 мая 2014

Ну, так как люди спрашивали о версии файлового потока. Я изменил симпатичный небольшой фрагмент, созданный Джоэлем Лопесом Да Силвой, который работает с MD5, SHA1 и SHA512, и использует потоковые потоки Он сделан для iOS, но работает с минимальными изменениями в OSX, а также (удалите метод ALAssetRepresentation). Он может создавать контрольные суммы для файлов с заданным путем к файлу или ALAssets (используя ALAssetRepresentation). Он объединяет данные в небольшие пакеты, что делает воздействие на память минимальным независимо от размера файла / размера ресурса.

В настоящее время он находится на github здесь: https://github.com/leetal/FileHash

...