본문 바로가기
코드로 배우는 스프링 부트 - 인프런

회원 웹 기능 - 등록

by step 1 2022. 8. 14.
반응형

기존 MemberController 코드 추가

//  입력 화면 호출
    @GetMapping("/members/new")
    public String createForm() {
        return "members/createMemberForm";
    }

//  입력 화면 데이터 전달 받은 후 처음 화면 호줄
    @PostMapping("/members/new")
    public String create(MemberForm form) {
        Member member = new Member();
        member.setName(form.getName());

        memberService.join(member);
        return "redirect:/";
    }

 

MemberForm 클래스 생성 -> Html에서 Form 데이터를 전달 받는 역할

package hello.hellospring.controller;

public class MemberForm {
    private String name;

    public String getName() {
        return name;
    }

    public void setName(String name) {
//      스프링에서 html form안에 name과 일치하는 데이터를 받아 줌
        this.name = name;
    }



        
}

 

Html 작성 -> members/createMemberForm.html

<!DOCTYPE HTML>
<html xmlns:th="http://www.thymeleaf.org">
<body>
<div class="container">
    <form action="/members/new" method="post">
        <div class="form-group">
            <label for="name">이름</label>
            <input type="text" id="name" name="name" placeholder="이름을 입력하세요">
        </div>
        <button type="submit">등록</button>
    </form>
</div> <!-- /container -->
</body>
</html>

 

동작 순서

사용자가 회원 가입 링크를 클릭하면 members/new getMapping 동작 -> 해당 html파일을 검색하여 호출

-> 사용자가 입력 후 등록 버튼을 클릭하면 members/new postMappng 동작 

Html에 name 값으로 들어있던 값을 MemberForm 클래스에서 자동으로 setter를 이용해서 받고 getter로 호출하여 Member 클래스에 저장 -> MemberService의 join 메소드를 호출하여 저장기능 동작

-> redirect: 명령어를 통해 처음페이지로 돌아감

 

여기서 중요한 점

html에서 name 값으로 해당 클래스에 같은 이름의 변수와 맵핑 된다는 점

url 경로가 같아도 get, post 전달 방식이 다르면 각각 다르게 동작한다는 점

post는 데이터를 전달할 때, get은 조회할 때 사용한다는 점

redirect 명령어를 return에 넣어주면 해당 url에 해당하는 html 화면을 보여준다는 점

반응형