发新帖

一个电话软件的sign算法

[复制链接]
26030 5
5NB
本人刚接触android,最近反编译一个电话软件遇到了问题总是解决不了

apk代码:
String str4 = new Date().getTime() / 1000L;
HashMap localHashMap = new HashMap();
localHashMap.put("appid", "1000");
localHashMap.put("username", this.mPref.getString("number", ""));
localHashMap.put("password", "1");
localHashMap.put("callnum", this.mCallee);
localHashMap.put("timeline", str4);
localHashMap.put("sign", MD5Util.MD5(HttpTool.caculateSign(localHashMap)).toLowerCase());
JSONObject localJSONObject = new JSONObject(HttpHelper.httpPost("http://xxx.com/api/callback", localHashMap));

抓包数据:sign=88591ec46365e9947875f2ab4dd08d2a&timeline=1428800915&appid=1000&username=13910321687&password=1&callnum=13800138000

从上面apk代码看出sign的值“88591ec46365e9947875f2ab4dd08d2a”是由1000+13910321687+1+13800138000+1428800915再从HttpTool.caculateSign函数里取key值md5加密而成。

一,HttpTool.caculateSign相关函数代码:

public class HttpTool
{
  public static String caculateSign(Map<String, String> paramMap)
  {
    ArrayList localArrayList = new ArrayList();
    Iterator localIterator = paramMap.keySet().iterator();
    for (;;)
    {
      if (!localIterator.hasNext()) {}
      try
      {
        String str2 = App_Params_Key.getAuth(localArrayList);  //关键key值引用函数
        return str2;
      }
      catch (Exception localException)
      {
        String str1;
        localException.printStackTrace();
      }
      str1 = (String)localIterator.next();
      localArrayList.add(new Parameter(str1, (String)paramMap.get(str1)));
    }
    return null;
  }

二,App_Params_Key.getAuth(localArrayList)关键key值引用函数代码:

public class App_Params_Key
{
  private static final String Separator = "";
  
  public static String getAuth(List<Parameter> paramList)  //这里还调用了Parameter函数
    throws Exception
  {
    if (paramList != null) {}
    try
    {
      int i = paramList.size();
      if (i == 0) {
        return "";
      }
      Parameter[] arrayOfParameter = (Parameter[])paramList.toArray(new Parameter[paramList.size()]);
      Arrays.sort(arrayOfParameter);
      StringBuffer localStringBuffer = new StringBuffer();
      for (int j = 0;; j++)
      {
        if (j >= arrayOfParameter.length)
        {
          localStringBuffer.append("c02258bbcc8c2f5b1fff81fa03759603");//key的值
          return localStringBuffer.toString();
        }
        if (j != 0) {
          localStringBuffer.append("");
        }
        localStringBuffer.append(arrayOfParameter[j].mValue);
      }
      return "";
    }
    catch (Exception localException)
    {
      localException.printStackTrace();
    }
  }

三,Parameter函数代码:

public class Parameter
  implements Serializable, Comparable
{
  private static final long serialVersionUID = 5164951358145483848L;
  public String mName;
  public String mValue;
  
  public Parameter(String paramString1, String paramString2)
  {
    this.mName = paramString1;
    this.mValue = paramString2;
  }
  
  public int compareTo(Object paramObject)
  {
    Parameter localParameter = (Parameter)paramObject;
    int i = this.mName.compareTo(localParameter.mName);
    if (i == 0) {
      i = this.mValue.compareTo(localParameter.mValue);
    }
    return i;
  }
  
  public boolean equals(Object paramObject)
  {
    if (paramObject == null) {}
    Parameter localParameter;
    do
    {
      do
      {
        return false;
        if (this == paramObject) {
          return true;
        }
      } while (!(paramObject instanceof Parameter));
      localParameter = (Parameter)paramObject;
    } while ((!this.mName.equals(localParameter.mName)) || (!this.mValue.equals(localParameter.mValue)));
    return true;
  }
  
  public String getmName()
  {
    return this.mName;
  }
  
  public String getmValue()
  {
    return this.mValue;
  }
  
  public void setmName(String paramString)
  {
    this.mName = paramString;
  }
  
  public void setmValue(String paramString)
  {
    this.mValue = paramString;
  }
}



本人只有点php基础对安卓这块儿是空白,只能通过半猜测的方法追出这些与sign算法有关的代码,经过多次实验还是不能解决,恳请大神们帮助解决小弟这里谢谢了!


最佳答案

查看完整内容

1000 13800138000 11428800915 13910321687 c02258bbcc8c2f5b1fff81fa03759603 按照字母排序后 只取参数值 然后加上字符串 再md5 就可以得到 md5(1000138001380001142880091513910321687c02258bbcc8c2f5b1fff81fa03759603) 88591ec46365e9947875f2ab4dd08d2a

举报 使用道具

回复

精彩评论5

cvt126    发表于 2015-4-12 09:37:45 | 显示全部楼层
1000 13800138000 11428800915 13910321687 c02258bbcc8c2f5b1fff81fa03759603

按照字母排序后 只取参数值 然后加上字符串 再md5 就可以得到
md5(1000138001380001142880091513910321687c02258bbcc8c2f5b1fff81fa03759603)

88591ec46365e9947875f2ab4dd08d2a

点评

谢谢这位朋友,原来它是按参数字母顺序排列的,非常感谢您的解答  详情 回复 发表于 2015-4-13 15:58

举报 使用道具

回复
ceshi999    发表于 2015-4-12 09:51:29 | 显示全部楼层
看着这注释,说明水平就比我高出很多了。。我无能为力了。

点评

不要笑话我了,我借用php的说法,安卓的我真不懂  详情 回复 发表于 2015-4-12 09:58

举报 使用道具

回复
残翼    发表于 2015-4-12 09:58:06 | 显示全部楼层
ceshi999 发表于 2015-4-12 09:51
看着这注释,说明水平就比我高出很多了。。我无能为力了。

不要笑话我了,我借用php的说法,安卓的我真不懂

举报 使用道具

回复
水波摇曳    发表于 2015-4-12 11:48:13 | 显示全部楼层
以前分析过一个sign的值来源
不知道这个怎么样

举报 使用道具

回复
残翼    发表于 2015-4-13 15:58:18 | 显示全部楼层
cvt126 发表于 2015-4-12 09:37
1000 13800138000 11428800915 13910321687 c02258bbcc8c2f5b1fff81fa03759603

按照字母排序后 只取参数值 ...

谢谢这位朋友,原来它是按参数字母顺序排列的,非常感谢您的解答

举报 使用道具

回复
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

快速回复 返回顶部 返回列表