Ottenere SHA1 tramite la programmazione

Dec 11 2020

Questo è qualcosa come la mia app per il rapporto di firma:

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

C'è un modo per ottenere questo codice (MD5, SHA1, SHA-256) tramite la programmazione Android? Voglio salvarne uno sul server. Quando si utilizza l'app, questi valori dovrebbero essere controllati con i valori memorizzati nel server, se non è uguale uscire e terminare il processo (lo faccio per evitare che la mia app si rompa)

Risposte

1 MohammadKhairPK Dec 11 2020 at 16:17

Questa risposta è presa da un'altra risposta Controlla questa funzione

// 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())
    }
}

Per usarlo chiamalo così

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

Sembra che tu stia cercando un controllo della versione. Se è così, stai fraintendendo lo scopo dell'hashing. L'hashing serve per controllare l'integrità dei dati e non per la verifica. Non fa differenza di sicurezza usare hash o meno, se stai solo caricando il valore e controllandolo nel server.