这篇“怎么使用Idea搭建全注解式开发的SpringMVC项目”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“怎么使用Idea搭建全注解式开发的SpringMVC项目”文章吧。
1. 创建项目
1.打开
Idea,并点击新建项目
注:使用的是
2022.2的商业版,该版本跟
2021.2的商业版创建
Maven项目不一样
2.点击右侧的新建项目 -> 取名 -> 创建
3.这样我们就创建了一个空依赖的
Maven项目
4.打开项目 -> 右键项目名 -> 点击添加框架支持
有时会找不到,重复这个过程即可
5.勾选
Web应用程序,然后点击确定,若出现
Web目录,则加载完毕
这创建的是传统的
Java Web项目:带
Web目录的,该目录下存在
WEB-INF目录
6.补全目录
创建完的目录结构如下, 缺失了一些目录,需要自己在
test目录下创建
resource目录
web目录:该目录的文件能被外界访问
WEB-INF目录:该目录的文件不对外展示
web.xml:主要用来配置
Filter、
Listener、
Servlet等
7.在
pom.xml文件里加入如下代码,然后刷新
Maven,这样会在
target里生成
war文件
不这样做的话,工件中就没有我们通过
Maven引入的
Jar包,会导致项目中用到引入
Jar包的地方出错,如下所示
如: 使用
@Controller注解设置请求时,会报
404
<!--设置打包方式为war--> <packaging>war</packaging>
8.或者项目结构->工件->创建
lib目录->添加
Jar包
2. 配置Tomcat
点击当前文件
点击编辑配置
点击
+
找到
Tomcat服务器,点击下面的本地
点击配置
点击
Tomcat主目录旁的文件图标,选择你
Tomcat安装到的文件夹所对应的路径,点击确定
这个文件夹应该是
bin目录的父目录
如果是正确的话,
idea会自动帮你填写
Tomcat基目录
配置工件:点击修复 -> 会进入一个新页面 -> 修改应用程序上下文,保留一个
/即可
我们添加框架支持的时候就会创建一个相关的工件
3. 示例
1.在
pom.xml文件中引入相关依赖
<!-- 添加springmvc依赖 --> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-webmvc</artifactId> <version>5.3.18</version> </dependency> <!-- 添加servlet 依赖 --> <dependency> <groupId>javax.servlet</groupId> <artifactId>javax.servlet-api</artifactId> <version>4.0.1</version> <scope>provided</scope> </dependency>
2.创建
Controller包
3.在
Controller包下创建
UserController.java文件, 复制下面代码到该文件中
package org.example.Controller;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;
@Controller
    public class UserController {
        @RequestMapping("/save")
        @ResponseBody
        public String index() {
            return "index";
        }
    }4.创建
Config包
5.在
Config包下创建一个专用于
SpringMVC的配置类-----
SpringMvcConfig
该配置类将
@ComponentScan注解只用于扫描
Controller包
为什么要有
SpringMVC专门的配置类, 就是为了
bean管理起来更清晰
就是将
controller层放在
springmvc容器中管理, 其他如
service层放在父容器
Spring中管理
@Configuration
@ComponentScan("org.example.Controller")
//扫描Controller包
public class SpringMvcConfig {
}6.在
Config包下创建
Tomcat启动类
SpringMvcInit类
该类要继承
AbstractDispatcherServletInitializer类
AbstractDispatcherServletInitializer类:用于
Tomcat启动
package org.example.Config;
import org.example.Config.SpringMvcConfig;
import org.springframework.web.context.WebApplicationContext;
import org.springframework.web.context.support.AnnotationConfigWebApplicationContext;
import org.springframework.web.servlet.support.AbstractDispatcherServletInitializer;
//定义一个servelt容器启动的配置类,用于加载spring的配置类
public class SpringMvcInit  extends AbstractDispatcherServletInitializer {
    //1. 将controller层放在springmvc容器中,其他如service层放在父容器,bean管理起来更清晰
    //2. 也可以没有父容器,将所有bean都放在springmvc容器中
    @Override
    //加载springMVC容器的配置类
    protected WebApplicationContext createServletApplicationContext() {
        //创建SpringMVC容器
        AnnotationConfigWebApplicationContext ctx = new AnnotationConfigWebApplicationContext();
        //加载配置类--SpringMvcConfig
        ctx.register(SpringConfig.class);
        return ctx;
    }
    @Override
    //配置哪些请求要被拦截,归属SpringMVC处理
    // /: 拦截所有请求
    protected String[] getServletMappings() {
        return new String[]{"/"};
    }
    @Override
    //加载Spring容器的配置类
    protected WebApplicationContext createRootApplicationContext() {
        return null;
    }
}2. 该类要继承`AbstractAnnotationConfigDispatcherServletInitializer`类, 用于简化开发
public class SpringMvcInit  extends AbstractAnnotationConfigDispatcherServletInitializer {
    //1. 将controller层放在springmvc容器中,其他如service层放在父容器,bean管理起来更清晰
    //2. 也可以没有父容器,将所有bean都放在springmvc容器中
    // === 上面的createRootApplicationContext()做的事
    //用来加载  springmvc容器的父容器spring的配置类
    @Override
    protected Class<?>[] getRootConfigClasses() {
        return new Class[0];
    }
    //加载springMVC的配置类
    //=== 上面的createServletApplicationContext()做的事
    @Override
    protected Class<?>[] getServletConfigClasses() {
        return new Class[]{SpringConfig.class};
    }
    //配置哪些请求要被拦截,归属SpringMVC处理
    // /: 拦截所有请求
    @Override
    protected String[] getServletMappings() {
        return new String[]{"/"};
    }
}