Цель C: SHA1 - PullRequest
       39

Цель C: SHA1

30 голосов
/ 12 августа 2010

Как мне вычислить строку или набор чисел в Objective c?

Ответы [ 3 ]

63 голосов
/ 12 августа 2010

CommonCrypto (фреймворк Apple) имеет функции для вычисления хэшей SHA-1, включая одношаговый хеш:

#include <CommonCrypto/CommonDigest.h>

unsigned char digest[CC_SHA1_DIGEST_LENGTH];
NSData *stringBytes = [someString dataUsingEncoding: NSUTF8StringEncoding]; /* or some other encoding */
if (CC_SHA1([stringBytes bytes], [stringBytes length], digest)) {
    /* SHA-1 hash has been calculated and stored in 'digest'. */
    ...
}

Для набора чисел предположим, что вы имеете в виду массив целых чиселизвестная длинаДля таких данных проще итеративно построить дайджест, чем использовать функцию однократного использования:

unsigned char digest[CC_SHA1_DIGEST_LENGTH];
uint32_t *someIntegers = ...;
size_t numIntegers = ...;

CC_SHA1_CTX ctx;
CC_SHA1_Init(&ctx);
{
    for (size_t i = 0; i < numIntegers; i++)
        CC_SHA1_Update(&ctx, someIntegers + i, sizeof(uint32_t));
}
CC_SHA1_Final(digest, &ctx);

/* SHA-1 hash has been calculated and stored in 'digest'. */
...

Обратите внимание, что это не учитывает порядок байтов.SHA-1, рассчитанный с помощью этого кода в системе PowerPC, будет отличаться от кода, рассчитанного для системы i386 или ARM.Решение простое - перед выполнением вычисления поменяйте местами байты целых чисел с известным порядком байтов:

    for (size_t i = 0; i < numIntegers; i++) {
        uint32_t swapped = CFSwapInt32HostToLittle(someIntegers[i]); /* or HostToBig */
        CC_SHA1_Update(&ctx, &swapped, sizeof(swapped));
    }
4 голосов
/ 27 августа 2013

Другое решение с библиотекой дайджеста сообщений (nv-ios-digest):

(1) Строка

// Create an SHA1 instance, update it with a string and do final.
SHA1 sha1 = [SHA1 sha1WithString:@"Hello"];

// Get the pointer of the internal buffer that holds the message digest value.
// The life of the internal buffer ends when the SHA1 instance is discarded.
// Copy the buffer as necessary. The size of the buffer can be obtained by
// 'bufferSize' method.
unsigned char *digestAsBytes = [sha1 buffer];

// Get the string expression of the message digest value.
NSString *digestAsString = [sha1 description];

(2) Числа

// Create an SHA1 instance.
SHA1 sha1 = [[SHA1 alloc] init];

// Update the SHA1 instance with numbers.
// (Sorry, the current implementation is endianness-dependent.)
[sha1 updateWithShort:(short)1];
[sha1 updateWithInt:(int)2];
[sha1 updateWithLong:(long)3];
[sha1 updateWithLongLong:(long long)4];
[sha1 updateWithFloat:(float)5];
[sha1 updateWithDouble:(double)6];

// Do final. 'final' method returns the pointer of the internal buffer
// that holds the message digest value. 'buffer' method returns the same.
// The life of the internal buffer ends when the SHA1 instance is discarded.
// Copy the buffer as necessary. The size of the buffer can be obtained by
// 'bufferSize' method.
unsigned char *digestAsBytes = [sha1 final];

// Get the string expression of the message digest value.
NSString *digestAsString = [sha1 description];

Библиотека дайджеста сообщений поддерживает MD5, SHA-1, SHA-224, SHA-256, SHA-384 и SHA-512.

[Блог] Дайджесты сообщений (MD5, SHA1 и т. Д.) На iOS с выделенными классами
http://darutk -oboegaki.blogspot.jp / 2013/04 / сообщение-дайджесты-md5-sha1-и т.д.-на-ios.html

[Библиотека] nv-ios-digest
https://github.com/TakahikoKawasaki/nv-ios-digest

2 голосов
/ 12 августа 2010

SHA1 на самом деле не поставляется с Objective-C.Вы можете использовать исходный код C для hashdeep и друзей, который лицензирован как общественное достояние (поскольку он был написан сотрудником правительства США): http://md5deep.sourceforge.net/.

...