banner
李大仁博客

李大仁博客

天地虽大,但有一念向善,心存良知,虽凡夫俗子,皆可为圣贤。

iOS開発におけるObjective-CでのBASE64エンコードとデコードの使用

BASE64 は一般的に使用される URL 暗号化方式であり、HTTP 環境で長い識別情報を送信するために使用されます。Base64 エンコードは短くなるだけでなく、読み取り不可能性も持っています。

以下のアドレスはエンコードされた Thunder 専用のダウンロードアドレスで、このエンコードが使用されています。thunder://QUFodHRwOi8vd3d3LmJhaWR1LmNvbS9pbWcvc3NsbTFfbG9nby5naWZaWg==

iOS で BASE64 を使用して暗号化と復号化を行う方法も非常に簡単で、google-toolbox-for-mac の GTMBase64.h を直接使用することができます。

google-toolbox-for-mac の対応するアドレスは次のとおりです:http://code.google.com/p/google-toolbox-for-mac/

ここでは、必要なヘルパーオブジェクトを多数見つけることができますが、ここでは以下の 3 つのファイルのみを使用します:GTMDefines.h、GTMBase64.h、GTMBase64.m

ダウンロードアドレス:http://code.google.com/p/google-toolbox-for-mac/source/browse/trunk/Foundation/?r=87

使用方法は次のとおりです:暗号化:

[[NSString alloc] initWithData:[GTMBase64 encodeData]
encoding];

復号化:

[[NSString alloc] initWithData:[GTMBase64 decodeString]
encoding];

以前の MD5 と SHA1 の結果と組み合わせて使用する方法:

  • (NSString *) sha1_base64
    {
    const char *cstr = [self cStringUsingEncoding];
    NSData *data = [NSData dataWithBytes length.length];

    uint8_t digest[CC_SHA1_DIGEST_LENGTH];

    CC_SHA1(data.bytes, data.length, digest);

    NSData * base64 = [[NSData alloc]initWithBytes length_SHA1_DIGEST_LENGTH];
    base64 = [GTMBase64 encodeData];

    NSString * output = [[NSString alloc] initWithData encoding];
    return output;
    }

  • (NSString *) md5_base64
    {
    const char *cStr = [self UTF8String];
    unsigned char digest[CC_MD5_DIGEST_LENGTH];
    CC_MD5( cStr, strlen(cStr), digest );

    NSData * base64 = [[NSData alloc]initWithBytes length_MD5_DIGEST_LENGTH];
    base64 = [GTMBase64 encodeData];

    NSString * output = [[NSString alloc] initWithData encoding];
    return output;
    }

読み込み中...
文章は、創作者によって署名され、ブロックチェーンに安全に保存されています。