亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

關于ThreadLocal對request和response的用法說明

發布時間:2020-10-24 17:47:49 來源:腳本之家 閱讀:487 作者:二缺和傻寶寶 欄目:開發技術

記得在一篇博文中看到描述threadLocal的一句話:

ThreadLocal除了適用于多線程保證每條線程都有自己的變量副本外,還適用于在線程上下文中共享某些變量值。

這兩種說法是有區別的。前者強調的是,使用ThreadLocal對副本做保護,避免同步、加鎖,降低效率;后者強調的是,某個變量線程上下文中,A處用到、B處用到、C處用到,先在入口處set一個值,后使用ThreadLocal的get方法直接在需要用到的地方拿這個值。

項目中,最近理由cookie存值,使用到了threadLocal這個字段,自己就想去研究下,原理這里跟后者強調的一樣,上代碼:

1.web.xml里邊配置過濾器,攔截請求,做處理

<filter> 
 <filter-name>InterceptorFilter</filter-name> 
 <filter-class>com.fx.anniversary.core.filter.InterceptorFilter</filter-class> 
</filter> 
<filter-mapping> 
 <filter-name>InterceptorFilter</filter-name> 
 <url-pattern>/*</url-pattern> 
</filter-mapping>

2.賦值

public class InterceptorFilter implements Filter{
 publicvoiddestroy(){
 
 }
 publicvoiddoFilter(ServletRequestrequest,ServletResponseresponse,FilterChainchain)throwsIOException,ServletException{
 HttpServletRequesthttpRequest=(HttpServletRequest)request;
 HttpServletResponsehttpResponse=(HttpServletResponse)response;
 InterceptorContext.setRequest(httpRequest);
 InterceptorContext.setResponse(httpResponse);
 try{
 chain.doFilter(request,
 response);
 }finally{
 //不管有木有出現異常,finally塊中代碼都會執行;在這里,相當于只服務于當前請求。
 InterceptorContext.removeRequest();
 InterceptorContext.removeResponse();
 }
 }
 public void init(FilterConfigfilterConfig)throwsServletException{
 
 }
}

3.InterceptorContext實體

public class InterceptorContext{
 private static ThreadLocal<httpservletrequest> _request = newThreadLocal<httpservletrequest>();
 private static ThreadLocal<httpservletresponse> _response = newThreadLocal<httpservletresponse>();
 publicstaticvoidsetRequest(HttpServletRequestrequest){
 _request.set(request);
 }
 public static HttpServletRequestgetRequest(){
 HttpServletRequestrequest=_request.get();returnrequest;
 }
 public static void removeRequest(){
 _request.remove();
 }
 public static void setResponse(HttpServletResponseresponse){
 _response.set(response);
 }
 public static HttpServletResponsegetResponse(){
 HttpServletResponseresponse=_response.get();
 return response;
 }
 public static void removeResponse(){
 _response.remove();
 }
}

4.項目中的開始調用。(因為這兩個方法調用的地方太多,每次都帶一個參數也比較繁瑣,所以采用這種方式,文章開頭總結過)

public String getAttribute(Stringkey){
 HttpServletRequestrequest = InterceptorContext.getRequest();
 Cookie[]cookies=request.getCookies();
 if(cookies!=null){
 for(Cookie cookie: cookies){
 if(cookie.getName().equals(key)){
 return cookie.getValue();
 }
 }
 }
 return"";
}
@Override
public void setAttribute(String key,String value){
 HttpServletResponse response=InterceptorContext.getResponse();
 Cookiecookie=newCookie(key,value);
 response.addCookie(cookie);
}

補充知識:利用ThreadLocal管理request和session以及用戶信息,實現 Use anywhere

1.我們有時需要獲取request或session中的數據的時候,首先需要獲取request和session對象,這個通常是在Controller的時候當做入參獲取,這樣方法的入參會顯得很長很臃腫的感覺。這就是的出發點,接下來就展示一下是如何實現的。

2.首先我們寫個一個攔截器:WebContextFilter

package com.office.common.filter;
import java.io.IOException;
import javax.servlet.FilterChain;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.springframework.web.filter.OncePerRequestFilter;
import com.office.common.context.WebContextHolder;
 
/**
 * webcontent信息加載到TheadLocal中
 * @author Neo
 * @date 2017年10月20日11:38:45
 */
