springboot使用jsp,过滤器,拦截器(拦截器与过滤器区别重点

jsp使用配置

  创建springboot项目在maven中暂时只添加两个Dependencies :devtools(热部署) web(远程调用,服务支持)

在创建的项目的pom.xml的<dependencies>增加jsp需要的依赖

 <!--整合jsp,需要的依赖-->
<dependency>
<groupId>org.apache.tomcat.embed</groupId>
<artifactId>tomcat-embed-jasper</artifactId>
</dependency>
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>javax.servlet-api</artifactId>
</dependency>
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>jstl</artifactId>
</dependency>


  在application.yml(yml格式的好用,把properties改了)文件中,增加视图解析

server:
# 设置端口为80,访问时可以省略
port: 80
# 视图解析器
spring:
mvc:
view:
prefix: /
suffix: .jsp

  标记webapp 。在src/main下建立 webapp目录 ,然后在Project Structure中,标记为idea识别的webapp

src/main下 新建 Directory 为webapp ,在project structure中 

在建立的出来的右侧,进行一下操作。apply 应用之后ok退出。如果有 Web,但是右侧下半部是空的,直接点击右侧下半部的+,指定自己创建的文件即可

到此,建立的jsp文件放到这个webapp目录下,启动项目在浏览器直接访问就可以定位到jsp资源。

修改一下配置文件application.properties

server:
# 设置端口为80,访问时可以省略
port: 80
servlet:
context-path: /
# 视图解析器
spring:
mvc:
view:
prefix: /
suffix: .jsp

springboot使用过滤器

    

首先自己创建一个过滤器

package com.xiaoeyu.springboot4.filter;

import javax.servlet.*;
import java.io.IOException; //通过实现Filter来自定义过滤器
public class Myfilter implements Filter {
/*
* filter是servelet规范规定的,只能用于web程序,是servlet容器比如Tomcat支持的,只在请求进入servlet之前,和出来以后起作用
* 拦截器:既可以在web程序,也可以Application,Swing程序中,是spring框架支持的,是spring的一个组件,可以使用spring里的任何资源,对象
* 例如 Service对象,数据源,事务管理等通过IOC注入给拦截器即可。拦截器能够深入到方法前后,异常抛出前后,有更大的弹性
* */
@Override
public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {
System.out.println("doFilter:在请求到达servlet之前执行过滤器");
filterChain.doFilter(servletRequest, servletResponse);
System.out.println("doFilter:在请求离开servlet之后离开Tomcat容器之前执行");
}
}

将过滤器进行注册,就是在springboot中使用上

package com.xiaoeyu.springboot4.config;

import com.xiaoeyu.springboot4.filter.Myfilter;
import org.springframework.boot.web.servlet.FilterRegistrationBean;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
//标注是一个配置类,等价于配置文件.xml,springboot框架会在启动的过程中读取该配置中@Bean注解的方法,将其返回值注入到IOC容器中
@Configuration
public class FilterConfig { @Bean //等同于在spring配置文件中的<bean>的配置,会把方法的返回值对象,注入到IOC容器中
public FilterRegistrationBean filterRegistrationBean() {
FilterRegistrationBean bean = new FilterRegistrationBean();
bean.setFilter(new Myfilter());//用什么过滤器进行拦截即注册过滤器
bean.addUrlPatterns("/*");//配置过滤器拦截的路径
bean.setOrder(1);//设置启动顺序,正数,越小越优先
return bean;
}
}

springboot使用拦截器

    

自定义个拦截器

package com.xiaoeyu.springboot4.interceptor;

import org.springframework.web.servlet.HandlerInterceptor;
import org.springframework.web.servlet.ModelAndView; import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse; //拦截器,需要访问Controller中的方法才会触发
public class Myinterceptor implements HandlerInterceptor { @Override
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
System.out.println("preHandle:在进入拦截器,执行Controller之前调用");
//返回值为false请求原路返回,但是前台显示的200状态码,任何请求都可以成功,到这里以后不在往下,原路返回
return true;
} @Override
public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
System.out.println("postHandle:执行完Controller逻辑,在Controller的return ModelAndView 之前执行,可以操控ModelAndView的数据");
modelAndView.addObject("name", "postHandle:修改姓名JRL");
System.out.println("postHandle:修改了ModelAndView中的name值");
} @Override
public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {
System.out.println("afterCompletion:Controller的Return之后,Filter返回给客户端之前(应该是FilterAfter方法执行前)"); }
}

将拦截器加载进去,在springboot能起作用

package com.xiaoeyu.springboot4.config;

import com.xiaoeyu.springboot4.interceptor.Myinterceptor;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.InterceptorRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;
//告知springboot这是一个配置类,在实现WebMvcConfigurer的对象中调用addInterceptors方法。把添加的拦截器注入到IOC容器
@Configuration
public class InterceptorConfig implements WebMvcConfigurer {
@Override
public void addInterceptors(InterceptorRegistry registry) {
registry.addInterceptor(new Myinterceptor()).addPathPatterns("/*");//拦截的路径
}
}

通过Controller在触发拦截器。访问静态资源不到不触发拦截器

package com.xiaoeyu.springboot4.controller;

import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.servlet.ModelAndView; @Controller
public class HelloController {
/*从前台通过url localhost/hello?name=冯永康
传过来一个参数,并把它打印且放到ModelAndView中,在拦截器中对name进行修改,并跳转到jsp页面,查看效果*/
@RequestMapping("/hello")
public ModelAndView hello(String name, ModelAndView mv) {
System.out.println("name:" + name);
mv.setViewName("test");
mv.addObject("name", name);
return mv;
}
}

