当前位置: 首页 > news >正文

郑州十大网站建设公司wordpress蛋糕主题

郑州十大网站建设公司,wordpress蛋糕主题,百度广告费,免费html5中文网站素材提示#xff1a;文章写完后#xff0c;目录可以自动生成#xff0c;如何生成可参考右边的帮助文档 文章目录 RequestContextHolder背景1.RequestContextHolder的使用2.request和response怎么和当前请求挂钩?3.request和response等是什么时候设置进去的? 案例应用---用户信… 提示文章写完后目录可以自动生成如何生成可参考右边的帮助文档 文章目录 RequestContextHolder背景1.RequestContextHolder的使用2.request和response怎么和当前请求挂钩?3.request和response等是什么时候设置进去的? 案例应用---用户信息文工具类AuthSessionEntityAuthSessionConstantsAuthContextHolder ---用户信息文工具类 RequestContextHolder 背景 最近遇到的问题是在service获取request和response,正常来说在service层是没有request的,然而直接从controlller传过来的话解决方法太粗暴,后来发现了SpringMVC提供的RequestContextHolder遂去分析一番,并借此对SpringMVC的结构深入了解一下,后面会再发文章详细分析源码 1.RequestContextHolder的使用 RequestContextHolder顾名思义,持有上下文的Request容器.使用是很简单的,具体使用如下: //两个方法在没有使用JSF的项目中是没有区别的 //RequestContextHolder.getRequestAttributes(); RequestAttributes requestAttributes RequestContextHolder.currentRequestAttributes();//从session里面获取对应的值 String str (String) requestAttributes.getAttribute(name,RequestAttributes.SCOPE_SESSION);HttpServletRequest request ((ServletRequestAttributes)requestAttributes).getRequest(); HttpServletResponse response ((ServletRequestAttributes)requestAttributes).getResponse();2.request和response怎么和当前请求挂钩? 首先分析RequestContextHolder这个类,里面有两个ThreadLocal保存当前线程下的request, //得到存储进去的request private static final ThreadLocalRequestAttributes requestAttributesHolder new NamedThreadLocalRequestAttributes(Request attributes);//可被子线程继承的request private static final ThreadLocalRequestAttributes inheritableRequestAttributesHolder new NamedInheritableThreadLocalRequestAttributes(Request context);再看getRequestAttributes()方法,相当于直接获取ThreadLocal里面的值,这样就保证了每一次获取到的Request是该请求的request. public static RequestAttributes getRequestAttributes() {RequestAttributes attributes requestAttributesHolder.get();if (attributes null) {attributes inheritableRequestAttributesHolder.get();}return attributes;}3.request和response等是什么时候设置进去的? 找这个的话需要对springMVC结构的DispatcherServlet的结构有一定了解才能准确的定位该去哪里找相关代码. 在IDEA中会显示如下的继承关系. 左边1这里是Servlet的接口和实现类. 右边2这里是使得SpringMVC具有Spring的一些环境变量和Spring容器.类似的XXXAware接口就是对该类提供Spring感知,简单来说就是如果想使用Spring的XXXX就要实现XXXAware,spring会把需要的东西传送过来. 那么剩下要分析的的就是三个类,简单看下源码 HttpServletBean 进行初始化工作 FrameworkServlet 初始化 WebApplicationContext,并提供service方法预处理请 DispatcherServlet 具体分发处理. 那么就可以在FrameworkServlet查看到该类重写了service(),doGet(),doPost()…等方法,这些实现里面都有一个预处理方法processRequest(request, response);,所以定位到了我们要找的位置 查看processRequest(request, response);的实现,具体可以分为三步: 获取上一个请求的参数重新建立新的参数设置到XXContextHolder父类的service()处理请求恢复request发布事 protected final void processRequest(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { long startTime System.currentTimeMillis(); Throwable failureCause null; //获取上一个请求保存的LocaleContextLocaleContext previousLocaleContext LocaleContextHolder.getLocaleContext(); //建立新的LocaleContextLocaleContext localeContext buildLocaleContext(request); //获取上一个请求保存的RequestAttributesRequestAttributes previousAttributes RequestContextHolder.getRequestAttributes(); //建立新的RequestAttributesServletRequestAttributes requestAttributes buildRequestAttributes(request, response, previousAttributes);WebAsyncManager asyncManager WebAsyncUtils.getAsyncManager(request); asyncManager.registerCallableInterceptor(FrameworkServlet.class.getName(), new RequestBindingInterceptor()); //具体设置的方法initContextHolders(request, localeContext, requestAttributes); try {doService(request, response);} catch (ServletException ex) { failureCause ex; throw ex;} catch (IOException ex) {failureCause ex;throw ex;} catch (Throwable ex) {failureCause ex;throw new NestedServletException(Request processing failed, ex);} finally { //恢复resetContextHolders(request, previousLocaleContext, previousAttributes); if (requestAttributes ! null) { requestAttributes.requestCompleted();} if (logger.isDebugEnabled()) { if (failureCause ! null) { this.logger.debug(Could not complete request, failureCause);} else { if (asyncManager.isConcurrentHandlingStarted()) {logger.debug(Leaving response open for concurrent processing);} else { this.logger.debug(Successfully completed request);}}} //发布事件publishRequestHandledEvent(request, response, startTime, failureCause);} }再看initContextHolders(request, localeContext, requestAttributes)方法,把新的RequestAttributes设置进LocalThread,实际上保存的类型为ServletRequestAttributes,这也是为什么在使用的时候可以把RequestAttributes强转为ServletRequestAttributes. private void initContextHolders(HttpServletRequest request, LocaleContext localeContext, RequestAttributes requestAttributes) { if (localeContext ! null) {LocaleContextHolder.setLocaleContext(localeContext, this.threadContextInheritable);} if (requestAttributes ! null) {RequestContextHolder.setRequestAttributes(requestAttributes, this.threadContextInheritable);} if (logger.isTraceEnabled()) {logger.trace(Bound request context to thread: request);} }因此RequestContextHolder里面最终保存的为ServletRequestAttributes,这个类相比RequestAttributes方法是多了很多. 案例应用—用户信息文工具类 AuthSessionEntity import lombok.Data;import java.util.List; import java.util.Set;/****/ Data public class AuthSessionEntity {/*** 用户ID*/private Long userId;/*** 登录用户名*/private String userName;/*** 登录用户真实姓名*/private String realName;/*** 所属部门ID**/private Long organizeId;/*** 负责部门ID**/private Long chargedOrganizeId;/*** 部门名称**/private String organizeName;/*** 所属部门code*/private String organizeCode;/*** 负责部门code*/private String chargeOrganizeCode;/*** 用户角色集合**/private SetLong roles;/*** 角色名称**/private String roleName;/*** 是否首次登录**/private Integer accountStatus;/*** 是否为超管*/private boolean isSuperAdmin;/*** 用户权限列表**/private ListAuthPermissionEntity menuVoList;private boolean firstLogin;private boolean headquartersTag;} AuthSessionConstants public class AuthSessionConstants {/*** 前端cookie中的key值**/public static final String AUTH_COOKIE_NAME SESSION;/*** 当前登录用户session信息*/public static final String CURRENT_USER CURRENT_USER;/*** 登录验证码*/public static final String LOGIN_CAPTCHA LOGIN_CAPTCHA;/*** 登录验证码有效期*/public static final long CAPTCHA_EXPIRED_TIME 3L * 60L * 1000L; } AuthContextHolder —用户信息文工具类 RequestContextHolder [springMvc 的上下文工具类] import com.alibaba.fastjson.JSON; import com..framework.auth.entity.AuthSessionEntity; import com..framework.exception.AppException; import com..framework.exception.UnauthorizedException; import org.apache.commons.lang3.StringUtils; import org.springframework.web.context.request.RequestContextHolder; import org.springframework.web.context.request.ServletRequestAttributes;import javax.servlet.http.Cookie; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpSession; import java.util.Objects;/*** description 认证配置上下文持有者替代调原先的BaseController作用参照springMvc 的上下文工具类* see RequestContextHolder [springMvc 的上下文工具类]**/ public class AuthContextHolder {/*** 保存用户信息到当前会话*/public static void saveCurrentUserSession(AuthSessionEntity authSessionEntity) {if (authSessionEntity null) {return;}HttpSession session getCurrentSession();session.setAttribute(AuthSessionConstants.CURRENT_USER, JSON.toJSONString(authSessionEntity));}/*** 移除当前会话的用户信息*/public static void removeCurrentUserSession() {HttpSession session getCurrentSession();session.removeAttribute(AuthSessionConstants.CURRENT_USER);session.invalidate();}/*** 获取当前用户登录信息*/public static AuthSessionEntity getCurrentUser() {HttpSession session getCurrentSession();String currentUser (String) session.getAttribute(AuthSessionConstants.CURRENT_USER);if (StringUtils.isBlank(currentUser)) {throw new UnauthorizedException(AuthError.USER_NOT_LOGIN);}return JSON.parseObject(currentUser, AuthSessionEntity.class);}/*** 当前用户是否登陆* return*/public static boolean isLogin() {HttpSession session getCurrentSession();String currentUser (String) session.getAttribute(AuthSessionConstants.CURRENT_USER);return !StringUtils.isBlank(currentUser);}/*** 获取当前登录用户会话*/public static HttpSession getCurrentSession() {return getRequest().getSession();}public static Cookie getAuthCookie() {Cookie[] cookies getRequest().getCookies();Cookie authCookie null;for (Cookie cookie : cookies) {if (AuthSessionConstants.AUTH_COOKIE_NAME.equals(cookie.getName()))authCookie cookie;}if (authCookie null)throw new AuthException(AuthError.USER_NOT_LOGIN);return authCookie;}public static String getAuthSource() {return getRequest().getHeader(AuthFilter.X_SOURCE);}private static HttpServletRequest getRequest() {return ((ServletRequestAttributes) Objects.requireNonNull(RequestContextHolder.getRequestAttributes())).getRequest();} }
http://www.zqtcl.cn/news/691068/

