java springmvc搭建_【Spring学习】SpringMVC demo搭建

前言:今天会通过IDEA建立一个SpringMVC的demo项目,在其中会涉及到一些基础模块和相关知识,然后结合这个具体的知识点,理解清楚SpringMVC的框架原理(以图的形式展示),顺藤摸瓜分析源码

一、新建项目

通过File-New-Project,在下方页面勾选:Spring MVC + Web Application

bbe8ac1a8c43df51491d8ebde3c8d973.png

点击Next填上:ProjectName和Project Location,之后会进入下载依赖包的过程:

5a5800282511907f123a1023c4d38860.png

完成之后,在窗口中打开的工程目录如下:其中lib中所放的是依赖的jar包,src中根据自己的需求添加package+class,其中IDEA已经自动帮助在WEB-INF中默认配置了applicationContext.xml、dispatcher-servlet.xml、web.xml

2ecc635a526f31a699ac342639b79904.png

至此,基础工程也包含IDEA自动配置的都已经建好

二、确认配置文件内容

梳理清楚WEB-INF下的三个xml文件的作用和其中所配置内容的具体含义

具体介绍如下:

1、web.xml

作用:用来对DispatcherServlet进行注册和初始化(web.xml configuration registers and initializes the DispatcherServlet)

内容示例:

1 <?xml version="1.0" encoding="UTF-8"?>

2

3 xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"

4 xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_3_1.xsd"

5 version="3.1">

6

7 contextConfigLocation

8 /WEB-INF/applicationContext.xml

9

10

11 org.springframework.web.context.ContextLoaderListener

12

13

14 dispatcher

15 org.springframework.web.servlet.DispatcherServlet

16 1

17

18

19 dispatcher

20 *.form

21

22

重点关注的内容,如图中黄色底色的的部分,这个是WebApplicationContext的配置文件,如上所示就代表只配置了一个WebApplicationContext,一般情况下是足够的,也可以有Context的层次结构:其中一个根WebApplicationContext在多个DispatcherServlet(或其他servlet)实例之间共享,每个实例都有自己的子WebApplicationContext配置:(注:如下图为从官网截图内容)

d86821a7edc83929c23e493c130fa7a9.png

2、applicationContext.xml

作用:这里的名字就是上面黄色底色标注出的xml文件的路径,这个WebApplicationContext具有指向ServletContext及其关联的Servlet的链接;

内容:

1 <?xml version="1.0" encoding="UTF-8"?>

2

3

4

5 xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"

6

7 xmlns:context="http://www.springframework.org/schema/context"

8

9 xmlns:mvc="http://www.springframework.org/schema/mvc"

10

11 xsi:schemaLocation="http://www.springframework.org/schema/beans12

13 http://www.springframework.org/schema/beans/spring-beans.xsd14

15 http://www.springframework.org/schema/context16

17 http://www.springframework.org/schema/context/spring-context.xsd18

19 http://www.springframework.org/schema/mvc20

21 http://www.springframework.org/schema/cache/spring-mvc.xsd">

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

备注:其中

以及下面的bean都是自己添加的

其中,context添加之后,上面的beans中的xmlns和xsi中都会添加上对应的项,mvc的也一样;但是IDEA在自动补齐mvc的内容时会出现cache字样,如下所示,导致出现bug,具体问题及bug解决方案在(三)中

3、dispatcher-servlet.xml:

作用:dispatcher-servlet.xml与applicationContext.xml是孩子与父亲的上下文的关系,在applicationContext.xml中可以定义全局的Spring的特性,dispatcher-servlet.xml就是在Context Hierarchy中定义的子WebapplicationContext.xml的内容,在其中具体定义属于当前Servlet的处理分发逻辑等

三、xml配置问题解决 && 模块功能实现

在applicationContext.xml中添加出现了问题,一共两个问题:

在自动生成这样之后,运行的时候会出现错误提示:

21-Feb-2019 14:50:30.345 严重 [RMI TCP Connection(3)-127.0.0.1] org.springframework.web.context.ContextLoader.initWebApplicationContext Context initialization failed

org.springframework.beans.factory.BeanCreationException: Error creating bean with name'org.springframework.cache.interceptor.CacheInterceptor#0': Cannot resolve reference to bean 'cacheManager' while setting bean property 'cacheManager'; nested exception is org.springframework.beans.factory.NoSuchBeanDefinitionException: No bean named 'cacheManager'available

at org.springframework.beans.factory.support.BeanDefinitionValueResolver.resolveReference(BeanDefinitionValueResolver.java:359)

at org.springframework.beans.factory.support.BeanDefinitionValueResolver.resolveValueIfNecessary(BeanDefinitionValueResolver.java:108)

at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.applyPropertyValues(AbstractAutowireCapableBeanFactory.java:1537)

at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.populateBean(AbstractAutowireCapableBeanFactory.java:1284)

at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:553)

at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:483)

at org.springframework.beans.factory.support.AbstractBeanFactory$1.getObject(AbstractBeanFactory.java:312)

