Obtendo SHA1 por meio da programação

Dec 11 2020

É algo como o relatório de login do meu aplicativo:

Variant: release
Config: config
Store: C:\Users\Superman\Desktop\web.jks
Alias: web
MD5: 8C:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00
SHA1: D3:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00
SHA-256: A0:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00
Valid until: Sunday, December 4, 2044

Existe uma maneira de obter esse código (MD5, SHA1, SHA-256) por meio da programação do Android? Quero salvar um deles no servidor. Ao usar o aplicativo, esses valores devem ser verificados com os valores armazenados no servidor, caso não seja igual saia e finalize o processo (faço isso para evitar que meu aplicativo seja crackeado)

Respostas

1 MohammadKhairPK Dec 11 2020 at 16:17

Esta resposta foi retirada de outra resposta Verifique esta função

// key like: SHA1, SHA256, MD5.
private fun get(key: String, info: PackageInfo) {
    try {
        for (signature in info.signatures) {
            val md: MessageDigest = MessageDigest.getInstance(key)
            md.update(signature.toByteArray())
            val digest: ByteArray = md.digest()
            val toRet = StringBuilder()
            for (i in digest.indices) {
                if (i != 0) toRet.append(":")
                val b: Byte = digest[i] and 0xff.toByte()
                val hex = Integer.toHexString(b.toInt())
                if (hex.length == 1) toRet.append("0")
                toRet.append(hex)
            }
            Log.d(TAG, "key: $key $toRet")
        }
    } catch (e1: PackageManager.NameNotFoundException) {
        Log.e(TAG, e1.toString())
    } catch (e: NoSuchAlgorithmException) {
        Log.e(TAG, e.toString())
    } catch (e: Exception) {
        Log.e(TAG, e.toString())
    }
}

Para usar, chame assim

get("SHA1", packageManager.getPackageInfo(packageName, PackageManager.GET_SIGNATURES))
1 mingchen Dec 11 2020 at 16:10

Parece que você está procurando uma verificação de versão. Nesse caso, você está entendendo mal o propósito do hashing. O hash serve para verificar a integridade dos dados e não para verificar. Não faz diferença de segurança usar hash ou não, se você estiver apenas enviando o valor e verificando no servidor.