终端开发

使用Android Studio开发可独立运行(runnable)混淆过的Jar程序 Android安装包精简系列之资源精简 Android安装包精简系列之图片优化 Android安装包精简系列之为什么要优化精简安装包 Android安装包精简系列(总纲) Android安装包精简系列之图标转字体 gradle相关资料汇总 Android编译常见错误解决 Android编译编译速度提升 终端基于gradle的开源项目运行环境配置指引 制作终端产品演示的gif 一个关于APK Signature Scheme v2签名的神奇bug定位经历 如何随apk一起打包并使用SQLite SDK热更之gradle插件(如何在SDK代码中自动插桩及如何生成补丁包) 关于Android的APK Signature Scheme v2签名相关的资料汇总 封装HttpURLConnection实现的简单的网络请求库 一款基于Java环境的读取应用包名、签名、是否V2签名等基本信息的工具 Android的APK Signature Scheme v2签名及一款基于Java环境的校验工具介绍 如何使用Eclipse开发可执行Jar程序,并生成混淆过的jar程序 Android 相关的学习资料整理(持续更新) macOS(Sierra 10.12)上Android源码(AOSP)的下载、编译与导入到Android Studio Google也看不下去被玩坏的悬浮窗了么? Android开发常用工具资源 SDK热更系列之概述(持续整理编辑中~) SDK热更系列之SDKHotfix待优化点 Android 终端开发相关的一些神图(持续更新) SDK热更系列之Demo项目介绍概述 SDK热更系列之Demo体验方法 SDK热更系列之如何获取应用在当前设备上的so对应的指令集 Gradle Android插件使用的中那些特别注意的点 Experimental Plugin User Guide(From Android Tools Project Site) 基于Android Studio使用gradle构建包含jni以及so的构建实例 基于Instrumentation框架的自动化测试 - Android自动化测试系列(四) Instrumentation框架介绍-Android自动化测试系列(三) 关于终端设备的设备唯一性的那些事之MAC地址 关于终端设备的设备唯一性的那些事之IMEI Android 检查应用是否有root权限 ant常见错误解决方案 Gradle介绍 iMac上Android Studio 相关设置及常见问题 再说adb 再看Android官方文档之分享 再看Android官方文档之Fragment&数据保存 再看Android官方文档之Activity&Intent 再看Android官方文档之ActionBar和兼容性 adb shell input(Android模拟输入)简单总结 再看Android官方文档之建立第一个APP Android开发调试常用工具 ANR(网络资料整理) Java参数引用传递引发的惨案(又一次Java的String的“非对象”特性的踩坑经历) android.view.WindowManager$BadTokenException,Unable to add window Android签名校验机制(数字证书) Robotium二三事-Android自动化测试系列(二) Robotium介绍-Android自动化测试系列(一) Android开发中遇到的那些坑 Eclipse使用中部分经验总结 Android中关于Nativa编译(NDK、JNI)的一些问题 Android简单实现的多线程下载模块 Android内存耗用之VSS/RSS/PSS/USS adb Advanced Command URL编码中的空格(编码以后变为+) Android MD5后 bye数组转化为Hex字符串的坑(记一次为女神排忧解难的经历) Android学习之路 adb Base Command Android Log的那些坑…………

标签

android 46

Android编译常见错误解决 一个关于APK Signature Scheme v2签名的神奇bug定位经历 关于Android的APK Signature Scheme v2签名相关的资料汇总 封装HttpURLConnection实现的简单的网络请求库 一款基于Java环境的读取应用包名、签名、是否V2签名等基本信息的工具 Android的APK Signature Scheme v2签名及一款基于Java环境的校验工具介绍 如何使用Eclipse开发可执行Jar程序,并生成混淆过的jar程序 Android 相关的学习资料整理(持续更新) macOS(Sierra 10.12)上Android源码(AOSP)的下载、编译与导入到Android Studio Android开发常用命令备忘 Google也看不下去被玩坏的悬浮窗了么? Android开发常用工具资源 Android 终端开发相关的一些神图(持续更新) Gradle Android插件使用的中那些特别注意的点 Experimental Plugin User Guide(From Android Tools Project Site) iMac(OS X)搭建私有maven仓库,提供Nexus Responsitory镜像 基于Android Studio使用gradle构建包含jni以及so的构建实例 基于Instrumentation框架的自动化测试 - Android自动化测试系列(四) Instrumentation框架介绍-Android自动化测试系列(三) 关于终端设备的设备唯一性的那些事之MAC地址 关于终端设备的设备唯一性的那些事之IMEI Android 检查应用是否有root权限 iMac(OS X)El Capitan 更新遇到的那些坑 ant常见错误解决方案 Gradle介绍 iMac上Android Studio 相关设置及常见问题 再说adb 再看Android官方文档之分享 再看Android官方文档之Fragment&数据保存 再看Android官方文档之Activity&Intent 再看Android官方文档之ActionBar和兼容性 adb shell input(Android模拟输入)简单总结 再看Android官方文档之建立第一个APP Android开发调试常用工具 ANR(网络资料整理) Java参数引用传递引发的惨案(又一次Java的String的“非对象”特性的踩坑经历) android.view.WindowManager$BadTokenException,Unable to add window Android签名校验机制(数字证书) Eclipse使用中部分经验总结 Android内存耗用之VSS/RSS/PSS/USS adb Advanced Command URL编码中的空格(编码以后变为+) Android MD5后 bye数组转化为Hex字符串的坑(记一次为女神排忧解难的经历) Android学习之路 adb Base Command Android Log的那些坑…………

