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); 设置不填充可以解决上述问题。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容