一个User
可以有多个Authorities
。默认情况下,当我创建一个新用户时,我想给他添加ROLE_USER
权限。
这是用户实体:
@Entity
@Table(name = "Users")
public class User
{
@Id
private String username;
private String password;
private String email;
@OneToMany
@JoinTable(
name = "UserAuthority",
joinColumns = @JoinColumn(name = "username"),
inverseJoinColumns = @JoinColumn(name = "authority"))
private List<Authority> authorities = new ArrayList<>();
和授权实体:
@Entity
public class Authority
{
@Id
private String authority;
我使用的是基本的UserRepository
和AuthorityReposiroty
,它们都是对CrudRepository
的扩展。
这是注册新用户的方法:
public String register(User user)
{
if (userRepository.findOne(user.getUsername()) != null)
{
return "User with given username already exists!";
}
user.setPassword(passwordEncoder.encode(user.getPassword()));
user.getAuthorities().add(authRepository.findOne("ROLE_USER"));
userRepository.save(user);
return "User successfully registered!";
}
当我尝试注册新用户时,会失败,并显示以下错误:
org.postgresql.util.PSQLException: ERROR: duplicate key value violates unique constraint "uk_c1gaghspdr9qx2yt45moye10y"
Detail: Key (authority)=(ROLE_USER) already exists.
我可以在日志中看到Hibernate正在尝试插入ROLE_USER
权限,这是不可能的,因为它已经存在,但我不明白为什么。我还没有在@OneToMany
注解上设置层叠属性。
我如何实现我想要的?
这是我的配置:
compile('org.springframework.boot:spring-boot-starter-data-jpa')
runtime('org.postgresql:postgresql:9.4-1206-jdbc42')
提前感谢!
发布于 2015-12-16 05:38:59
问题出在关系上。你有OneToMany -意味着在另一个网站上是relation ManyToOne...如果您在一个用户中使用了某个权限,则不能将此实体(对象)用于其他用户。
您的问题的解决方案是将关系更改为User类中的@ManyToMany
实例@OneToMany
。它的强度很小,但实际上它是关系ManyToMany,因为用户可以拥有多个权限,任何权限都可以在许多用户中使用。
https://stackoverflow.com/questions/34299142
复制相似问题