at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:230)

at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:308)

at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:197)

at org.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingletons(DefaultListableBeanFactory.java:761)

at org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.java:867)

at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:543)

at org.springframework.web.context.ContextLoader.configureAndRefreshWebApplicationContext(ContextLoader.java:443)

at org.springframework.web.context.ContextLoader.initWebApplicationContext(ContextLoader.java:325)

at org.springframework.web.context.ContextLoaderListener.contextInitialized(ContextLoaderListener.java:107)

at org.apache.catalina.core.StandardContext.listenerStart(StandardContext.java:4668)

at org.apache.catalina.core.StandardContext.startInternal(StandardContext.java:5136)

at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:183)

at org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:713)

at org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:690)

at org.apache.catalina.core.StandardHost.addChild(StandardHost.java:695)

at org.apache.catalina.startup.HostConfig.manageApp(HostConfig.java:1729)

at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)

at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)

at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)

at java.lang.reflect.Method.invoke(Method.java:498)

[2019-02-21 02:50:30,383] Artifact demo:war exploded: Error during artifact deployment. See server log fordetails.

at org.apache.tomcat.util.modeler.BaseModelMBean.invoke(BaseModelMBean.java:289)

at com.sun.jmx.interceptor.DefaultMBeanServerInterceptor.invoke(DefaultMBeanServerInterceptor.java:819)

at com.sun.jmx.mbeanserver.JmxMBeanServer.invoke(JmxMBeanServer.java:801)

at org.apache.catalina.mbeans.MBeanFactory.createStandardContext(MBeanFactory.java:457)

at org.apache.catalina.mbeans.MBeanFactory.createStandardContext(MBeanFactory.java:406)

at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)

at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)

at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)

at java.lang.reflect.Method.invoke(Method.java:498)

at org.apache.tomcat.util.modeler.BaseModelMBean.invoke(BaseModelMBean.java:289)

at com.sun.jmx.interceptor.DefaultMBeanServerInterceptor.invoke(DefaultMBeanServerInterceptor.java:819)

at com.sun.jmx.mbeanserver.JmxMBeanServer.invoke(JmxMBeanServer.java:801)

at javax.management.remote.rmi.RMIConnectionImpl.doOperation(RMIConnectionImpl.java:1468)

at javax.management.remote.rmi.RMIConnectionImpl.access$300(RMIConnectionImpl.java:76)

at javax.management.remote.rmi.RMIConnectionImpl$PrivilegedOperation.run(RMIConnectionImpl.java:1309)

at javax.management.remote.rmi.RMIConnectionImpl.doPrivilegedOperation(RMIConnectionImpl.java:1401)

at javax.management.remote.rmi.RMIConnectionImpl.invoke(RMIConnectionImpl.java:829)

at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)

at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)

at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)

at java.lang.reflect.Method.invoke(Method.java:498)

at sun.rmi.server.UnicastServerRef.dispatch(UnicastServerRef.java:324)

at sun.rmi.transport.Transport$1.run(Transport.java:200)

at sun.rmi.transport.Transport$1.run(Transport.java:197)

at java.security.AccessController.doPrivileged(Native Method)

at sun.rmi.transport.Transport.serviceCall(Transport.java:196)

at sun.rmi.transport.tcp.TCPTransport.handleMessages(TCPTransport.java:568)

at sun.rmi.transport.tcp.TCPTransport$ConnectionHandler.run0(TCPTransport.java:826)

at sun.rmi.transport.tcp.TCPTransport$ConnectionHandler.lambda$run$0(TCPTransport.java:683)

at java.security.AccessController.doPrivileged(Native Method)

at sun.rmi.transport.tcp.TCPTransport$ConnectionHandler.run(TCPTransport.java:682)

at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142)

at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617)

at java.lang.Thread.run(Thread.java:745)

Caused by: org.springframework.beans.factory.NoSuchBeanDefinitionException: No bean named'cacheManager'available

at org.springframework.beans.factory.support.DefaultListableBeanFactory.getBeanDefinition(DefaultListableBeanFactory.java:687)

at org.springframework.beans.factory.support.AbstractBeanFactory.getMergedLocalBeanDefinition(AbstractBeanFactory.java:1213)

at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:284)

at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:197)

at org.springframework.beans.factory.support.BeanDefinitionValueResolver.resolveReference(BeanDefinitionValueResolver.java:351)

...60 more

以上错误中的cacheManager,我并没有用到,但是很奇怪,为什么会抛出这个错误,搜索全局找跟cache相关的内容,发现在xml文件中出现了xmlns和schemaLocation中有cache的内容出现,基于此继续追查(后面会补一篇xml解析和schema的内容),发现可能是这里配置的问题,而且因为实际上还没有走到具体逻辑中,是在启动过程中就已经抛出错误,出现cache的xmlns的内容如下:xmlns:mvc=http://www.springframework.org/schema/cache

