iOS开发之Objective-c的MD5/SHA1加密算法的实现

时间:2022-09-27 23:21:13
    1. Objective-c实现MD5和SHA1算法相对还是比较简单的,可以直接调用系统的C/C++共享库来实现调用
    2. MD5即Message Digest Algorithm 5(信息-摘要算法 5),用于确保信息传输完整一致。是计算机广泛使用的杂凑算法之一
    3. SHA即Secure Hash Algorithm(安全散列算法) 是美国国家安全局 (NSA) 设计,美国国家标准与技术研究院 (NIST) 发布的一系列密码散列函数。
    4. 使用方式如下:
    5. MD5加密方式
    6. -(NSString *) md5
    7. {
    8. const charchar *cStr = [self UTF8String];
    9. unsigned char digest[CC_MD5_DIGEST_LENGTH];
    10. CC_MD5( cStr, strlen(cStr), digest );
    11. NSMutableString *output = [NSMutableString stringWithCapacity:CC_MD5_DIGEST_LENGTH * 2];
    12. for(int i = 0; i < CC_MD5_DIGEST_LENGTH; i++)
    13. [output appendFormat:@"%02x", digest[i]];
    14. return output;
    15. }
    16. SHA1加密方式
    17. - (NSString *) sha1:(NSString *)input
      {
          const char *cstr = [input cStringUsingEncoding:NSUTF8StringEncoding];
          NSData *data = [NSData dataWithBytes:cstr length:input.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;
      }
    18. 当然也可以结合BASE64来使用,这里的BASE64编码使用 GTMBase64实现,需要导入
    19. - (NSString *) sha1_base64
    20. {
    21. const charchar *cstr = [self cStringUsingEncoding:NSUTF8StringEncoding];
    22. NSData *data = [NSData dataWithBytes:cstr length:self.length];
    23. uint8_t digest[CC_SHA1_DIGEST_LENGTH];
    24. CC_SHA1(data.bytes, data.length, digest);
    25. NSData * base64 = [[NSData alloc]initWithBytes:digest length:CC_SHA1_DIGEST_LENGTH];
    26. base64 = [GTMBase64 encodeData:base64];
    27. NSString * output = [[NSString alloc] initWithData:base64 encoding:NSUTF8StringEncoding];
    28. return output;
    29. }
    30. - (NSString *) md5_base64
    31. {
    32. const charchar *cStr = [self UTF8String];
    33. unsigned char digest[CC_MD5_DIGEST_LENGTH];
    34. CC_MD5( cStr, strlen(cStr), digest );
    35. NSData * base64 = [[NSData alloc]initWithBytes:digest length:CC_MD5_DIGEST_LENGTH];
    36. base64 = [GTMBase64 encodeData:base64];
    37. NSString * output = [[NSString alloc] initWithData:base64 encoding:NSUTF8StringEncoding];
    38. return output;
    39. }
    40. 通过拓展NSString,实现完整功能,全部代码
    41. @interface NSString (encrypto)
    42. - (NSString *) md5;
    43. - (NSString *) sha1;
    44. - (NSString *) sha1_base64;
    45. - (NSString *) md5_base64;
    46. - (NSString *) base64;
    47. @end
    48. @implementation NSString (encrypto)
    49. - (NSString*) sha1
    50. {
    51. const charchar *cstr = [self cStringUsingEncoding:NSUTF8StringEncoding];
    52. NSData *data = [NSData dataWithBytes:cstr length:self.length];
    53. uint8_t digest[CC_SHA1_DIGEST_LENGTH];
    54. CC_SHA1(data.bytes, data.length, digest);
    55. NSMutableString* output = [NSMutableString stringWithCapacity:CC_SHA1_DIGEST_LENGTH * 2];
    56. for(int i = 0; i < CC_SHA1_DIGEST_LENGTH; i++)
    57. [output appendFormat:@"%02x", digest[i]];
    58. return output;
    59. }
    60. -(NSString *) md5
    61. {
    62. const charchar *cStr = [self UTF8String];
    63. unsigned char digest[CC_MD5_DIGEST_LENGTH];
    64. CC_MD5( cStr, strlen(cStr), digest );
    65. NSMutableString *output = [NSMutableString stringWithCapacity:CC_MD5_DIGEST_LENGTH * 2];
    66. for(int i = 0; i < CC_MD5_DIGEST_LENGTH; i++)
    67. [output appendFormat:@"%02x", digest[i]];
    68. return output;
    69. }
    70. - (NSString *) sha1_base64
    71. {
    72. const charchar *cstr = [self cStringUsingEncoding:NSUTF8StringEncoding];
    73. NSData *data = [NSData dataWithBytes:cstr length:self.length];
    74. uint8_t digest[CC_SHA1_DIGEST_LENGTH];
    75. CC_SHA1(data.bytes, data.length, digest);
    76. NSData * base64 = [[NSData alloc]initWithBytes:digest length:CC_SHA1_DIGEST_LENGTH];
    77. base64 = [GTMBase64 encodeData:base64];
    78. NSString * output = [[NSString alloc] initWithData:base64 encoding:NSUTF8StringEncoding];
    79. return output;
    80. }
    81. - (NSString *) md5_base64
    82. {
    83. const charchar *cStr = [self UTF8String];
    84. unsigned char digest[CC_MD5_DIGEST_LENGTH];
    85. CC_MD5( cStr, strlen(cStr), digest );
    86. NSData * base64 = [[NSData alloc]initWithBytes:digest length:CC_MD5_DIGEST_LENGTH];
    87. base64 = [GTMBase64 encodeData:base64];
    88. NSString * output = [[NSString alloc] initWithData:base64 encoding:NSUTF8StringEncoding];
    89. return output;
    90. }
    91. - (NSString *) base64
    92. {
    93. NSData * data = [self dataUsingEncoding:NSASCIIStringEncoding allowLossyConversion:YES];
    94. data = [GTMBase64 encodeData:data];
    95. NSString * output = [[NSString alloc] initWithData:data encoding:NSUTF8StringEncoding];
    96. return output;
    97. }
    98. @end
    99. 实现时候不要忘记导入CC相关的库的头文件
    100. CommonCrypto/CommonDigest.h