这是用于方便显示数据的 test.jsp  直接返回字符换也可以

<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>Title</title>
</head>
<body>
我是一个jsp页面<br>
获取ModelAndView中的数据 name=${name}<br>
</body>
</html>

springboot jsp,过滤器,拦截器的更多相关文章

  1. JavaWeb中监听器+过滤器+拦截器区别、配置和实际应用

    JavaWeb中监听器+过滤器+拦截器区别.配置和实际应用 1.前沿上一篇文章提到在web.xml中各个元素的执行顺序是这样的,context-param-->listener-->fil ...

  2. SpringBoot如何添加拦截器

    在web开发的过程中,为了实现登录权限验证,我们往往需要添加一个拦截器在用户的的请求到达controller层的时候实现登录验证,那么SpringBoot如何添加拦截器呢? 步骤如下: 1.继承Web ...

  3. MVC中的过滤器/拦截器怎么写

    创建一个AuthenticateFilterAttribute(即过滤器/拦截器) 引用System.Web.Mvc; public class AuthenticateFilterAttribute ...

  4. 在springboot中使用拦截器

    在springMVC中可以实现拦截器,是通过实现HandlerInterceptor接口,然后在springmvc-web.xml中配置就可以使用拦截器了.在springboot中拦截器也是一样的思想 ...

  5. Springboot + redis + 注解 + 拦截器来实现接口幂等性校验

    Springboot + redis + 注解 + 拦截器来实现接口幂等性校验   1. SpringBoot 整合篇 2. 手写一套迷你版HTTP服务器 3. 记住:永远不要在MySQL中使用UTF ...

  6. springmvc以及springboot中的拦截器配置

    拦截器两种实现   如果不同的controller中都需要拦截器,不能使用相同的拦截器,因为拦截器不能跨controller,这个时候只能为不同的controller配置不同的拦截器,每一个拦截器只能 ...

  7. springboot中使用拦截器、监听器、过滤器

     拦截器.过滤器.监听器在web项目中很常见,这里对springboot中怎么去使用做一个总结. 1. 拦截器(Interceptor)   我们需要对一个类实现HandlerInterceptor接 ...

  8. SpringBoot 过滤器, 拦截器, 监听器 对比及使用场景

    1. 过滤器 (实现 javax.servlet.Filter 接口) ① 过滤器是在web应用启动的时候初始化一次, 在web应用停止的时候销毁. ② 可以对请求的URL进行过滤, 对敏感词过滤, ...

  9. 过滤器 拦截器 登录login实例

    当请求来的时候,首先经过拦截器/过滤器,在经过一系列拦截器/拦截器处理后,再由再根据URL找到Servlet.执行servlet中的代码. 过滤器:按照过滤的对象类型的不同,可分为按资源名过滤和按请求 ...

随机推荐

  1. js作用域链和预编译

    js引擎运行分为两步,预解析 代码执行 (1)预解析: js引擎会拿js里面所有的var还有 function 提升到当前作用域的最前面 (2)代码执行:按照代码书写的顺序从上往下执行 预解析分为:变 ...

  2. pycharm---文件名颜色所代表的含义

    绿色,已经加入版本控制暂未提交: 红色,未加入版本控制: 蓝色,加入版本控制,已提交,有改动: 白色,加入版本控制,已提交,无改动: 灰色:版本控制已忽略文件.

  3. Redis缓存,持久化,高可用

    一,Redis作缓存服务器 ​ 本篇博客是接着上一篇博客未分享完的技术点. ​ redis作为缓存服务器是众多企业中的选择之一,虽然该技术很成熟但也是存在一定的问题.就是缓存带来的缓存穿透,缓存击穿, ...

  4. IOS系统

    苹果产品以前技术是很牛逼.但是,苹果的系统是IOS系统,是一个封闭系统,就是你只看的到程序看不到文件的存储位置,相当于说他们自己的软件或者要花钱的软件才可以在闭环系统里面通过苹果视频该软件导出来,祝2 ...

  5. Liunx学习总结(五)--包管理

    包管理简介 Linux 上的应用程序一般是以源码形式或者编译后的二进制格式提供给用户使用.对于以源码形式提供的应用程序,用户需要借助于编译器,自行编译成二进制格式才能使用.而即便是编译后的二进制包,用 ...

  6. 在 Web 级集群中动态调整 Pod 资源限制

    作者阿里云容器平台技术专家 王程阿里云容器平台技术专家 张晓宇(衷源) ## 引子 不知道大家有没有过这样的经历,当我们拥有了一套 Kubernetes 集群,然后开始部署应用的时候,我们应该给容器分 ...

  7. 修改预制体效果无变化(unity&&CocosCreator)

    推荐阅读:  我的CSDN  我的博客园  QQ群:704621321 1.问题       修改预制体后保存,预览游戏预制体未发生变化(和改之前效果一样) 2.回忆       以前做unity的时 ...

  8. FineReport - 软件安装部署

    FineReport 软件安装与部署 FineReport试用码申请 在浏览器中输入网址:http://www.finereport.com/,进入帆软官网首页,点击免费试用,填写相关信息后,既可以收 ...

  9. Node开发知识概括

    一. javascript高级话题(面向对象,作用域,闭包,设计模式等) 1. 常用js类定义的方法有哪些? 参考答案:主要有构造函数原型和对象创建两种方法.原型法是通用老方法,对象创建是ES5推荐使 ...

  10. SDU暑期集训排位(4)

    SDU暑期集训排位(4) C. Pick Your Team 题意 有 \(n\) 个人,每个人有能力值,A 和 B 轮流选人,A 先选,B 选人按照一种给出的优先级, A 可以随便选.A 想最大化己 ...