然后找到这个mvc是在下面定义的:相匹配,重新输入内容自动联想发现:红色框线内基本都是annotation-driven,只是来源不同,默认点击enter会自动选择cache的路径,导致出现这个错误

072cf8aa18d13ae39f1b01a9ebc6d6d8.png

8.5章节中有如下内容描述:

The cache abstraction provides several storage integration options. To use them, you need to declare an appropriate CacheManager (an entity that controls and manages Cache instances and that can be used to retrieve these for storage).

之后官网详细的基于不同方式的cache需要配置的xml内容做了demo样例,也查询了一些其他文档,本地添加bean的声明之后,异常消失:

bffc6b60735c46843c5ecd4ee3b1412a.png

至此,这个基于自动补齐的的问题解决,但实际上,我需要的是:mvc的namespace和对应的xsd,修改程序将:namespace和schemaLocations中的cache都改成mvc:

653dd1f6e85bef7e9d563b0684d4521e.png

在applicationContext.xml中继续添加bean配置:

在src下建包名/类,testController.java的实现,如下:

@Controllerpublic classTestController {

@RequestMapping("/test.form")public voidexecute(){return;

}

}

test.jsp的内容如下:

test

四、运行

点击run之后会提示进行Edit Configurations,进入页面,将相应内容填入(需要启动TomcatServer并设置路径)

d10a559dee03a182e42403d459c4662c.png

设置Demployment:

867c636ab79f2808aadadc6eee1c9c16.png

之后点击run按钮,运行提示ClassNotFound:

严重 [RMI TCP Connection(3)-127.0.0.1] org.apache.catalina.core.StandardContext.listenerStart Error configuring application listener of class[org.springframework.web.context.ContextLoaderListener]

java.lang.ClassNotFoundException: org.springframework.web.context.ContextLoaderListener

at org.apache.catalina.loader.WebappClassLoaderBase.loadClass(WebappClassLoaderBase.java:1363)

at org.apache.catalina.loader.WebappClassLoaderBase.loadClass(WebappClassLoaderBase.java:1186)

at org.apache.catalina.core.DefaultInstanceManager.loadClass(DefaultInstanceManager.java:540)

at org.apache.catalina.core.DefaultInstanceManager.loadClassMaybePrivileged(DefaultInstanceManager.java:521)

at org.apache.catalina.core.DefaultInstanceManager.newInstance(DefaultInstanceManager.java:150)

at org.apache.catalina.core.StandardContext.listenerStart(StandardContext.java:4590)

但工程的lib目录下的jar都引入了,那就是Tomcat运行的时候加载不到这个jar包的原因,通过File-Project Structure打开进入到工程设置页面,如下图所示,将右侧点击之后选择Put into output Root,

2e57a499daac66d620bf4b9b3130e7bd.png

之后查看左侧output root的按钮,可以看到:WEB-INF下有SpringMVC的jar包:

e0ced8f2c8c059e129a42f83b67fc9ee.png

以上问题都解决以后,就能够运行成功整个项目了~

备注:在运行过程中,下方窗口中出现运行日志会有中文乱码的情况:可以参考该篇文章:https://blog.csdn.net/qq_41264674/article/details/80945140

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Spring Boot MyBatis 整合可以使用以下步骤: 1. 新建一个 Spring Boot 项目,并添加 MyBatis 和 Spring MVC 的依赖。 ```xml <dependency> <groupId>org.mybatis.spring.boot</groupId> <artifactId>mybatis-spring-boot-starter</artifactId> <version>2.1.4</version> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> ``` 2. 配置 MyBatis 的数据源和 SQLSessionFactory。 ```java @Configuration @MapperScan("com.example.demo.mapper") public class MybatisConfig { @Bean @ConfigurationProperties(prefix = "spring.datasource") public DataSource dataSource() { return new DruidDataSource(); } @Bean public SqlSessionFactory sqlSessionFactory() throws Exception { SqlSessionFactoryBean sessionFactory = new SqlSessionFactoryBean(); sessionFactory.setDataSource(dataSource()); return sessionFactory.getObject(); } } ``` 3. 编写 Mapper 接口和对应的 XML 映射文件。 ```java public interface UserMapper { @Select("SELECT * FROM user WHERE id = #{id}") User getUserById(@Param("id") Integer id); } ``` ```xml <mapper namespace="com.example.demo.mapper.UserMapper"> <select id="getUserById" resultType="com.example.demo.entity.User"> SELECT * FROM user WHERE id = #{id} </select> </mapper> ``` 4. 在 Controller 中注入 Mapper 并使用。 ```java @RestController public class UserController { @Autowired private UserMapper userMapper; @GetMapping("/user/{id}") public User getUserById(@PathVariable Integer id) { return userMapper.getUserById(id); } } ``` 以上就是 Spring Boot MyBatis 整合的基本步骤。需要注意的是,在使用 MyBatis 时,需要在 Mapper 接口上添加 `@Mapper` 注解或使用 `@MapperScan` 注解指定 Mapper 接口所在的包。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值