相关文章:

  • 电脑做科目一网站购物网站怎么创建
  • c2c网站建设公司wordpress被公众号干掉
  • wordpress托管建站网站页面布局和样式设计
  • 建站平台江苏省建设监理协会网站
  • 安徽网站开发培训价格百度seo排名公司
  • 青海网站建设费用oa系统和erp系统区别
  • 个人做网站的注意事项网站开发工程师6
  • 镇江百度网站建设北京网站开发价格
  • 大岭山镇仿做网站推广计划表格
  • 网站备案地址不是我的地址怎么办建设银行网站查询业务收费吗
  • 电商网站设计内容网站编辑及seo招聘
  • 用什么网站开发浙江省住房和建设厅网站
  • 站长工具seo优化建议微信小程序线上商城怎么申请
  • 建筑网站开发设计做网站的公司msgg
  • 设计师个人网站模板网站的尾页要怎么做
  • 营销型网站建设风格设定包括哪些方面wordpress企业魔板
  • 怎样做淘客网站做绿色产品的网站
  • 关于网站建设的通知wordpress点注册后一直不出来
  • 科技公司网站设计方案开发公司绩效考核
  • 深圳网站建设推进旗县政务网站建设工作方案
  • 南宁 网站建设网站集约建设
  • 做网站编辑好吗吉林省四平市
  • 石家庄网站制作最新军事新闻最新消息视频
  • 高端品牌网站设计企业网站建设wordpress文章前阅读
  • 广州做网站星珀各电商网站的特点
  • 西安模板做网站广州微信网站建设平台
  • 网站开发硬件工程师待遇微信商城有哪些第三方平台
  • 基于响应式设计的网站建设软件开发项目甘特图
  • 绍兴兴住房和城乡建设局网站网站更换名称需要重新备案吗
  • 跨境电商网站开发文档网站建设费可摊几年