这篇文章,我们来获取一下文件的SHA1。此方法主要用于文件比对,比如云空间上传文件时,需要提前判断文件之前是否存在于与空间之上。(一般配合MD5使用,SHA1 和 SHA256 的使用方法一样咱们下面说)。
1、SHA的简介
安全散列算法(Secure Hash Algorithm,缩写为SHA),是FIPS所认证的安全散列算法。能计算出一个数字消息所对应到的长度固定的字符串(又称消息摘要)的算法。且若输入的讯息不同,它们对应到不同字串的机率很高;而SHA是FIPS所认证的五种安全杂凑算法。。这些算法之所以称作“安全”是基于以下两点(根据官方标准的描述):1、由讯息摘要反推原输入讯息,从计算理论上来说是很困难的。2、想要找到两组不同的讯息对应到相同的讯息摘要,从计算理论上来说也是很困难的。任何对输入讯息的变动,都有很高的机率导致其产生的讯息摘要迥异。
SHA家族的五个算法,分别是SHA-1、SHA-224、SHA-256、SHA-384,和SHA-512,由美国国家安全局(NSA)所设计,并由美国国家标准与技术研究院(NIST)发布;是美国的政府标准。
2、获取文件的SHA1 - 直接上代码
//
// ViewController.m
// ToReport
//
// Created by 司小文 on 2017/12/28.
// Copyright © 2017年 司小文. All rights reserved.
//
#import "ViewController.h"
#include <CommonCrypto/CommonDigest.h>
@interface ViewController ()
@end
@implementation ViewController
- (void)viewDidLoad {
[super viewDidLoad];
NSString *filePath = [[NSBundle mainBundle] pathForResource:@"agree@3x" ofType:@"png"];
NSString *str_SHA1 = [self sha1OfPath:filePath];
NSLog(@"xxx = %@",str_SHA1);
}
#pragma mark 获取文件sha1标签
-(NSString *)sha1OfPath:(NSString *)path
{
NSFileManager *fileManager = [NSFileManager defaultManager];
// Make sure the file exists
if( [fileManager fileExistsAtPath:path isDirectory:nil] )
{
NSData *data = [NSData dataWithContentsOfFile:path];
unsigned char digest[CC_SHA1_DIGEST_LENGTH];
CC_SHA1( data.bytes, (CC_LONG)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;
}
else
{
return @"";
}
}
- (void)didReceiveMemoryWarning {
[super didReceiveMemoryWarning];
// Dispose of any resources that can be recreated.
}
@end
3、获取文件的SHA256 - 只是吧上方,方法中的sha1全部改为sha256就可以了(PS: SHA-224、SHA-256、SHA-384,和SHA-512 都是直接把sha1替换了就可以了)
如果需要验证 可以去http://www.atool.org/file_hash.php 和代码结果进行对比。
感谢观看,学以致用更感谢!