AndroidのNDK JNIエントリーノート-day04-NDKハッシュアルゴリズムを達成

* AndroidのNDK JNIのディレクトリエントリのメモ*

初め

以前の研究では、我々は必要な知識NDK開発をマスターしています。

次のステップは、問題の作成を通じて、より多くの練習で、体験を向上させる能力を高めるために、問題を解決します。

毎日の開発は、頻繁に使用されるMD5 SHA1 SHA256ハッシュアルゴリズムなど、私たちはネイティブでこれらの機能を実装することができます。

ハッシュアルゴリズム

HASHは、主に情報セキュリティ暗号化アルゴリズム、彼が面倒と呼ばれるHASH値の128ビットコードの異なる長さに変換された情報のいくつかの分野で使用されます。ハッシュは、データコンテンツおよびデータ格納アドレス間のマッピング関係を見つけることである、と言うことができます。

Androidの開発、証明書の拇印を確認してください。

アンドロイド-CERT-指紋

ハンズ

前と同じようにネイティブC ++プロジェクトテンプレートを作成します

プロジェクト準備

day04-例-プレビュー

オープンソースのC ++ライブラリのハッシュアルゴリズムの選択

ポータブルC ++ハッシュライブラリ

CPP-ハッシュライブラリー

C ++ソースコードライブラリを導入するには、Androidプロジェクト

アンドロイド使用-CPP-ライブラリのソース

CMakeLists.txt

cmake_minimum_required(VERSION 3.4.1)

# 该命令会查找指定目录下的所有源文件,然后将结果存进指定变量名
aux_source_directory(hash-library HASH_LIBRARY_SRC)
# 添加头文件搜索目录
include_directories(hash-library)

add_library(
             native-lib

             SHARED
             
             # 将 hash-library 源文件添加进来
             native-lib.cpp ${HASH_LIBRARY_SRC})

find_library(
              log-lib
              log )

target_link_libraries( 
                       native-lib
                       ${log-lib} )

機能を実現

MD5

Javaのバージョン:

public static String md5(String plainText) {
    try {
        MessageDigest md5 = MessageDigest.getInstance("MD5");
        byte[] md5Byte = md5.digest(plainText.getBytes());
        return byteArrayToString(md5Byte);
    } catch (Exception e) {
        return "";
    }
}

ネイティブバージョン:

extern "C"
JNIEXPORT jstring JNICALL
Java_com_ihubin_ndkjni_NativeUtil_md5(JNIEnv *env, jclass clazz, jstring plaintext) {
    const char * plaintextChar = env->GetStringUTFChars(plaintext, 0);
    std::string plaintextStr = std::string(plaintextChar);
    
    MD5 md5;
    std::string md5String = md5(plaintextStr);
    char * tabStr = new char [md5String.length()+1];
    strcpy(tabStr, md5String.c_str());
    
    char md5Result[128] = {0};
    formatSignature(tabStr, md5Result);
    return env->NewStringUTF(md5Result);
}

SHA1

Javaのバージョン:

public static String sha1(String plainText) {
    try {
        MessageDigest sha1 = MessageDigest.getInstance("SHA1");
        byte[] sha1Byte = sha1.digest(plainText.getBytes());
        return byteArrayToString(sha1Byte);
    } catch (Exception e) {
        return "";
    }
}

ネイティブバージョン:

extern "C"
JNIEXPORT jstring JNICALL
Java_com_ihubin_ndkjni_NativeUtil_sha1(JNIEnv *env, jclass clazz, jstring plaintext) {
    const char * plaintextChar = env->GetStringUTFChars(plaintext, 0);
    std::string plaintextStr = std::string(plaintextChar);
    
    SHA1 sha1;
    std::string sha1String = sha1(plaintextStr);
    char * tabStr = new char [sha1String.length()+1];
    strcpy(tabStr, sha1String.c_str());
    
    char sha1Result[128] = {0};
    formatSignature(tabStr, sha1Result);
    return env->NewStringUTF(sha1Result);
}

SHA256

Javaのバージョン:

public static String sha256(String plainText) {
    try {
        MessageDigest sha256 = MessageDigest.getInstance("SHA256");
        byte[] sha256Byte = sha256.digest(plainText.getBytes());
        return byteArrayToString(sha256Byte);
    } catch (Exception e) {
        return "";
    }
}

ネイティブバージョン:

extern "C"
JNIEXPORT jstring JNICALL
Java_com_ihubin_ndkjni_NativeUtil_sha256(JNIEnv *env, jclass clazz, jstring plaintext) {
    const char * plaintextChar = env->GetStringUTFChars(plaintext, 0);
    std::string plaintextStr = std::string(plaintextChar);
    
    SHA256 sha256;
    std::string sha256String = sha256(plaintextStr);
    char * tabStr = new char [sha256String.length()+1];
    strcpy(tabStr, sha256String.c_str());
    
    char sha256Result[128] = {0};
    formatSignature(tabStr, sha256Result);
    return env->NewStringUTF(sha256Result);
}

最終結果

day04-例-結果

これまでのところ、我々はC ++ライブラリでのAndroidのオープンソースプロジェクトで参照学んできた、我々はまた、リアライズハッシュアルゴリズムネイティブを実現します。


コード:

NDKJNIday04

参考文献:

オラクル - JNIの型とデータ構造

C ++ハッシュライブラリー

CMakeの入門します


おすすめ

転載: www.cnblogs.com/binglingziyu/p/android-ndk-jni-basic-day04.html