/*
* Copyright (c) 2002-2012 Alibaba Group Holding Limited.
* All rights reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.alibaba.citrus.service.requestcontext.util;
import javax.servlet.http.HttpServletRequest;
import com.alibaba.citrus.service.requestcontext.RequestContext;
import org.springframework.web.context.request.RequestAttributes;
import org.springframework.web.context.request.RequestContextHolder;
import org.springframework.web.context.request.ServletRequestAttributes;
/**
* 和<code>RequestContext</code>相关的辅助类。
*
* @author Michael Zhou
*/
public class RequestContextUtil {
private static final String REQUEST_CONTEXT_KEY = "_outer_webx3_request_context_";
/**
* 取得和当前request相关联的<code>RequestContext</code>对象。
*
* @param request 要检查的request
* @return <code>RequestContext</code>对象,如果没找到,则返回<code>null</code>
*/
public static RequestContext getRequestContext(HttpServletRequest request) {
return (RequestContext) request.getAttribute(REQUEST_CONTEXT_KEY);
}
/**
* 将<code>RequestContext</code>对象和request相关联。
*
* @param requestContext <code>RequestContext</code>对象
*/
public static void setRequestContext(RequestContext requestContext) {
HttpServletRequest request = requestContext.getRequest();
request.setAttribute(REQUEST_CONTEXT_KEY, requestContext);
}
/** 将<code>RequestContext</code>对象和request脱离关联。 */
public static void removeRequestContext(HttpServletRequest request) {
request.removeAttribute(REQUEST_CONTEXT_KEY);
}
/**
* 在指定的request context及其级联的request context中找到一个指定类型的request context。
*
* @param request 从该<code>HttpServletRequest</code>中取得request context
* @param requestContextInterface 要查找的类
* @return <code>RequestContext</code>对象,如果没找到,则返回<code>null</code>
*/
public static <R extends RequestContext> R findRequestContext(HttpServletRequest request, Class<R> requestContextInterface) {
return findRequestContext(getRequestContext(request), requestContextInterface);
}
/**
* 在指定的request context及其级联的request context中找到一个指定类型的request context。
*
* @param requestContext 要搜索的request context
* @param requestContextInterface 要查找的类
* @return <code>RequestContext</code>对象,如果没找到,则返回<code>null</code>
*/
public static <R extends RequestContext> R findRequestContext(RequestContext requestContext, Class<R> requestContextInterface) {
do {
if (requestContextInterface.isInstance(requestContext)) {
break;
}
requestContext = requestContext.getWrappedRequestContext();
} while (requestContext != null);
return requestContextInterface.cast(requestContext);
}
/**
* 注册spring <code>ServletRequestAttributes</code>中的析构回调方法,这些方法将在request
* context被提交之后依次调用。
*/
public static void registerRequestDestructionCallback(String name, Runnable callback) {
ServletRequestAttributes attributes = (ServletRequestAttributes) RequestContextHolder.getRequestAttributes();
attributes.registerDestructionCallback(name, callback, RequestAttributes.SCOPE_REQUEST);
}
}