이번시간에는 회원 등록을 해보았다.

 

package hello.hellospring.controller;

import hello.hellospring.service.MemberService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.GetMapping;

@Controller
public class MemberController {


    private final MemberService memberService;

    @Autowired
    public MemberController(MemberService memberService){
        this.memberService = memberService;
    }

    @GetMapping("/members/new")
    public String createForm(){
        return "members/createMemberForm";
    }
}

기존에 만들어 놨던 MemberController에 

/members/new 를 매핑으로 사용하는 creatForm을

만들었다. members/createMemberForm을 반환하게된다!

 

<!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디렉터리를 만들고 그 하위에 createMemberForm.html을 

만들었다. input type태그를 사용하여 

이름을 입력받고 등록버튼을 누르면 서버로 값이 전달되게 된다.

 

그 다음으로는 넘어온 값을 받아서 실제 회원가입을 할 수 있게끔 만들었다.

package hello.hellospring.controller;

public class MemberForm {

    private String name;

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }
}

먼저 MemberForm 이라는 클래스를 만들고 Getter and Setter를 만들어준다 

이유는 받아온 값을 매칭시켜줄 클래스를 만들어야하기 때문이다!

 

package hello.hellospring.controller;

import hello.hellospring.domain.Member;
import hello.hellospring.service.MemberService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PostMapping;

@Controller
public class MemberController {


    private final MemberService memberService;

    @Autowired
    public MemberController(MemberService memberService){
        this.memberService = memberService;
    }

    @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:/";
    }
}

그런 다음 @PostMapping으로 create를 만들었다.

 

-createForm()

먼저 회원가입을 누르면 members/new로 들어온다

이때는 Get방식이다 단지 members/createMemberForm 을 뿌려주는것뿐이다.

createMemberForm 에 이름을 넣고 등록버튼을 누르면 Post 방식으로 넘어온다!!

 

PostMapping은 데이터를 폼 ?같은것에 넣고 전달할때 쓰인다.

Get은 조회할때 쓰인다

url은 같지만 Post냐 Get이냐 에 따라 다르게 매핑이 가능한다.

 

등록버튼이 눌러지면 Post매핑인 create()가 동작한다.!

-create()

이때 MemberForm 의 name에 데이터 값이 들어오게된다.

(스프링이 createMemberForm.html에 있는 

input type에 name을 보고 넣어주게된다.)

스프링이 setName()을 통해서 값을 넣어주게되고

 

나는 getName을 이용하여 member 객체에 name값을 

넘겨준다!

 

그리고 join을 이용하여 가입하고

 

redirect 를 이용하여 " / "를 다시 요청한다.!

+ Recent posts