javascript의 submit에서 controller 호출이 안되고 403 에러가 나요.
1837
작성한 질문수 10
javascript를 이용하여 삭제에 대해 다시한번 확인을 요청하려 합니다.
기존에 form에 직접 method, action을 입력했을때는 controller의 delete함수가 잘 호출되었으나,
javascript로 form을 작동시에는 controller의 delete함수가 호출되지 않고, 403 에러가 발생합니다.
<form id = "deleteForm" >
<input type="hidden" name="sdkVer" class="form-control"
th:value="${item.sdkVer}" readonly>
<input type="hidden" name="plfmCode" class="form-control"
th:value="${item.plfmCode}" readonly>
<input type="hidden" name="cntryCode" class="form-control"
th:value="${item.cntryCode}" readonly>
<input type="hidden" name="epgSettingId" class="form-control"
th:value="${epg.epgSettingId}" readonly>
<td>
<button class="btn btn-primary " onclick="checkDelete()" >삭제</button>
</td>
<script type="text/javascript">
function checkDelete() {
var check = confirm("삭제를 하시겠습니까?");
if(check == true){
var deleteForm = document.getElementById("deleteForm");
deleteForm.action='/delete';
deleteForm.method = 'post';
deleteForm.submit();
}
else if(check == false){
document.write("취소를 눌렀습니다.");
}
}
</script>
</form>
@PostMapping("/delete")
public String delete(Model model, @RequestParam Map<String , String> attributes) throws IOException {
System.out.println("HomeController.delete");
System.out.println("attributes.get(\"plfmCode\") = " + attributes.get("plfmCode"));
EpgId originalEpgId = new EpgId(attributes.get("epgSettingId"), attributes.get("plfmCode"), attributes.get("sdkVer"), attributes.get("cntryCode"), "N");
itemService.delete(originalEpgId);
return post_detail(new Item( attributes.get("plfmCode"), attributes.get("sdkVer"), attributes.get("cntryCode")), model);
}
답변 1
1
안녕하세요. 예람님
403 오류는 시큐리티 관련 오류입니다.
아마도 스프링 시큐리티에서 form을 만들 때 thymeleaf와 자동으로 연동이 되어서, csrf 공격을 보호하기 위해 다음 부분이 자동으로 만들어질거에요.
(브라우저 소스보기에서 보여야 합니다.)
<input type="hidden" name="_csrf" value="...."/>
그런데 아마 소스보기를 하시면 _csrf hidden 이 안보일꺼에요.
폼을 생성할 때
<form id = "deleteForm" > 이렇게 생성하면 안되고,
다음과 같이 생성하시면
<form th:action method="post" id="insertForm">
thymeleaf가 인식을 해서 다음 부분을 자동으로 만들어줄거에요.
<input type="hidden" name="_csrf" value="...."/>
감사합니다.
existsByUserIdAndProjectId vs existsByUserAndProject 중 어떤 방식이 적절할까요?
0
64
1
existsByUserIdAndProjectId vs existsByUserAndProject 중 어떤 방식이 적절할까요?
0
100
3
MemberRepository 구현체
0
55
1
pdf 표현 질문드립니다.
0
59
1
로그가 남지 않는 문제.
0
78
1
테스트 라이브러리가 강의는 junit4가 맞나요??
0
67
2
pdf 파일과 차이점이 있는 것같은데 문제 없나요?
0
68
2
@PrePersist, @PreUpdate 호출 시점 질문드립니다.
0
87
2
Sort 인터페이스는 잘 사용 안하나요?
0
50
1
스캔대상 질문드립니다.
0
45
1
하이버네이트6에서의 최적화에 이은 질문
0
81
1
save() vs saveAndFlush DB 통신 횟수
0
50
1
순수 JPA 리포지토리 코드 수정부분
0
85
2
bulk연산 후 flush하는 이유를 모르겠어요
0
147
3
bulk insert 질문입니다.
0
174
2
교만했던 것 같아요.
0
142
1
RESTful 강의는 안하시는 건지 궁금합니다.
0
143
2
동적 테이블에 대한 질문
0
84
1
영속성 전이와 연관관계
0
128
2
강의 10:25 질문
0
71
1
단건 update 질문
0
94
2
엔티티 와 도메인의 경계
0
124
1
UsernameOnlyDto 타입 type mismatch 오류
0
114
1
Projection 개념과 데이터 전달과정에 대해 질문 있습니다.
0
131
1





