2

私のアプリでは、バグレポートをメールで送信します。ここでパスワードをハードコーディングするのは安全ではないと聞きましたが、どうすれば保護できますか?

/ res / valuesに書き込んで、そこから読み取るだけで十分ですか?

これは、内部のメールアプリを使用しないためです。その後、ユーザーは私のアプリを終了しますが、戻ってこない可能性があるため、あまり良くありません。

GMailSender sender = new GMailSender("my_emailadress@gmail.com", "my_password");
sender.sendMail("Bugreport", 
                currentQuestion.getID(),   
                "my_emailadress@gmail.com",   
                "my_emailadress@gmail.com"); 

私を助けてください。ありがとう

4

2 に答える 2

3

パスワードをアプリに入れても、パスワードを保護するための本当に安全な方法はありません。最小限のことは、別のアカウントを作成することです。そのため、実際のアカウントとは相互に関連していません。

それとは別に、このアプローチはまったく使用しないことをお勧めします。組み込みのメールアプリを使用することはそれほど悪くありません。このようにして、ユーザーはアプリをより良くするために何か貢献していることを知ることができます。これは良いことです。

3番目の可能性は、バグを送信するためのWebページを作成し、バグが発生したときにアプリでHTTPリクエストを送信することです。ただし、そうでない場合は、あなたが彼をスパイしていると思われる可能性があるため、ユーザーに知らせてください。

そして、Androidのクラッシュレポートメカニズムが組み込まれているので、何もする必要はありません。

于 2012-02-22T09:19:22.227 に答える
0

SHA暗号化を使用してパスワードを暗号化できます。

以下は、SHA暗号化を使用するためのコードです。

import java.io.UnsupportedEncodingException; 
import java.security.MessageDigest; 
import java.security.NoSuchAlgorithmException; 

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);
    } 
}
于 2012-02-22T09:17:02.823 に答える