我正在尝试在 Spring Boot 中使用 Hibernate 作为 JPA 设置一个简单的项目,我尝试了这个和这个教程,并且在这两个(和任何地方)@SpringBootApplication
似乎都足以使存储库在整个应用程序范围内都可以访问,因为它包括@ComponentScan
,但在我的情况下,它不是。即使这个答案看起来也适合我的情况,但不是。
项目结构
project
│ └── src
│ └── main
│ └── java
│ └── medisam
| └── Application.java
│ └── src
│ └── main
│ └── java
│ └── medisam
│ └── entity
│ └── User.java
| └── UserRepository.java
│ └── src
│ └── main
│ └── java
│ └── medisam
│ └── controller
│ └── MainController.java
有了这样的结构和这段代码:
@SpringBootApplication
public class Application {
...
private static final Logger LOG = LoggerFactory.getLogger(Application.class);
@Autowired
private UserRepository repo;
public static void main(String args[]) {
SpringApplication.run(Application.class, args);
}
...
}
我得到:
...创建名称为 “应用程序”的 bean 时出错:通过字段“repo”表示不满足的依赖关系;嵌套异常是 org.springframework.beans.factory.NoSuchBeanDefinitionException :没有 “medisam.entity.UserRepository” 类型的合格 bean可用:预计至少有 1 个有资格作为 自动装配 候选者的 bean。依赖注解: {@org.springframework.beans.factory.annotation.Autowired(required=true)} ...
只有当我这样做时:
@ComponentScan(basePackages = {"medisam.controller", "medisam.entity"})
@EntityScan({"medisam.entity"})
@EnableJpaRepositories(basePackages = {"medisam.entity"})
public class Application {
...
private static final Logger LOG = LoggerFactory.getLogger(Application.class);
@Autowired
private UserRepository repo;
public static void main(String args[]) {
SpringApplication.run(Application.class, args);
}
...
}
我得到了一个工作代码,但是,如果真的有办法只用 实现这个@SpringBootApplication
,我想使用它。
会不会@SpringBootApplication
是扫描不正确?
请帮忙
编辑
用户存储库.java
package medisam.entity;
import org.springframework.data.jpa.repository.JpaRepository;
import org.springframework.stereotype.Repository;
@Repository
public interface UserRepository extends JpaRepository<User, Integer> {
}
用户.java
package medisam.entity;
import java.util.Set;
import javax.persistence.Access;
import javax.persistence.AccessType;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.JoinColumn;
import javax.persistence.JoinTable;
import javax.persistence.ManyToMany;
@Entity
public class User {
@Id
@GeneratedValue(strategy = GenerationType.AUTO)
private Integer id;
private String name;
private String email;
private String username;
private String password;
private boolean enabled;
@ManyToMany(targetEntity = Role.class)
@Access(AccessType.FIELD)
@JoinTable(name = "user_role", joinColumns = @JoinColumn(name = "user_id", referencedColumnName = "id"),
inverseJoinColumns = @JoinColumn(name = "role_id", referencedColumnName = "id"))
private Set<Role> roles;
public Integer getId() {
return id;
}
public void setId(Integer id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getEmail() {
return email;
}
public void setEmail(String email) {
this.email = email;
}
public String getUsername() {
return username;
}
public void setUsername(String username) {
this.username = username;
}
public String getPassword() {
return password;
}
public void setPassword(String password) {
this.password = password;
}
public boolean isEnabled() {
return enabled;
}
public void setEnabled(boolean enabled) {
this.enabled = enabled;
}
public Set<Role> getRoles() {
return roles;
}
public void setRoles(Set<Role> roles) {
this.roles = roles;
}
}