👨🎓作者:Java 学术趴
🏦仓库:Github、Gitee
✏️博客:CSDN、掘金、InfoQ、云+社区
💌公众号:Java 学术趴
🚫特别声明:原创不易,未经授权不得转载或抄袭,如需转载可联系小编授权。
🙏版权声明:文章里的部分文字或者图片来自于互联网以及百度百科,如有侵权请尽快联系小编。微信搜索公众号 Java 学术趴联系小编。
☠️每日毒鸡汤:这个社会是存在不公平的,不要抱怨,因为没有用!人总是在反省中进步的!
👋大家好!我是你们的老朋友 Java 学术趴,好久没有时间写文章,最近忙着找工作。没有太多的时间给大家分享文章,从今天开始给大家持续发布新的技术文章,还希望大家多多支持支持。感谢感谢~~💓💓💓
1.3 自定义配置
1.3.1 @value 注解
语法格式: @value("${key}") 。key 来自 application.properties(yml)主配置文件中。
通过这种方式我们可以获取到 application.properties|yml 中的原始属性以及自定义属性的属性值。
# 设置端口号server.port=8082# 设置上下文路径server.servlet.context-path=/myBoot# 自定义属性key=valueschool.name=程云博school.website=https://github.com/yunbochengschool.address=河北承德school=重返计划复制代码
复制代码
// 以下是在Controller层中获取到的主配置文件中属性的属性值。@Controllerpublic class HelloController { // 我们使用 @Value 注解来获取配置文件中 server.port属性对应的属性值。 @Value("${server.port}") private Integer port; @Value("${server.servlet.context-path}") private String contextPath; @Value("${school.name}") private String schoolName; @Value("${school.website}") private String schoolWebsite; @Value("${school.address}") private String schoolAddress; // 这个注解是请求的路径信息。请求路径如果是:localhost:8082/myBoot/hello,那么就执行这个方法 @RequestMapping(value = "/hello") // 这个注解的作用是:告诉容器返回的是一个字符串,不是返回的一个试图,跳转页面。 @ResponseBody public String queryData(){ return "学校名字=" + schoolName + ",学校地址=" + schoolAddress + ",学校网站=" + schoolWebsite + ",项目端口号=" + port + ",项目路径=" + contextPath; }}复制代码
复制代码
1.3.2 @ConfigurationProperties 注解
原理:将整个文件映射成一个对象,用于自定义配置项比较多的情况。
使用步骤:
需要创建一个实体类,这个实体类的作用就是获取主配置文件中属性的属性值。
// 这个注解作用是:创建这个类的对象@Component// 这个注解的作用是:主配置文件中属性的开头,也就是配置属性的前缀@ConfigurationProperties(prefix = "school")// 添加lombok,省略Getter、Setter方法、有参构造、以及toString()方法@Data// 添加无参构造@NoArgsConstructorpublic class SchoolInfo { // 这个成员属性的名字和主配置文件中的属性名必须保持一致。 // 主配置:school.name=程云博 school.website=https://github.com/yunbocheng school.address=河北承德 // 这样就可以把程云博赋值给以下的name属性。 private String name; private String website; private String address;}复制代码
复制代码
在其他类中使用这个实体类中属性值。这里在 controller 类中来使用这个实例对象。
@Controllerpublic class HelloController { // 这个注解的作用是:使用自动注入的方式来获取这个对象。 // 先使用byName方式来寻找一个info对象。当对象不存在的时候使用byType方式来寻找SchoolInfo这个类。 // 因为这里不存在info这个对象。所以就使用byType的方式来寻找SchoolInfo这个类/之后发现SchoolInfo // 这个类中存在@Component这个注解,就可以创建出一个该类的对象。 @Resource private SchoolInfo info; @RequestMapping(value = "/data") @ResponseBody public String queryData2(){ return info.toString(); }}复制代码
复制代码
具体实现见项目:SpringBoot-custom-yml
1.4 SpringBoot 中使用 JSP
注意:在 SpringBoot 不建议使用 JSP 并且 SpringBoot 本身默认也不支持 JSP,需要在 pom.xml 中导入 JSP 依赖。
如果只是使用 JSP,加入 JSP 依赖即可。但是如果要使用 servelt 必须加入 servlet 依赖。
SpringBoot 不推荐使用 JSP,而是使用模板技术代替 JSP
使用 JSP 需要配置:
加入一个处理 JSP 的依赖。负责编译 JSP 文件
<dependency> <groupId>org.apache.tomcat.embed</groupId> <artifactId>tomcat-embed-jasper</artifactId> <version>10.1.0-M8</version> </dependency>复制代码
复制代码
如果需要其他依赖,还需要加入其他的依赖。比如:servlet...
<dependency> <groupId>javax.servlet</groupId> <artifactId>javax.servlet-api</artifactId> <version>4.0.1</version> </dependency>复制代码
复制代码
创建一个存放 JSP 文件的目录,一般叫做 webapp
当我们创建这个 webapp 文件夹的时候,就是一个普通的文件。此时需要在项目结构中来更改这个文件的属性,让这个文件变为 web 资源文件夹。
需要在 pom.xml 文件中指定 JSP 文件编译后的存放的目录。 META-INF/resources
<build> <!-- 指定jsp文件编译之后的存放目录--> <resources> <resource> <!-- jsp原来的目录--> <directory>src/main/webapp</directory> <!-- 指定编译后的存放目录--> <targetPath>META-INF/resources</targetPath> <!-- 指定处理的目录和文件 --> <includes> <include>**/*.*</include> </includes> </resource> </resources> <plugins> <plugin> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-maven-plugin</artifactId> <version>2.2.2.RELEASE</version> </plugin> </plugins> </build复制代码
复制代码
创建 Controller,访问 JSP
@Controllerpublic class JspController { public String doJsp(HttpServletRequest request){ // 将数据存储到request作用域中 request.setAttribute("data","SpringBoot使用了JSP"); // 试图的逻辑名称 return "index.jsp"; } @RequestMapping(value = "/jsp") // 此时这个String返回值代表的是视图,用于跳转界面。而不是简单的返回一个字符串 public String doJsp(Model model){ model.addAttribute("data","SpringBoot使用了JSP"); return "index.jsp"; }}复制代码
复制代码
在 application.properties 文件中配置试图解析器
server.port=8083server.servlet.context-path=/myJsp# 配置视图解析器# 配置试图解析器前缀。/ 代表的是:src/main/webappspring.mvc.view.prefix=/# 配置试图解析器后缀。 .jspspring.mvc.view.suffix=.jsp复制代码
复制代码
1.5 SpringBoot 中使用 ApplicationContext
在 main 方法中 SpringApplication.run()方法获取返回的 Spring 容器对象,在获取业务 bean 进行调用。
通过 SpringApplication.run(Application.class,args):返回值就是 ApplicationContext 容器。
1.6 CommandLineRunner 接口
开发中可能会有这样的场景。需要在容器启动后执行一些内容。比如读取配置文件、数据库链接之类的。SpringBoot 给我们提供了两个接口来帮助我们实现这种需求。这两个接口分别为 CommandLineRunner 和 ApplicationRunner。他们的执行时机为容器启动完成的时候,这两个接口中有一个 run 方法,我们只需要实现这个方法即可。这两个接口的区别:ApplicationRunner 中 run 方法的参数为:ApplicationArguments,而 CommandLineRunner 接口中 run 方法的参数为:String 数组。
这两个接口中都有一个 run 方法,执行时间在容器对象那个创建好之后,自定执行 run()方法。可以完成自定义的在容器对象创建好的一些操作。
@FunctionalInterfacepublic interface CommandLineRunner{ void run(String...args) yhrows Exception;}@FunctionalInterfacepublic interface ApplicationRunner{ void run(ApplicationArguments args) throws Exception;}复制代码
复制代码
2.第二章:SpringBoot 的 Web 组件
2.1 拦截器
SpringMVC 中实现自定义拦截器:
创建类实现 SpringMVC 框架的 HandlerInterceptor 接口
public interface HandlerInterceptor { // 这个方法返回值是boolean类型。返回true时,可以进行处理。返回为false时,请求被拦截。 default boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception { return true; } default void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, @Nullable ModelAndView modelAndView) throws Exception { } default void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, @Nullable Exception ex) throws Exception { }}复制代码
复制代码
需在 SpringMVC 的配置文件中声明拦截器
<mvc:interceptors> <mvc:interceptor> <mvc:path="url/> <bean class="拦截器类全限定名称"/> </mvc:interceptor></mvc:interceptors>复制代码
复制代码
SpringBoot 中实现自定义拦截器:
创建一个拦截器类
// 自定义拦截器public class LoginInterceptor implements HandlerInterceptor { /** * * @param request * @param response * @param handler 被拦截的控制器对象 * @return boolean * true:请求能被 Controller处理 * false:请求被拦截 * @throws Exception */ @Override public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception { System.out.println("执行了拦截器的方法!"); return true; }}复制代码
复制代码
将拦截器注入到 Spring 容器中。声明这个拦截器拦截/不拦截哪个请求地址。
@Configurationpublic class MyAppConfig implements WebMvcConfigurer { // 添加拦截器对象,注入到容器中 @Override public void addInterceptors(InterceptorRegistry registry) { // 创建拦截器对象 HandlerInterceptor interceptor = new LoginInterceptor(); // 指定拦截的请求地址。这个代表以user开头的地址全部的拦截 String path [] = {"/user/**"}; // 指定不拦截的请求地址。 String excludePath [] = {"/user/login"}; // addInterceptor() :添加拦截器的方法 // addPathPatterns():添加拦截器拦截的路径的方法 // excludePathPatterns() : 添加拦截器忽略拦截路径的方法。 registry.addInterceptor(interceptor) .addPathPatterns(path) .excludePathPatterns(excludePath); }}复制代码
复制代码
给定两个请求路径,测试拦截器是否起作用
@Controllerpublic class BootController { @RequestMapping("/user/account") @ResponseBody public String userAccount(){ return "访问user/account地址"; } @RequestMapping("/user/login") @ResponseBody public String userLogin(){ return "访问user/login地址"; }}复制代码
复制代码
启动 SpringBoot 的主启动类,请求 Controller 的请求路径测试是否可以被拦截
@SpringBootApplicationpublic class SpringBootInterceptorApplication { public static void main(String[] args) { SpringApplication.run(SpringBootInterceptorApplication.class, args); }}复制代码
复制代码
2.2 SpringBoot 中使用 Servlet
SpringBoot 中使用 Servlet 步骤:
定义一个 Servlet
public class MyServlet extends HttpServlet { @Override protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { doPost(req,resp); } @Override protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { // 使用HttpServletResponse输出数据,应答结果 resp.setContentType("text/html;charset=utf-8"); PrintWriter out = resp.getWriter(); out.println("执行的是Servlet"); out.flush();; out.close(); }}复制代码
复制代码
注册一个 Servlet 对象
@Configurationpublic class WebApplicationConfig { // 定义方法,注册Servlet对象 @Bean public ServletRegistrationBean servletRegistrationBean(){ // public ServletRegistrationBean(T servlet,String... urlMappings) // 第一个参数是 Servlet对象,第二个是url地址 ServletRegistrationBean bean = new ServletRegistrationBean(new MyServlet(),"/myServlet"); return bean; }}复制代码
复制代码
2.3 SpringBoot 中注册 Filter
SpringBoot 中使用 Filter 过滤器
创建自定义过滤器类
// 自定义过滤器public class MyFilter implements Filter { @Override public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException { System.out.println("执行了MyFilter"); filterChain.doFilter(servletRequest,servletResponse); }}复制代码
复制代码
将自定义的过滤器引入到 spirng 容器中
// 将自定义的过滤器配置到spring容器中@Configurationpublic class WebApplicationConfig { public FilterRegistrationBean filterRegistrationBean(){ FilterRegistrationBean bean = new FilterRegistrationBean(); bean.setFilter(new MyFilter()); bean.addUrlPatterns("/user/*"); return bean; }}复制代码
复制代码
在 Controller 中使用过滤器来处理请求
@Controllerpublic class MyController { @RequestMapping("/user/account") @ResponseBody public String userAccount(){ return "/user/account"; }}复制代码
复制代码
以上项目的源代码,点击星球进行免费获取 星球 (Github 地址)如果没有 Github 的小伙伴儿。可以关注本人微信公众号:Java 学术趴,发送 SpringBoot,免费给发给大家项目源码,代码是经过小编亲自测试的,绝对可靠。免费拿去使用。
评论