IOS计算MD5值

117 篇文章 0 订阅
73 篇文章 1 订阅

#import <Foundation/Foundation.h>

#import <CommonCrypto/CommonDigest.h>

#define FileHashDefaultChunkSizeForReadingData 1024*8 // 8K

@interface QQYMD5Util : NSObject

//计算NSDataMD5

+(NSString*)getMD5WithData:(NSData*)data;


//计算字符串的MD5值,

+(NSString*)getmd5WithString:(NSString*)string;


//计算大文件的MD5

+(NSString*)getFileMD5WithPath:(NSString*)path;

@end



#import "QQYMD5Util.h"


@implementation QQYMD5Util

+ (NSString*)getmd5WithString:(NSString *)string

{

    const char* original_str=[string UTF8String];

    unsigned char digist[CC_MD5_DIGEST_LENGTH]; //CC_MD5_DIGEST_LENGTH = 16

    CC_MD5(original_str, strlen(original_str), digist);

    NSMutableString* outPutStr = [NSMutableString stringWithCapacity:10];

    for(int  i =0; i<CC_MD5_DIGEST_LENGTH;i++){

        [outPutStr appendFormat:@"%02x", digist[i]];//小写x表示输出的是小写MD5,大写X表示输出的是大写MD5

    }

    return [outPutStr lowercaseString];

}


+ (NSString*)getMD5WithData:(NSData *)data{

    const char* original_str = (const char *)[data bytes];

    unsigned char digist[CC_MD5_DIGEST_LENGTH]; //CC_MD5_DIGEST_LENGTH = 16

    CC_MD5(original_str, strlen(original_str), digist);

    NSMutableString* outPutStr = [NSMutableString stringWithCapacity:10];

    for(int  i =0; i<CC_MD5_DIGEST_LENGTH;i++){

        [outPutStr appendFormat:@"%02x",digist[i]];//小写x表示输出的是小写MD5,大写X表示输出的是大写MD5

    }

    

   //也可以定义一个字节数组来接收计算得到的MD5

    //    Byte byte[16];

    //    CC_MD5(original_str, strlen(original_str), byte);

    //    NSMutableString* outPutStr = [NSMutableString stringWithCapacity:10];

    //    for(int  i = 0; i<CC_MD5_DIGEST_LENGTH;i++){

    //        [outPutStr appendFormat:@"%02x",byte[i]];

    //    }

    //    [temp release];

    

    return [outPutStr lowercaseString];

    

}


+(NSString*)getFileMD5WithPath:(NSString*)path

{

    return ( NSString *)FileMD5HashCreateWithPath((__bridge CFStringRef)path,FileHashDefaultChunkSizeForReadingData);

}


CFStringRef FileMD5HashCreateWithPath(CFStringRef filePath,

                                      size_t chunkSizeForReadingData) {

    

    // Declare needed variables

    CFStringRef result = NULL;

    CFReadStreamRef readStream = NULL;

    

    // Get the file URL

    CFURLRef fileURL =

    CFURLCreateWithFileSystemPath(kCFAllocatorDefault,

                                  (CFStringRef)filePath,

                                  kCFURLPOSIXPathStyle,

                                  (Boolean)false);

    

    CC_MD5_CTX hashObject;

    bool hasMoreData = true;

    bool didSucceed;

    

    if (!fileURL) goto done;

    

    // Create and open the read stream

    readStream = CFReadStreamCreateWithFile(kCFAllocatorDefault,

                                            (CFURLRef)fileURL);

    if (!readStream) goto done;

    didSucceed = (bool)CFReadStreamOpen(readStream);

    if (!didSucceed) goto done;

    

    // Initialize the hash object

    CC_MD5_Init(&hashObject);

    

    // Make sure chunkSizeForReadingData is valid

    if (!chunkSizeForReadingData) {

        chunkSizeForReadingData = FileHashDefaultChunkSizeForReadingData;

    }

    

    // Feed the data to the hash object

    while (hasMoreData) {

        uint8_t buffer[chunkSizeForReadingData];

        CFIndex readBytesCount = CFReadStreamRead(readStream,

                                                  (UInt8 *)buffer,

                                                  (CFIndex)sizeof(buffer));

        if (readBytesCount == -1)break;

        if (readBytesCount == 0) {

            hasMoreData =false;

            continue;

        }

        CC_MD5_Update(&hashObject,(const void *)buffer,(CC_LONG)readBytesCount);

    }

    

    // Check if the read operation succeeded

    didSucceed = !hasMoreData;

    

    // Compute the hash digest

    unsigned char digest[CC_MD5_DIGEST_LENGTH];

    CC_MD5_Final(digest, &hashObject);

    

    // Abort if the read operation failed

    if (!didSucceed) goto done;

    

    // Compute the string result

    char hash[2 *sizeof(digest) + 1];

    for (size_t i =0; i < sizeof(digest); ++i) {

        snprintf(hash + (2 * i),3, "%02x", (int)(digest[i]));

    }

    result = CFStringCreateWithCString(kCFAllocatorDefault,

                                       (const char *)hash,

                                       kCFStringEncodingUTF8);

    

done:

    

    if (readStream) {

        CFReadStreamClose(readStream);

        CFRelease(readStream);

    }

    if (fileURL) {

        CFRelease(fileURL);

    }

    return result;

}

@end

调用事例:

#include "QQYMD5Util.h"  


NSString* filePath;   

NSString* fileMD5 = [QQYMD5Util getFileMD5WithPath:filePath]; 


参考:http://www.cnblogs.com/ios8/p/ios-md5.html


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在iOS上修改视频的MD5,你需要使用AVFoundation框架和CommonCrypto库。下面是一个示例代码,演示如何计算视频的MD5: 首先,导入所需的框架和库: ```swift import AVFoundation import CommonCrypto ``` 然后,定义一个函数来计算视频的MD5: ```swift func calculateMD5(for videoURL: URL) -> String? { guard let file = FileHandle(forReadingAtPath: videoURL.path) else { return nil } let bufferSize = 1024 * 1024 var context = CC_MD5_CTX() CC_MD5_Init(&context) while autoreleasepool(invoking: { let data = file.readData(ofLength: bufferSize) return !data.isEmpty }) { data.withUnsafeBytes { (bytes: UnsafeRawBufferPointer) -> Void in CC_MD5_Update(&context, bytes.baseAddress, numericCast(data.count)) } } var digest = [UInt8](repeating: 0, count: Int(CC_MD5_DIGEST_LENGTH)) CC_MD5_Final(&digest, &context) var md5String = "" for byte in digest { md5String += String(format: "%02x", byte) } return md5String } ``` 使用上述函数,你可以传入视频的URL来计算MD5。示例代码如下: ```swift if let videoURL = Bundle.main.url(forResource: "video", withExtension: "mp4") { if let md5 = calculateMD5(for: videoURL) { print("Video MD5: \(md5)") } else { print("Failed to calculate MD5.") } } else { print("Video file not found.") } ``` 请确保将代码中的“video”替换为你实际的视频文件名。这段代码假设视频文件位于应用的主资源束中。 希望这能帮到你!如果你有任何进一步的问题,请随时问我。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值