这个签名是在http_build_query()这个方法执行完成后,附加了另外一个提供的字符串,之后进行MD5加密取得32位的值,在网上查找各种方法之后生成出来的签名都是错的。
于是开始仔细研究http_build_query()这个方法,具体的过程大概是这样的:
1、构造需要通过http_build_query()处理的带有特殊字符的字符串
2、在PHP中调用http_build_query()方法处理该字符串
3、将得到的字符串与原来的字符串进行比较,然后自己构造同样的字符传
自己构造的过程就不赘述的,下面是实现方法:
/** * Java实现PHP中的http_build_query()效果 * @param array * key=value形式的二位数组 * @return */ public String http_build_query(Map<String ,String> array){ String reString = null; //遍历数组形成akey=avalue&bkey=bvalue&ckey=cvalue形式的的字符串 Iterator it = array.entrySet().iterator(); while (it.hasNext()){ Map.Entry<String,String> entry =(Map.Entry) it.next(); String key = entry.getKey(); String value = entry.getValue(); reString += key+"="+value+"&"; } reString = reString.substring(0, reString.length()-1); //将得到的字符串进行处理得到目标格式的字符串 reString = java.net.URLEncoder.encode(reString); reString = reString.replace("%3D", "=").replace("%26", "&"); return reString; }
但是,马上问题来了,如果参数数组中有汉字的话java.net.URLEncoder.encode(String string)之后的串在两个不同的类中处理出
来的字符串竟然神奇的不一样,不一样,同样的字符串,在不同类的相同方法中处理过后竟然不一样,又开始一阵纠结,最后因为java.net.URLEncoder.encode(String string)已经被划线了,就想是不是这个问题,替换成现在推荐的方法java.net.URLEncoder.encode(String string ,String enc),ok,问题解决。附上最后的处理方法
/** * Java实现PHP中的http_build_query()效果 * @param array * key=value形式的二位数组 * @return */ public String http_build_query(Map<String ,String> array){ String reString = null; //遍历数组形成akey=avalue&bkey=bvalue&ckey=cvalue形式的的字符串 Iterator it = array.entrySet().iterator(); while (it.hasNext()){ Map.Entry<String,String> entry =(Map.Entry) it.next(); String key = entry.getKey(); String value = entry.getValue(); reString += key+"="+value+"&"; } reString = reString.substring(0, reString.length()-1); //将得到的字符串进行处理得到目标格式的字符串 try { reString = java.net.URLEncoder.encode(reString,"utf-8"); } catch (UnsupportedEncodingException e) { // TODO Auto-generated catch block e.printStackTrace(); } reString = reString.replace("%3D", "=").replace("%26", "&"); return reString; }
ok,总结完毕 ...暴露了我的小学作文水平