Golang MD5算法与 java(android)的互通

对MD5加密来说,惟一要注意的就是加密完的Base64加密后,Android使用自己的标准util库时,一定要设置无填充方式,加密结果转成base64。如下所示:

  1. java
  MessageDigest md5 = null;
        try {
            md5 = MessageDigest.getInstance("MD5");
            md5.update(val.getBytes());
            byte[] m = md5.digest();//加密
           // BASE64Encoder encoder = new BASE64Encoder();
            //血坑!!!!!!!!!!!!!
           return Base64.encodeToString(m,Base64.NO_WRAP);
        } catch (NoSuchAlgorithmException e) {
            e.printStackTrace();
        }
        return null;
  1. go
func MD5(src string)(string)  {
    md5Ctx := md5.New()
    md5Ctx.Write([]byte(src))
    cipherStr := md5Ctx.Sum(nil)
    fmt.Print(cipherStr)
    return base64.StdEncoding.EncodeToString(cipherStr)
}

Android使用md5加密后,再用android标准的Base64加密后,最后会多一个换行符,我的处理方法是,Base64.encodeToString(m,Base64.NO_WRAP); 设置不填充可以解决上述问题。

    原文作者:送你一碗大麦茶
    原文地址: https://www.jianshu.com/p/ab8fd56edab9
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