| 
 | 
	
 
 
最近调用一个第三方接口,生成签名的时候要使用到PHP中的http_build_query()方法,它的原话是这样写的 http_build_query数组形成GET形式的字符串 。 
    这个签名是在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,总结完毕...暴露了我的小学作文水平
 
  |   
 
 
 
 | 
  
 |