iOS开发之Objective-c的SHA224/SHA256/SHA384/SHA512加密算法的实现

之前在博文中实现的SHA1的安全性已经满足不了用户需求,今天把SHA224/SHA256/SHA384/SHA512的实现一并附上。 SHA即Secure Hash Algorithm(安全散列算法)有多种不同位数的实现,常见的有SHA224/SHA256/SHA384/SHA512等 

SHA224:

 
- (NSString*) sha224
{
  const char *cstr = [self cStringUsingEncoding:NSUTF8StringEncoding];
  NSData *data = [NSData dataWithBytes:cstr length:self.length];
 
  uint8_t digest[CC_SHA224_DIGEST_LENGTH];
 
  CC_SHA224(data.bytes, data.length, digest);
 
  NSMutableString* output = [NSMutableString stringWithCapacity:CC_SHA224_DIGEST_LENGTH * 2];
 
  for(int i = 0; i < CC_SHA224_DIGEST_LENGTH; i++)
    [output appendFormat:@"%02x", digest[i]];
 
  return output;
}

SHA256:

 
- (NSString*) sha256
{
  const char *cstr = [self cStringUsingEncoding:NSUTF8StringEncoding];
  NSData *data = [NSData dataWithBytes:cstr length:self.length];
 
  uint8_t digest[CC_SHA256_DIGEST_LENGTH];
 
  CC_SHA256(data.bytes, data.length, digest);
 
  NSMutableString* output = [NSMutableString stringWithCapacity:CC_SHA256_DIGEST_LENGTH * 2];
 
  for(int i = 0; i < CC_SHA256_DIGEST_LENGTH; i++)
    [output appendFormat:@"%02x", digest[i]];
 
  return output;
}

SHA384:

 
- (NSString*) sha384
{
  const char *cstr = [self cStringUsingEncoding:NSUTF8StringEncoding];
  NSData *data = [NSData dataWithBytes:cstr length:self.length];
 
  uint8_t digest[CC_SHA384_DIGEST_LENGTH];
 
  CC_SHA384(data.bytes, data.length, digest);
 
  NSMutableString* output = [NSMutableString stringWithCapacity:CC_SHA384_DIGEST_LENGTH * 2];
 
  for(int i = 0; i < CC_SHA384_DIGEST_LENGTH; i++)
    [output appendFormat:@"%02x", digest[i]];
 
  return output;
}

SHA512:

 
- (NSString*) sha512
{
  const char *cstr = [self cStringUsingEncoding:NSUTF8StringEncoding];
  NSData *data = [NSData dataWithBytes:cstr length:self.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;
}

放到一起大团结

 
//
//NSString+SHA.h
//
 
#import <Foundation/Foundation.h>
#import <CommonCrypto/CommonDigest.h>
#import <CommonCrypto/CommonCryptor.h>
 
@interface NSString(SHA)
-(NSString *) sha1;
-(NSString *) sha224;
-(NSString *) sha256;
-(NSString *) sha384;
-(NSString *) sha512;
@end
 
//
//NSString+SHA.m
//
 
#import "NSString+SHA.h"
 
@implementation NSString(SHA)
 
- (NSString*) sha1
{
  const char *cstr = [self cStringUsingEncoding:NSUTF8StringEncoding];
  NSData *data = [NSData dataWithBytes:cstr length:self.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;
}
 
- (NSString*) sha224
{
  const char *cstr = [self cStringUsingEncoding:NSUTF8StringEncoding];
  NSData *data = [NSData dataWithBytes:cstr length:self.length];
 
  uint8_t digest[CC_SHA224_DIGEST_LENGTH];
 
  CC_SHA224(data.bytes, data.length, digest);
 
  NSMutableString* output = [NSMutableString stringWithCapacity:CC_SHA224_DIGEST_LENGTH * 2];
 
  for(int i = 0; i < CC_SHA224_DIGEST_LENGTH; i++)
    [output appendFormat:@"%02x", digest[i]];
 
  return output;
}
 
- (NSString*) sha256
{
  const char *cstr = [self cStringUsingEncoding:NSUTF8StringEncoding];
  NSData *data = [NSData dataWithBytes:cstr length:self.length];
 
  uint8_t digest[CC_SHA256_DIGEST_LENGTH];
 
  CC_SHA256(data.bytes, data.length, digest);
 
  NSMutableString* output = [NSMutableString stringWithCapacity:CC_SHA256_DIGEST_LENGTH * 2];
 
  for(int i = 0; i < CC_SHA256_DIGEST_LENGTH; i++)
    [output appendFormat:@"%02x", digest[i]];
 
  return output;
}
 
- (NSString*) sha384
{
  const char *cstr = [self cStringUsingEncoding:NSUTF8StringEncoding];
  NSData *data = [NSData dataWithBytes:cstr length:self.length];
 
  uint8_t digest[CC_SHA384_DIGEST_LENGTH];
 
  CC_SHA384(data.bytes, data.length, digest);
 
  NSMutableString* output = [NSMutableString stringWithCapacity:CC_SHA384_DIGEST_LENGTH * 2];
 
  for(int i = 0; i < CC_SHA384_DIGEST_LENGTH; i++)
    [output appendFormat:@"%02x", digest[i]];
 
  return output;
}
 
- (NSString*) sha512
{
  const char *cstr = [self cStringUsingEncoding:NSUTF8StringEncoding];
  NSData *data = [NSData dataWithBytes:cstr length:self.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;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值