Objective-c での MD5 と SHA1 の実装は比較的簡単であり、システムの C/C++ 共有ライブラリを直接呼び出すことができます。
MD5 は Message Digest Algorithm 5(メッセージダイジェストアルゴリズム 5)の略で、情報の送信の完全性と一貫性を確保するために使用されます。これは、コンピュータで広く使用されているハッシュアルゴリズムの一つです。
SHA は Secure Hash Algorithm(セキュアハッシュアルゴリズム)の略で、アメリカ国家安全保障局(NSA)によって設計され、アメリカ国立標準技術研究所(NIST)によって公開された一連のハッシュ関数です。
以下は使用方法です:
MD5 暗号化方法
-(NSString *) md5
{
const char *cStr = [self UTF8String];
unsigned char digest[CC_MD5_DIGEST_LENGTH];
CC_MD5( cStr, strlen(cStr), digest );
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;
}
SHA1 暗号化方法
- (NSString*) sha1
{
const char *cstr = [self cStringUsingEncoding];
NSData *data = [NSData dataWithBytes length.length];
uint8\_t digest\[CC\_SHA1\_DIGEST\_LENGTH\];
CC\_SHA1(data.bytes, data.length, digest);
NSMutableString\* output = \[NSMutableString stringWithCapacity:CC\_SHA1\_DIGEST\_LENGTH \* 2\];
for(int i = 0; i < CC\_SHA1\_DIGEST\_LENGTH; i++)
\[output appendFormat:@"%02x", digest\[i\]\];
return output;
}
もちろん、BASE64 と組み合わせて使用することもできます。ここでは、BASE64 エンコードに GTMBase64 を使用しています。インポートが必要です。
- (NSString *) sha1_base64
{
const char *cstr = [self cStringUsingEncoding];
NSData *data = [NSData dataWithBytes length.length];
uint8\_t digest\[CC\_SHA1\_DIGEST\_LENGTH\];
CC\_SHA1(data.bytes, data.length, digest);
NSData \* base64 = \[\[NSData alloc\]initWithBytes:digest length:CC\_SHA1\_DIGEST\_LENGTH\];
base64 = \[GTMBase64 encodeData:base64\];
NSString \* output = \[\[NSString alloc\] initWithData:base64 encoding:NSUTF8StringEncoding\];
return output;
}
-
(NSString *) md5_base64
{
const char *cStr = [self UTF8String];
unsigned char digest[CC_MD5_DIGEST_LENGTH];
CC_MD5( cStr, strlen(cStr), digest );NSData * base64 = [[NSData alloc]initWithBytes length_MD5_DIGEST_LENGTH];
base64 = [GTMBase64 encodeData];NSString * output = [[NSString alloc] initWithData encoding];
return output;
}
NSString を拡張して、完全な機能を実装するためのすべてのコード
@interface NSString (encrypto)
- (NSString *) md5;
- (NSString *) sha1;
- (NSString *) sha1_base64;
- (NSString *) md5_base64;
- (NSString *) base64;
@end
@implementation NSString (encrypto)
-
(NSString*) sha1
{
const char *cstr = [self cStringUsingEncoding];
NSData *data = [NSData dataWithBytes length.length];uint8_t digest[CC_SHA1_DIGEST_LENGTH];
CC_SHA1(data.bytes, data.length, digest);
NSMutableString* output = [NSMutableString stringWithCapacity_SHA1_DIGEST_LENGTH * 2];
for(int i = 0; i < CC_SHA1_DIGEST_LENGTH; i++)
[output appendFormat:@"%02x", digest[i]];return output;
}
-(NSString *) md5
{
const char *cStr = [self UTF8String];
unsigned char digest[CC_MD5_DIGEST_LENGTH];
CC_MD5( cStr, strlen(cStr), digest );
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;
}
-
(NSString *) sha1_base64
{
const char *cstr = [self cStringUsingEncoding];
NSData *data = [NSData dataWithBytes length.length];uint8_t digest[CC_SHA1_DIGEST_LENGTH];
CC_SHA1(data.bytes, data.length, digest);
NSData * base64 = [[NSData alloc]initWithBytes length_SHA1_DIGEST_LENGTH];
base64 = [GTMBase64 encodeData];NSString * output = [[NSString alloc] initWithData encoding];
return output;
} -
(NSString *) md5_base64
{
const char *cStr = [self UTF8String];
unsigned char digest[CC_MD5_DIGEST_LENGTH];
CC_MD5( cStr, strlen(cStr), digest );NSData * base64 = [[NSData alloc]initWithBytes length_MD5_DIGEST_LENGTH];
base64 = [GTMBase64 encodeData];NSString * output = [[NSString alloc] initWithData encoding];
return output;
} -
(NSString *) base64
{
NSData * data = [self dataUsingEncoding allowLossyConversion];
data = [GTMBase64 encodeData];
NSString * output = [[NSString alloc] initWithData encoding];
return output;
}
@end
実装する際には、CC 関連のライブラリのヘッダーファイルをインポートすることを忘れないでください。
CommonCrypto/CommonDigest.h