❶ java Web 怎樣修改request的參數值
用過濾器就可以實現,現在web.xml文件中配置好過濾器,自定義個一個過濾器,實現Filter介面,在doFilter中實現自己的過濾邏輯,我這里有個設置所有請求中的字元編碼,你可以參考一下:
Java code
web.xml配置如下:
<filter>
<!--過濾器名稱,隨便定義-->
<filter-name>UrlFilter</filter-name>
<!--filter-class指向自定義的過濾器,完整的包名+類名-->
<filter-class>
com.wgh.common.SetCharacterEncodingFilter
</filter-class>
<!--過濾器中的默認參數,默認的字元編碼是GBK-->
<init-param>
<param-name>defaultEncoding</param-name>
<param-value>GBK</param-value>
</init-param>
</filter>
<!--filter和filter-mapping是成對出現的-->
<filter-mapping>
<!--過濾器名稱,一定要和上面的一樣,-->
<filter-name>UrlFilter</filter-name>
<!--表示攔截所有的請求-->
<url-pattern>/*</url-pattern>
</filter-mapping>
SetCharacterEncodingFilter過濾器類:
package com.wgh.common;
import java.io.IOException;
import java.text.SimpleDateFormat;
import java.util.Arrays;
import java.util.Enumeration;
import java.util.List;
import javax.servlet.Filter;
import javax.servlet.FilterChain;
import javax.servlet.FilterConfig;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
public class SetCharacterEncodingFilter implements Filter {
private static String log = "ksURL_log";
private static String web_xml_url;
protected static String defaultEncoding = null;
protected FilterConfig filterConfig = null;
protected boolean ignore = true;
public void destroy() {
this.defaultEncoding = null;
this.filterConfig = null;
this.web_xml_url = null;
}
public void doFilter(ServletRequest request, ServletResponse response,
FilterChain chain) throws IOException, ServletException {
if (ignore || (request.getCharacterEncoding() == null)) {
String defaultEncoding = selectEncoding(request);
HttpServletRequest req = (HttpServletRequest) request;
if (defaultEncoding != null){
String uri = req.getRequestURI();
String url_suffix = uri.substring(uri.lastIndexOf("/")+1);
request.setCharacterEncoding(defaultEncoding);
}
}
}
public void init(FilterConfig filterConfig) throws ServletException {
this.filterConfig = filterConfig;
this.defaultEncoding = filterConfig.getInitParameter("defaultEncoding");
String value = filterConfig.getInitParameter("ignore");
if (value == null)
this.ignore = true;
else if (value.equalsIgnoreCase("true"))
this.ignore = true;
else if (value.equalsIgnoreCase("yes"))
this.ignore = true;
else
this.ignore = false;
}
protected String selectEncoding(ServletRequest request) {
return (this.defaultEncoding);
}
}
❷ 如何解決javarequest請求中有多個參數的問題
通過程序遍歷http請求的所有參數放到hashmap中,用的時候方便了。
如果參數值有中文,那麼需要在程序中添加filter轉碼,或者在下面程序里,對paramValue轉碼
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
Map map = new HashMap();
Enumeration paramNames = request.getParameterNames();
while (paramNames.hasMoreElements()) {
String paramName = (String) paramNames.nextElement();
String[] paramValues = request.getParameterValues(paramName);
if (paramValues.length == 1) {
String paramValue = paramValues[0];
if (paramValue.length() != 0) {
System.out.println("參數:" + paramName + "=" + paramValue);
map.put(paramName, paramValue);
}
}
}
Map map = new HashMap();
Enumeration paramNames = request.getParameterNames();
while (paramNames.hasMoreElements()) {
String paramName = (String) paramNames.nextElement();
String[] paramValues = request.getParameterValues(paramName);
if (paramValues.length == 1) {
String paramValue = paramValues[0];
if (paramValue.length() != 0) {
System.out.println("參數:" + paramName + "=" + paramValue);
map.put(paramName, paramValue);
}
}
}
}
❸ java 從一個URL中提取特定子字元串保存
可以通過java的」substring「方法截取出對應的字元串,前提是內知道開始和結束的字元串的值:
String getSignInfo = reqResult.substring(reqResult.indexOf("(") + 1, reqResult.indexOf(")"));
解釋容:上述方法就是截取reqResult字元串的中開始」(「和結束」)「中間部分的內容,」1「就是」)「的長度,之後將獲取的結果賦值給」getSignInfo進行輸出即可「;
備註:以上方法通用於截取字元串,數字」6「和開始結束字元串根據實際需要修改即可。
❹ JAVA如何對URL進行加密和解密啊
URLDecoder和URLEncoder應該是不行的,程序員輕易的就能解碼修改參數後重新編碼。
比較合適的就是版RSA加密了,只要兩個權伺服器共用一個密鑰,一個加密,另一個收到後再用密鑰解密就行。因為是整數加密,所以在沒有證書的情況下基本無法解密的。
des加密也是不錯的選擇,比RSA簡單。
如果有能力也可以自己寫一個簡單的加密方法。