inflearn logo
강의

講義

知識共有

スプリングセキュリティ

3) Webベースの認可処理DB連動 - 主なアーキテクチャについて

진행중에 jpa 오류가 발생 합니다.

解決済みの質問

775

yeong

投稿した質問数 8

0

org.springframework.dao.InvalidDataAccessApiUsageException: detached entity passed to persist: io.security.corespringsecurity.domain.entity.Role; nested exception is org.hibernate.PersistentObjectException: detached entity passed to persist: io.security.corespringsecurity.domain.entity.Role

 

 

찾아보니까 

 

@ManyToOne(cascade = {CascadeType.ALL},fetch = FetchType.LAZY)

 

해당 에러가 발생 합니다.

 

RoleHierarchy 의 경우

 

package io.security.corespringsecurity.domain.entity;

 

import lombok.*;

 

import javax.persistence.*;

import java.io.Serializable;

import java.util.HashSet;

import java.util.Set;

 

@Entity

@Table(name="ROLE_HIERARCHY")

@Data

@AllArgsConstructor

@NoArgsConstructor

@ToString(exclude = {"parentName", "roleHierarchy"})

@Builder

public class RoleHierarchy implements Serializable {

@Id

@GeneratedValue

private Long id;

 

@Column(name = "child_name")

private String childName;

 

@ManyToOne(cascade = {CascadeType.ALL},fetch = FetchType.LAZY)

    @JoinColumn(name = "parent_name", referencedColumnName = "child_name")

    private RoleHierarchy parentName;

 

    @OneToMany(mappedBy = "parentName", cascade={CascadeType.ALL})

    private Set<RoleHierarchy> roleHierarchy = new HashSet<RoleHierarchy>();

}

 

해당 내용으로 작성 하였구요 

 

 

SetupDataLoader에서 

setupSecurityResources()

 

=>

 

 

private void setupSecurityResources() {

Set<Role> roles = new HashSet<>();

        Role adminRole = createRoleIfNotFound("ROLE_ADMIN", "관리자");

        roles.add(adminRole);

 

        createResourceIfNotFound("/admin/**", "", roles, "url");

        createUserIfNotFound("admin", "pass", "admin@gmail.com", 10,  roles);

        

        Set<Role> roles1 = new HashSet<>();

        Role managerRole = createRoleIfNotFound("ROLE_MANAGER", "매니저");

        roles1.add(managerRole);

 

        createResourceIfNotFound("io.security.corespringsecurity.aopsecurity.method.AopMethodService.methodTest", "", roles1, "method");

        createResourceIfNotFound("io.security.corespringsecurity.aopsecurity.method.AopMethodService.innerCallMethodTest", "", roles1, "method");

        createResourceIfNotFound("execution(* io.security.corespringsecurity.aopsecurity.pointcut.*Service.*(..))", "", roles1, "pointcut");

        createUserIfNotFound("manager", "pass", "manager@gmail.com", 20, roles1);

        createRoleHierarchyIfNotFound(managerRole, adminRole);

 

        Set<Role> roles3 = new HashSet<>();

        Role childRole1 = createRoleIfNotFound("ROLE_USER", "회원");

        roles3.add(childRole1);

 

        createResourceIfNotFound("/users/**", "", roles3, "url");

        createUserIfNotFound("user", "pass", "user@gmail.com", 30, roles3);

        createRoleHierarchyIfNotFound(childRole1, managerRole);

}

해당 내용으로 작성 하였습니다.

 

보고 따라치는 과정에서 무언가 빠졌을까요

 

 

 

 

spring-boot java Spring Security

回答 2

0

griotold

에러 메세지를 보면

detached entity passed to persist

JPA의 영속성 컨텐스트에서 분리된 상태라 예외가 발생한듯 보입니다. 강사님께서 제공한 코드 그대로 두시고CustomUserDetailsService의 loadUserByUsername()메소드 위에 @Transactional만 붙여도 정상 작동합니다. 설명을 덧붙이자면 영속성 컨텍스트는 트랜잭션 안에서 동작 해야 합니다.

0

yeong

Account entity 의 

@ManyToMany(fetch = FetchType.LAZY, cascade={CascadeType.MERGE})

    @JoinTable(name = "account_roles", joinColumns = { @JoinColumn(name = "account_id") }, inverseJoinColumns = {

            @JoinColumn(name = "role_id") })

    private Set<Role> userRoles = new HashSet<>();

 

로 변경 하여 해결 하였습니다.

 

시큐리티 공부 버전 질문

0

175

1

[해결 방법] MethodSecurityConfig.customMethodSecurityMetadataSource() 호출하지 않는 이슈

0

186

1

AbstractSecurityInterceptor.class.beforeInvocation()를 2번 실행하는 경우

0

174

1

강의 코드가 왜이렇게 뒤죽박죽인가요...

0

249

1

메인 페이지로 접속해도 login url로 리다이렉트가 되지 않습니다..

0

236

1

파라미터값이 넘어가지 않습니다 ....

0

374

1

security filterChain 설정 질문이 있습니다.

0

331

1

소스 부분 질문 드립니다.

0

208

2

섹션4 7번 강의 문제가 있는거 같네요.

0

344

2

파일이 수시로 이름이 바껴있네요 ㄷㄷ

0

304

1

HttpSessionSecurityContextRepository를 사용안하는 문제

0

555

2

error , exception 이 잘 안됩니다.

0

281

2

thymeleaf tag 질문합니다.

0

196

2

버전업하면서 deprecated된 것들이 너무많아요

0

478

1

spring security 패치 관련

0

437

1

모바일을 사용할때 토큰말고 세션

0

846

2

DB 연동한 인가 부분에 대한 질문입니다!

0

264

1

Ajax방식도 똑같이 Session방식을 사용하는건가요?

0

307

1

Config 파일 생성 시 질문이 있습니다.

0

225

1

강사님 몇일동안 구글 검색만 100개 했는데도 이유를 모르겠습니다..

1

429

2

403 에러 뜹니다.

0

813

2

login_proc의 존재에 대한 간략한 설명입니다

0

276

1

top.html에 로그인 링크를 만들어서 로그인을 해봤습니다

0

282

2

안녕하세요. DB에 저장될 때 이해 안 가는 값이 있어서 질문드립니다!

0

189

1