public class WebContextFilter extends OncePerRequestFilter {
 
	public WebContextFilter() {
	}
 
	protected void doFilterInternal(HttpServletRequest request, HttpServletResponse response, FilterChain filterChain)
			throws ServletException, IOException {
		if (request == null || response == null) {
			return;
		} else {
			WebContextHolder.setRequest(request);
			WebContextHolder.setResponse(response);
			filterChain.doFilter(request, response);
			return;
		}
	}
}

3.然后我們將寫好的攔截器配置到web.xml中:

<?xml version="1.0" encoding="UTF-8"?>
<web-app version="3.0" xmlns="http://java.sun.com/xml/ns/javaee"
	xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
	xsi:schemaLocation="http://java.sun.com/xml/ns/javaee 
	http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd">
	
	<display-name>Archetype Created Web Application</display-name>
 
	<context-param>
		<param-name>contextConfigLocation</param-name>
		<param-value></param-value>
	</context-param>
 
	<filter>
		<filter-name>encodingFilter</filter-name>
		<filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
		<init-param>
			<param-name>encoding</param-name>
			<param-value>UTF-8</param-value>
		</init-param>
		<init-param>
			<param-name>forceEncoding</param-name>
			<param-value>true</param-value>
		</init-param>
	</filter>
	<filter-mapping>
		<filter-name>encodingFilter</filter-name>
		<url-pattern>/*</url-pattern>
	</filter-mapping>
	
	<!-- ******************************************************************* -->
	<!-- *************** webcontent信息加載到TheadLocal中 ******************** -->
	<!-- ******************************************************************* -->
	<filter>
		<filter-name>webContentFilter</filter-name>
		<filter-class>com.office.common.filter.WebContextFilter</filter-class>
	</filter>
	<filter-mapping>
		<filter-name>webContentFilter</filter-name>
		<url-pattern>/*</url-pattern><!-- /* -->
	</filter-mapping>
	<listener>
		<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
	</listener>
	
 
	<servlet>
		<servlet-name>springMVC</servlet-name>
		<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
		<init-param>
			<param-name>contextConfigLocation</param-name>
			<param-value>classpath*:applicationContext.xml</param-value>
		</init-param>
		<load-on-startup>1</load-on-startup>
	</servlet>
	<servlet-mapping>
		<servlet-name>springMVC</servlet-name>
		<url-pattern>/</url-pattern>
	</servlet-mapping>
</web-app>

4.編寫一個同一個管理操作工具類:WebContextHolder

package com.office.common.context;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
import com.office.common.dto.UserDTO;
 
/**
 * 上下文
 * @author Neo
 * @date 2017年10月20日11:42:57
 */
@SuppressWarnings({ "rawtypes", "unchecked" })
public class WebContextHolder {
 
	public WebContextHolder() {
	}
 
	public static String getRequestIp() {
		if (getRequest() == null)
			return null;
		HttpServletRequest request = getRequest();
		String ip = request.getHeader("X-Forwarded-For");
		if (ip == null || ip.length() == 0 || "unknown".equalsIgnoreCase(ip)) {
			if (ip == null || ip.length() == 0 || "unknown".equalsIgnoreCase(ip))
				ip = request.getHeader("Proxy-Client-IP");
			if (ip == null || ip.length() == 0 || "unknown".equalsIgnoreCase(ip))
				ip = request.getHeader("WL-Proxy-Client-IP");
			if (ip == null || ip.length() == 0 || "unknown".equalsIgnoreCase(ip))
				ip = request.getHeader("HTTP_CLIENT_IP");
			if (ip == null || ip.length() == 0 || "unknown".equalsIgnoreCase(ip))
				ip = request.getHeader("HTTP_X_FORWARDED_FOR");
			if (ip == null || ip.length() == 0 || "unknown".equalsIgnoreCase(ip))
				ip = request.getRemoteAddr();
		} else if (ip.length() > 15) {
			String ips[] = ip.split(",");
			int index = 0;
			do {
				if (index >= ips.length)
					break;
				String strIp = ips[index];
				if (!"unknown".equalsIgnoreCase(strIp)) {
					ip = strIp;
					break;
				}
				index++;
			} while (true);
		}
		return ip;
	}
 
