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
'Spring > 스프링 입문' 카테고리의 다른 글
[스프링 입문] 06. 스프링 DB 접근 기술 - H2 데이터베이스 설치 (0) | 2022.04.28 |
---|---|
[스프링 입문] 05. 회원 관리 예제(웹 MVC 개발) - 회원 웹 기능3(조회) (0) | 2022.04.28 |
[스프링 입문] 05. 회원 관리 예제(웹 MVC 개발) - 회원 웹 기능1(홈 화면 추가) (0) | 2022.04.28 |
[스프링 입문] 04. 스프링 빈과 의존 관계 - 자바 코드로 직접 스프링 빈 등록하기 (0) | 2022.04.28 |
[스프링 입문] 04. 스프링 빈과 의존 관계 - 컴포넌트 스캔과 자동 의존 관계 설정 (0) | 2022.04.28 |