Posted on 2009-08-20 22:35
Gavin.lee 阅读(3464)
评论(0) 编辑 收藏 所属分类:
web 积累(前端 + 后台)
今天出了很大的纰漏,我们站上工行充值渠道疯狂掉单,原因是开发包陈旧,但是没法查到日志,写的日志全是空文件,原因就是我将request.getQueryString()写到文件中当日志,怪我对这个方法理解不透,回来好好反省一下,查了api,写了这个方法:
api第一句:Returns the query string that is contained in the request URL after the path,这就说明它只对get方法抛的数据有效。post方法传的参数getQueryString将什么都得不到。
我的总结:
import java.io.UnsupportedEncodingException;
import java.net.URLEncoder;
import java.util.Enumeration;
data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
import javax.servlet.http.HttpServletRequest;
data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
data:image/s3,"s3://crabby-images/16507/1650758e64773369e558bf6a35239aa629f2eb9d" alt=""
public class QueryString
{
private StringBuffer query = new StringBuffer();
data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public QueryString(String name, String value)
{
encode(name, value);
}
data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public synchronized void add(String name, String value)
{
query.append('&');
encode(name, value);
}
data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
private synchronized void encode(String name, String value)
{
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
try
{
query.append(URLEncoder.encode(name, "UTF-8"));
query.append('=');
value = value.replaceAll(" ", "%20");
query.append(value);
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
} catch (UnsupportedEncodingException e)
{
e.printStackTrace();
}
}
data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public String getQuery()
{
return query.toString();
}
data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public String toString()
{
return getQuery();
}
data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
/** *//**
* 直接接受request
* 注:request中提供的getQueryString方法只对Get方法才能生效,
* 在我们不知道方法的情况下最好重写getQueryString
* @param request
* @return
*/
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public static String getQueryString(HttpServletRequest request)
{
boolean first = true;
StringBuffer strbuf = new StringBuffer("");
Enumeration emParams = request.getParameterNames();
//do-while
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
do
{
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
if (!emParams.hasMoreElements())
{
break;
}
String sParam = (String) emParams.nextElement();
String[] sValues = request.getParameterValues(sParam);
String sValue = "";
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
for (int i = 0; i < sValues.length; i++)
{
sValue = sValues[i];
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
if (sValue != null && sValue.trim().length() != 0 && first == true)
{
//第一个参数
first = false;
strbuf.append(sParam).append("=").append(sValue);
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
} else if (sValue != null && sValue.trim().length() != 0 && first == false)
{
strbuf.append("&").append(sParam).append("=").append(sValue);
}
}
} while (true);
data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
return strbuf.toString();
}
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public static void main(String args[])
{
QueryString qs = new QueryString("parms1", "1");
qs.add("parms", "2");
qs.add("parms", "3");
System.out.println(qs.toString()); //parms1=1&parms=2&parms=3
}
}
data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""