Spring/스프링 입문

[스프링 입문] 05. 회원 관리 예제(웹 MVC 개발) - 회원 웹 기능2(등록)

HSY_mumu 2022. 4. 28. 21:47
728x90

(인프런) 김영한님의 스프링 입문 - 코드로 배우는 스프링 부트, 웹 MVC, DB 접근 기술을 공부하고 리뷰한 글입니다.

1. 회원 등록 폼 개발

1. 회원 등록 폼 컨트롤러

1) controller 패키지에 MemberController 클래스 생성

2) MemberController 코드 작성

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.ui.Model;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PostMapping;

import java.util.List;

@Controller
public class MemberController {
    // private final MemberService memberService = new MemberService();
    // 스프링 컨테이너에 스프링 빈으로 등록을 해두고 가져다 쓰는 방식(같은 MemberService를 공유하도록)
    private final MemberService memberService;

    // 회원 컨트롤러 & 회원 서비스 연결
    @Autowired
    public MemberController(MemberService memberService) {
        this.memberService = memberService;
    }

    // /members/new에 대한 GET 요청이 들어오면
    @GetMapping("/members/new")
    public String createForm() {
        return "members/createMemberForm";  // 해당 html String으로 반환
    }
}

 

2. 회원 등록 폼 HTML

1) templates/members 에 createMemberForm.html 생성

2) 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>
  • <input>에 입력한 텍스트가 post로 폼이 제출되면 key가 name으로 사용됨
  • 등록 버튼을 클릭하면 post폼이 /member/new 로 제출

2. 회원 등록 컨트롤러

1. 웹 등록 화면에서 데이터를 전달 받을 폼 객체

1) controller 패키지에 MemberForm 클래스 생성

2) MemberForm 코드 작성

package hello.hellospring.controller;

import hello.hellospring.domain.Member;

public class MemberForm {
    private String name;    

    public String getName() {
        return name;
    }

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

}

 

2. 회원 컨트롤러에서 회원을 실제 등록하는 기능

1) Controller 패키지에 MemberController 클래스에 회원 등록 함수 작성

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.ui.Model;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PostMapping;

import java.util.List;

@Controller
public class MemberController {
	...
    // /members/new에 대한 POST 요청이 들어오면
    @PostMapping("/members/new")
    public String create(MemberForm form) {
        Member member = new Member();
        member.setName(form.getName()); // form 에서 받은 name 넣어줌

        memberService.join(member); // 회원 가입
        //System.out.println("member = "+ member.getName());

        return "redirect:/";    // 홈 화면으로
    }
}
  • members/new에 대한 POST 요청이 들어오면 파라미터로 들어온 form에 자동으로 폼 값이 담겨져서 온다.

 

 

728x90