0

私のAndroidアプリケーションでは、データアクセスのセキュリティのためにMD5ハッシュキーを使用しています。電子メール+時間+「接尾辞」文字列を使用してキーを生成しています。うまくいっています。+しかし、問題は、のようなプラス()記号が少なくとも1つある電子メールアドレスを使用しているa+b@gmail.com場合、サーバーが「不正なアクセスキー」メッセージを返すことです。マイナス(-)、アンダースコア(_)などの記号が付いたメールアドレスでは機能しますが、プラス(+)記号が付いたメールアドレスでは機能しません。私はこの方法でMD5ハッシュキーを生成しています:

public static String MD5_Hash(String s) {
    try {
        // Create MD5 Hash
        MessageDigest digest = java.security.MessageDigest
                .getInstance("MD5");
        digest.update(s.getBytes());
        byte messageDigest[] = digest.digest();

        // Create Hex String
        StringBuffer hexString = new StringBuffer();
        for (int i = 0; i < messageDigest.length; i++) {
            String h = Integer.toHexString(0xFF & messageDigest[i]);
            while (h.length() < 2)
                h = "0" + h;
            hexString.append(h);
        }
        return hexString.toString();

    } catch (NoSuchAlgorithmException e) {
        e.printStackTrace();
    }
    return "";
}
4

1 に答える 1

-1

これが私のやり方です:-

public static String getMD5(String input) {

 byte[] source;
 try {
     source = input.getBytes("UTF-8");
 } catch (UnsupportedEncodingException e) {
     System.out.println("Error!");
 }

 String result = null;
 char hexDigits[] = {'0', '1', '2', '3', '4', '5', '6', '7',
         '8', '9', 'a', 'b', 'c', 'd', 'e', 'f'};
 try {
     MessageDigest md = MessageDigest.getInstance("MD5");
     md.update(source);
     byte temp[] = md.digest();
     char str[] = new char[16 * 2];
     int k = 0;
     for (int i = 0; i < 16; i++) {
         byte byte0 = temp[i];
         str[k++] = hexDigits[byte0 >>> 4 & 0xf];
         str[k++] = hexDigits[byte0 & 0xf];
     }
     result = new String(str);
 } catch (Exception e) {
 System.out.println("Error!");
}
return result;
}
于 2012-07-24T10:36:46.207 に答える