Android MD5后 bye数组转化为Hex字符串的坑(记一次为女神排忧解难的经历)

2014年07月22日

前些天女神在接入我们的组件时候忽然遇到一个问题,女神青睐自然要积极表现,最终问题顺利解决,今天总结下。先说下结论:一个byte是8位,而16进制是4位,所以要把一个bye转化为hex的时候,其高四位和低四位分别转化为为2个16进制字符。当高四位为0时,转化完要用‘0’补齐。

代码地址:https://github.com/bihe0832/MyDemo/tree/master/JavaDemo/src

问题描述:

    女神在生成请求的sign时用md5加密偶现生成的sign不可用。女神表示问题应该出在从sign到MD5生成md5值的过程。

问题现象:

    抓了一个女神出现问题的时候的sign:4578e54fb3a1bd18e0681bc1c734514e。
         使用站长工具测试一下MD5:   3dcb16d67b01d6f6b279a61d5bb043fb
         对比一下女神md5以后的内容:3dcb16d67b1d6f6b279a61d5bb043fb
    发现问题的原因在于女神的md5结果转化为str以后少了一个0,好诡异啊。

问题代码:

找到了问题的表现,然后让女神把代码发给我,出现问题的代码内容如下:
public static String goddessMD5(String s) {
    try {
        MessageDigest digest = java.security.MessageDigest.getInstance("MD5");
        digest.update(s.getBytes());
        byte messageDigest[] = digest.digest();

        StringBuffer hexString = new StringBuffer();
        for (int i=0; i<messageDigest.length; i++){
            hexString.append(Integer.toHexString(0xFF & messageDigest[i]));
        }
        return hexString.toString();

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

仔细看了一遍还是没有发现问题,那就加个log看一下少0的位置为什么会少一个0

07-22 19:09:30.020: I/MyDemo(16687): 3d
07-22 19:09:30.020: I/MyDemo(16687): cb
07-22 19:09:30.020: I/MyDemo(16687): 16
07-22 19:09:30.020: I/MyDemo(16687): d6
07-22 19:09:30.020: I/MyDemo(16687): 7b
07-22 19:09:30.020: I/MyDemo(16687): 1
07-22 19:09:30.020: I/MyDemo(16687): d6
07-22 19:09:30.020: I/MyDemo(16687): f6
07-22 19:09:30.020: I/MyDemo(16687): b2
07-22 19:09:30.020: I/MyDemo(16687): 79
07-22 19:09:30.020: I/MyDemo(16687): a6
07-22 19:09:30.020: I/MyDemo(16687): 1d
07-22 19:09:30.020: I/MyDemo(16687): 5b
07-22 19:09:30.020: I/MyDemo(16687): b0
07-22 19:09:30.020: I/MyDemo(16687): 43
07-22 19:09:30.020: I/MyDemo(16687): fb
07-22 19:09:30.020: I/MyDemo(16687): goddess md5 :3dcb16d67b1d6f6b279a61d5bb043fb

其余位置一个bye都会转化为两位的str,只有1的地方有问题,而且倒数第三个0出现在第二位是没有问题的,看来只是0在第一位有问题,更加诡异。debug下查看messageDigest里面的内容:

[61, -53, 22, -42, 123, 1, -42, -10, -78, 121, -90, 29, 91, -80, 67, -5]

可以看到从bye转化为hex的string的时候转化为了两个字符,这是为什么呢?

  • 一个byte是8位,而16进制是4位,所以要把一个bye转化为hex的时候,其高四位和低四位分别转化为为2个16进制字符。当高四位为0时,转化完自然要用‘0’补齐。
  • 数字1(00000001)转化以后为‘01’,再toString就丢了一位,导致少了0。

修改后代码:

按照上面定位的原因,修改代码,果然解决!代码如下:

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

        StringBuffer hexString = new StringBuffer();
        String tempStr = "";
        for (int i=0; i<messageDigest.length; i++){
            if(Integer.toHexString(0xFF & messageDigest[i]).length() < 2){
                tempStr = "0"+Integer.toHexString(0xFF & messageDigest[i]);
            }else{
                tempStr = Integer.toHexString(0xFF & messageDigest[i]);
            }
            hexString.append(tempStr);
        }
        return hexString.toString();

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

运行结果:

    07-22 19:48:31.198: I/MyDemo(17796): originalSig:4578e54fb3a1bd18e0681bc1c734514e
    07-22 19:48:31.248: I/MyDemo(17796): my      md5 :3dcb16d67b01d6f6b279a61d5bb043fb
    07-22 19:09:30.020: I/MyDemo(16687): goddess md5 :3dcb16d67b1d6f6b279a61d5bb043fb

附一个SDK常用的各种进制之间转换的基础类:https://github.com/bihe0832/MyDemo/tree/master/Common



PS:我的博客即将搬运同步至腾讯云+社区,邀请大家一同入驻:https://cloud.tencent.com/developer/support-plan?invite_code=10zhijuy24v4f

赞赏

取消
微信扫一扫,赞赏子勰
扫码支持
屌丝程序猿,鸡血攻城狮!努力学技术,潜心做精品!