【问题标题】:Implementing HMAC encryption algorithm in iPhone application在 iPhone 应用程序中实现 HMAC 加密算法
【发布时间】:2011-08-17 06:14:24
【问题描述】:

我想为我的 iPhone 应用程序实现 HMAC 加密算法。任何示例代码都会有帮助。另外,请指导我的简要实现。

【问题讨论】:

    标签: iphone objective-c cocoa-touch ios encryption


    【解决方案1】:

    使用通用加密函数。 documentation 在手册页中,因此您需要稍微寻找一下。它们位于 iOS 和 Mac OS X 上的 libSystem 中,因此无需向您的项目添加另一个库或框架。从下面的示例可以看出,API 与 OpenSSL 的非常相似。

    如果您真的对加密感兴趣,而不是验证数据,Common Crypto 具有执行 AES 和 3DES(和 DES,但不要使用它,它对于现代需求来说太弱)的功能。请查看CCCryptor 手册页了解详细信息。

    下面的例子相当于运行openssl dgst -md5 -hmac secret < myfile.txt。首先初始化 CCHmacContext,然后只要您有要验证的数据,就调用 CCHmacUpdate。读取所有字节后,调用 CCHmacFinal 将 HMAC 放入缓冲区。我提供了一种将 HMAC 字节转换为可打印十六进制的粗略方法。

    #include <CommonCrypto/CommonHMAC.h>
    
    #include <sys/types.h>
    #include <errno.h>
    #include <fcntl.h>
    #include <stdio.h>
    #include <stdlib.h>
    #include <string.h>
    #include <unistd.h>
    
    extern int      errno;
    
        int
    main( int ac, char *av[] )
    {
        CCHmacContext    ctx;
        char             *key = "secret";
        char             buf[ 8192 ];
        unsigned char    mac[ CC_MD5_DIGEST_LENGTH ];
        char             hexmac[ 2 * CC_MD5_DIGEST_LENGTH + 1 ];
        char             *p;
        int              fd;
        int              rr, i;
    
        if ( ac != 2 ) {
            fprintf( stderr, "usage: %s path\n", av[ 0 ] );
            exit( 1 );
        }
    
        if (( fd = open( av[ 1 ], O_RDONLY )) < 0 ) {
            fprintf( stderr, "open %s: %s\n", av[ 1 ], strerror( errno ));
            exit( 2 );
        }
    
        CCHmacInit( &ctx, kCCHmacAlgMD5, key, strlen( key ));
    
        while (( rr = read( fd, buf, sizeof( buf ))) > 0 ) {
            CCHmacUpdate( &ctx, buf, rr );
        }
        if ( rr < 0 ) {
            perror( "read" );
            exit( 2 );
        }
        CCHmacFinal( &ctx, mac );
    
        (void)close( fd );
    
        p = hexmac;
        for ( i = 0; i < CC_MD5_DIGEST_LENGTH; i++ ) {
            snprintf( p, 3, "%02x", mac[ i ] );
            p += 2;
        }
    
        printf( "%s\n", hexmac );
    
        return( 0 );
    }
    

    【讨论】:

    • 谢谢!我在我们的博客上对此进行了总结,并为 NSString 制作了一个类别以供进一步使用。请参阅blog.blackwhale.at/?p=801。干杯,安卡
    【解决方案2】:

    HMAC 不是一种加密机制,而是一种身份验证摘要。它使用底层消息摘要函数(如 SHA-1、SHA-256、MD5 等)和密钥生成可用于验证数据的代码。

    生成 HMAC 摘要非常简单。这是来自 RFC2104 的描述(通过 Wikipedia)

    让:

    • H(·) 是一个加密哈希函数(即 SHA-1、SHA-256、MD5 等)
    • K 是一个秘密密钥,在散列函数的输入块大小或原始密钥的散列(如果它长于该块大小)的右侧用额外的零填充
    • m 是要认证的消息
    • |表示连接
    • ⊕表示异或(XOR)
    • opad 是外部填充(0x5c5c5c…5c5c,一个块长的十六进制常量)
    • ipad 是内部填充(0x363636…3636,一个块长的十六进制常量)

    那么 HMAC(K,m) 在数学上定义为:

    HMAC(K,m) = H((K ⊕ opad) | H((K ⊕ ipad) | m))。

    对于底层摘要函数,您可以帮助自己使用 OpenSSL 的 C 实现之一。事实上,它还有一个 HMAC 的 C 实现,您可能可以直接使用它。

    【讨论】:

    • 谢谢院长。 IOS 中应该使用哪个 API 来利用 HMAC 身份验证摘要?有示例代码吗?
    • 我认为iOS中没有任何内置API,您必须自己编写。您需要从 OpenSSL 获取源代码并手动将其添加到您的应用程序中。
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2017-10-04
    • 2010-09-16
    • 2011-03-21
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多