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

如何保护网站模板2021搜索引擎排名

如何保护网站模板,2021搜索引擎排名,网站权重转移做排名,网页设计行业一、拦截器核心概念 作用:拦截器是 Spring 框架提供的核心功能,用于在请求处理前后执行预定义逻辑,实现统一处理(如登录校验、日志记录等)。 核心方法: public class LoginInterceptor implements Handl…

一、拦截器核心概念

作用:拦截器是 Spring 框架提供的核心功能,用于在请求处理前后执行预定义逻辑,实现统一处理(如登录校验、日志记录等)。

核心方法

public class LoginInterceptor implements HandlerInterceptor {// 目标方法执行前调用(核心控制点)@Overridepublic boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) {return true; // true=放行, false=拦截}// 目标方法执行后调用(Controller 方法执行完毕)@Overridepublic void postHandle(...) { ... }// 整个请求完成后的最终处理(视图渲染后)@Overridepublic void afterCompletion(...) { ... }
}

二、拦截器使用步骤
1. 定义拦截器
@Slf4j
@Component
public class LoginInterceptor implements HandlerInterceptor {@Overridepublic boolean preHandle(HttpServletRequest request, ...) {// 登录校验示例HttpSession session = request.getSession(false);if (session == null || session.getAttribute("USER") == null) {response.setStatus(401); // 401 Unauthorizedreturn false; // 拦截请求}return true; // 放行}
}
2. 注册拦截器
@Configuration
public class WebConfig implements WebMvcConfigurer {@Autowiredprivate LoginInterceptor loginInterceptor;@Overridepublic void addInterceptors(InterceptorRegistry registry) {registry.addInterceptor(loginInterceptor).addPathPatterns("/**")          // 拦截所有路径.excludePathPatterns("/login")    // 排除登录接口.excludePathPatterns("/**/*.js")  // 排除静态资源.excludePathPatterns("/**/*.css");}
}

三、拦截路径配置规则
路径模式匹配示例不匹配示例
/*/user/book/user/login
/**/user/user/profile-
/book/*/book/add/book/detail/book/1/author
/book/**/book/book/1/author/user/books

四、拦截器执行流程


五、登录校验实战案例
1. 拦截器实现
public boolean preHandle(...) {if (request.getSession().getAttribute("USER") == null) {response.setStatus(401);return false;}return true;
}
2. 前端处理拦截
// AJAX 错误处理
$.ajax({error: function(error) {if (error.status === 401) {window.location.href = "/login.html"; // 跳转登录页}}
});

六、设计模式:适配器原理

拦截器底层实现

// DispatcherServlet 核心代码
protected void doDispatch(...) {// 1. 获取拦截器链HandlerExecutionChain mappedHandler = getHandler(request);// 2. 执行 preHandle()if (!mappedHandler.applyPreHandle(request, response)) {return; // 拦截请求}// 3. 执行 Controller 方法mv = ha.handle(...);// 4. 执行 postHandle()mappedHandler.applyPostHandle(...);// 5. 渲染视图后执行 afterCompletion()processDispatchResult(...);
}

适配器模式应用

  • HandlerAdapter 适配不同类型的控制器(如 @ControllerHttpRequestHandler

  • 解决不同处理器接口的兼容问题


七、最佳实践建议
  1. 路径排除:静态资源(JS/CSS/图片)必须排除

  2. 性能优化:在 preHandle() 中尽早返回拦截结果

  3. 异常处理:结合 @ControllerAdvice 统一处理拦截器抛出的异常

  4. 执行顺序:多个拦截器按注册顺序执行 preHandle(),逆序执行 postHandle()

  5. 生产建议

    • 登录拦截器排除 /login/health 等公开接口

    • 敏感操作(如支付)使用独立拦截器增强校验

// 多拦截器配置示例
registry.addInterceptor(new LogInterceptor()).order(1);
registry.addInterceptor(new AuthInterceptor()).order(2);

总结核心价值

  1. 解耦:将通用逻辑(如鉴权)从业务代码剥离

  2. 复用:一次编写,全局生效

  3. 可维护:统一修改拦截逻辑,避免散弹式修改

  4. 安全:强制实施安全策略(如所有接口必须认证)

通过拦截器 + 统一返回格式 + 统一异常处理,可构建高可维护性的 Spring Boot 后端架构,

http://www.dtcms.com/wzjs/423346.html

相关文章:

  • 做网站大作业的心得体会百度网盘网页版登录
  • 做众筹网站网站优化排名金苹果系统
  • dw 做网站图片之间的链接一个企业seo网站的优化流程
  • 网站开发培训课程表九个关键词感悟中国理念
  • 品牌宣传网站制作合肥seo网站排名
  • 石河子建设网站seo基础入门视频教程
  • 中建八局第一建设有限公司中标电商seo优化
  • 网站百度v认证搜索引擎营销的优缺点
  • 机械设备采购平台东莞seo托管
  • 做市场的逛的网站百度收录网站提交入口
  • 一般ps做网站大小多少抖音seo怎么收费
  • 北京沙河教做网站的浙江网站seo
  • 品牌网站怎么做seo苏州新闻今天最新消息新闻事件
  • 网站建设需要准备什么全媒体广告代理加盟
  • qt网站开发烘焙甜点培训学校
  • 做网站界面尺寸是多少网站建设优化的技巧
  • 海口网站开发建设百度关键词搜索指数
  • 做医疗的网站建设百度一下你就知道官网下载安装
  • 软件技术文档编写标准规范seo最新
  • 莱芜区组织部网站长沙百度推广排名
  • 毕设做网站怎么样种子搜索引擎 磁力天堂
  • 网站建设滚动条怎么插入大连seo网站推广
  • 东莞自适应网站建设优化大师客服
  • 沈阳做网站的网络营销策略理论有哪些
  • 学校网站的功能青岛谷歌seo
  • 白云网站建设怎么做网站教程
  • 东京热 在线A视频网站一级做爰片百度指数特点
  • 网站建设的界面f分优秀的网页设计网站
  • 独立ip网站建设外贸平台有哪些比较好
  • 如何创建一个网站的步骤环球网