2

Android アプリに ormlite を使用しています。しかし今、私には問題があります。属性 password を持つクラス ユーザーがいます。暗号化/復号化したい。しかし、ormlite で動作する解決策は見つかりませんでした。誰かアイデアはありますか?暗号化が ormlite でサポートされていないことは既にわかりましたが、ormlite で動作する他のソリューションを探しています。

Dao で den CRUD 操作をオーバーライドすることは可能ですか? (私はアンドロイドに慣れていないので、愚かな質問であれば申し訳ありません)

手伝ってくれてありがとう

4

1 に答える 1

3

DB に格納するクリアテキスト パスワード フィールドを指定せず、暗号化されたパスワードのみを格納します (または、パスワード ハッシュのみを格納することをお勧めします。パスワードをデータベースに格納するための最良の方法を参照してください)。

だからあなたは次のようなものを持つでしょう

class User {
    @DatabaseField(canBeNull = false)
    private String passwordHash;

    public void setPassword(String password) {
        this.passwordHash = hashPassword(password);
    }

    public boolean isPasswordCorrect(String givenPassword) {
        return TextUtils.equals(hasPassword(givenPassword), passwordHash);
    }

    private String hashPassword(String password) {
        return AeSimpleSHA1.SHA1(password);
    }
}

public class AeSimpleSHA1 { 

    private static String convertToHex(byte[] data) { 
        StringBuffer buf = new StringBuffer();
        for (int i = 0; i < data.length; i++) { 
            int halfbyte = (data[i] >>> 4) & 0x0F;
            int two_halfs = 0;
            do { 
                if ((0 <= halfbyte) && (halfbyte <= 9)) 
                    buf.append((char) ('0' + halfbyte));
                else 
                    buf.append((char) ('a' + (halfbyte - 10)));
                halfbyte = data[i] & 0x0F;
            } while(two_halfs++ < 1);
        } 
        return buf.toString();
    } 

    public static String SHA1(String text) 
    throws NoSuchAlgorithmException, UnsupportedEncodingException  { 
        MessageDigest md;
        md = MessageDigest.getInstance("SHA-1");
        byte[] sha1hash = new byte[40];
        md.update(text.getBytes("iso-8859-1"), 0, text.length());
        sha1hash = md.digest();
        return convertToHex(sha1hash);
    } 
} 

How to SHA1 hash a string in Android?から恥知らずにコピーされた SHA1 のもの .

于 2012-04-06T09:02:53.367 に答える