我从之前捣鼓shiro时做的demo项目里cv了基本结构代码,准备在此基础上再做一个项目
demo项目本身是已经跑通了的
这是配置类
spring.application.name=order_manage
server.port=8888
server.servlet.context-path=/order
spring.freemarker.prefix=/
spring.mvc.view.suffix=.jsp
spring.datasource.type=com.alibaba.druid.pool.DruidDataSource
spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver
spring.datasource.url=jdbc:mysql://localhost:3306/curriculum?characterEncoding=UTF-8
spring.datasource.username=root
spring.datasource.password=123456
mybatis.type-aliases-package=com.order.entity
mybatis.mapper-locations=classpath:mapper/*.xml
这是我的目录结构(mapper接口前后改了一下名,但不影响)
这是dao接口类,该加的注解都加了
package com.order.dao;
import com.order.entity.User;
import org.apache.ibatis.annotations.Mapper;
@Mapper
public interface UserDao {
public int save(User user);
public User findByUsername(String username);
public User findRolesByUserName(String username);
}
我把所有配置和三层框架都cv了过来,想试一下能不能跑
结果出现了配置报错
这是部分报错
Caused by: org.springframework.beans.factory.NoSuchBeanDefinitionException: No qualifying bean of type 'com.order.dao.UserDao' available: expected at least 1 bean which qualifies as autowire candidate. Dependency annotations: {@org.springframework.beans.factory.annotation.Autowired(required=true)}
at org.springframework.beans.factory.support.DefaultListableBeanFactory.raiseNoMatchingBeanFound(DefaultListableBeanFactory.java:1824) ~[spring-beans-6.0.11.jar:6.0.11]
at org.springframework.beans.factory.support.DefaultListableBeanFactory.doResolveDependency(DefaultListableBeanFactory.java:1383) ~[spring-beans-6.0.11.jar:6.0.11]
at org.springframework.beans.factory.support.DefaultListableBeanFactory.resolveDependency(DefaultListableBeanFactory.java:1337) ~[spring-beans-6.0.11.jar:6.0.11]
at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor$AutowiredFieldElement.resolveFieldValue(AutowiredAnnotationBeanPostProcessor.java:713) ~[spring-beans-6.0.11.jar:6.0.11]
... 67 common frames omitted
很明显,dao的bean注入失败了
实际上因为业务类和其它配置里@Autowired了dao,所以业务和用到了UserDao的其它配置类一并报错了
这里不多赘述
我在业务实现类上加了该加的注解
@Service
@Transactional
实际上我基本上一整个项目都是cv来的,导致错误根本无从排起
application.properties是整个cv然后改路径的
pom.xml是创建工程时自动生成,把整个dependencies都cv了过来
一段折磨之后,我排查到了pom
随手改了一下SpringBoot的版本和项目的groupId
这是修改前的pom.xml(部分)
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>3.1.2</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<groupId>com</groupId>
<artifactId>order</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>order_manage</name>
<description>order_manage</description>
<properties>
<java.version>17</java.version>
</properties>
这是修改后的pom.xml(部分)
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.7.3</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<groupId>com.curriculm</groupId>
<artifactId>order</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>order_manage</name>
<description>order_manage</description>
<properties>
<java.version>17</java.version>
</properties>
然后程序不知道为什么自己就跑起来了?!
原来的groupId是com,看着不太舒服顺手改了一下,我以为就是这个的问题(?
结果发现在我把com.curriculum改回com时也能跑
想起来我还顺手改了SpringBoot的版本号,去核实了一遍,确实
顺理成章发现这个是SpringBoot版本的问题
最开始用3.1.2,bean死活造不出来
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>3.1.2</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
换回2.7.3就跑通了
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.7.3</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
纯纯的环境问题,SpringBoot版本用错了,导致换一个地方同一套配置跑不动
为了之后少踩同样的坑,暂且记录下来
我恨环境配置
话说我的idea新建SpringBoot项目时选项里只有3.以后的版本
要手动在pom里改版本,原因未知,但我懒得管了~