	public static HttpServletRequest getRequest() {
		if (requestLocal == null)
			return null;
		else
			return (HttpServletRequest) requestLocal.get();
	}
 
	public static String getContextPath() {
		if (getRequest() == null)
			return null;
		else
			return (new StringBuilder()).append(getRequest().getContextPath()).append("/").toString();
	}
 
	public static String getCurrRequestURI() {
		if (getRequest() == null)
			return null;
		else
			return (new StringBuilder()).append(getRequest().getRequestURI().replace(getRequest().getContextPath(), ""))
					.append("/").toString();
	}
 
	public static HttpServletResponse getResponse() {
		if (responseLocal == null)
			return null;
		else
			return (HttpServletResponse) responseLocal.get();
	}
 
	public static HttpSession getSession() {
		if (requestLocal == null)
			return null;
		if (requestLocal.get() == null)
			return null;
		else
			return ((HttpServletRequest) requestLocal.get()).getSession();
	}
 
	public static UserDTO getLoginUserSession(Class loginUserClass) {
		if (getSession() == null)
			return null;
		Object obj = getSession().getAttribute(CURRENT_USER);
		if (obj == null)
			return null;
		else
			return (UserDTO) obj;
	}
 
	public static UserDTO getLoginUserSession() {
		return getLoginUserSession(UserDTO.class);
	}
 
	public static void createLoginUserSession(UserDTO loginUser) {
		if (loginUser != null)
			getSession().setAttribute(CURRENT_USER, loginUser);
	}
 
	public static void destroyLoginUserSession() {
		if (getLoginUserSession() != null) {
			getSession().removeAttribute(CURRENT_USER);
			getSession().invalidate();
		}
	}
 
	public static void setRequest(HttpServletRequest request) {
		if (requestLocal == null)
			requestLocal = new ThreadLocal();
		requestLocal.set(request);
	}
 
	public static void setResponse(HttpServletResponse response) {
		if (responseLocal == null)
			responseLocal = new ThreadLocal();
		responseLocal.set(response);
	}
	
 /**
  * 獲取項目請求的根目錄
  * 
  * @return eg:http://localhost:8080/projectName
  */
	public static String getProjectRequestRootPath() {
		HttpServletRequest request = WebContextHolder.getRequest();
		StringBuffer sb = new StringBuffer();
		sb.append(request.getScheme()).
		 append("://").
		 append(request.getServerName()).
		 append(":").
		 append(request.getServerPort()).
		 append(request.getContextPath()).
		 append("/");
		return sb.toString();
	}
 
	private static ThreadLocal requestLocal;
	private static ThreadLocal responseLocal;
	public static String CURRENT_USER = "CURRENT_USER";
 
}

5.使用展示:

//我們可以在任何地方使用這種方法取值

WebContextHolder.getRequest().getParameter("id");

以上這篇關于ThreadLocal對request和response的用法說明就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持億速云。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

湖南省| 栾城县| 乾安县| 孝昌县| 当雄县| 兴安县| 开江县| 嵊州市| 友谊县| 民丰县| 濮阳县| 洪洞县| 会昌县| 恭城| 汤原县| 比如县| 鄂伦春自治旗| 河北省| 青田县| 泸定县| 冕宁县| 梁河县| 勐海县| 工布江达县| 长治县| 石家庄市| 沭阳县| 古田县| 宾阳县| 兴隆县| 丰宁| 南木林县| 浪卡子县| 贞丰县| 获嘉县| 含山县| 北川| 独山县| 盘锦市| 普定县| 宣化县|