본 게시글은 김영한님의 [스프링 입문 - 코드로 배우는 스프링 부트, 웹 MVC, DB 접근 기술]을 수강하며 작성한 글입니다.
1. 회원 웹 기능 - 홈 화면 추가
1. HomeController 파일 생성
package hello.hellospring.controller;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.GetMapping;
@Controller
public class HomeController {
@GetMapping("/")
public String home() {
return "home";
}
}
2. resources/templates/home.html 파일 생성
<!DOCTYPE html>
<html xmlns:th="http://www.thymeleaf.org">
<body>
<div class="container">
<div>
<h1>Hello</h1>
<p>회원 기능</p>
<p>
<a href="/members/new">회원가입</a>
<a href="/members">회원 목록 조회</a>
</p>
</div>
</div>
</body>
</html>
3. 테스트 - localhost:8080/ 접속
💡 welcome page(index.html)는?
→ 컨트롤러가 정적 파일보다 우선순위가 높다.
2. 회원 웹 기능 - 등록
1. MemberController에 @GetMapping("/members/new") 추가
@GetMapping("/members/new")
public String createForm() {
return "members/createMemberForm";
}
2. /resources/templates/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>
form을 작성하여 제출하면 post 메서드로 요청이 전송된다.
3. MemberForm.java 파일을 생성한다.
package hello.hellospring.controller;
public class MemberForm {
private String name;
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
}
웹에서 데이터를 전달받을 객체인 form 클래스를 생성한다.
4. MemberController에 @PostMapping("/members/new") 추가
public String create(MemberForm form) {
Member member = new Member();
member.setName(form.getName());
memberService.join(member);
return "redirect:/";
}
3. 회원 웹 기능 - 조회
1. MemberController에 @GetMapping("/members") 추가
@GetMapping("/members")
public String list(Model model) {
List<Member> members = memberService.findMembers();
model.addAttribute("members", members);
return "members/memberList";
}
2. resources/templates/members/memberList.html 파일 생성
<!DOCTYPE HTML>
<html xmlns:th="http://www.thymeleaf.org">
<body>
<div class="container">
<div>
<table>
<thead>
<tr>
<th>#</th>
<th>이름</th>
</tr>
</thead>
<tbody>
<tr th:each="member : ${members}">
<td th:text="${member.id}"></td>
<td th:text="${member.name}"></td>
</tr>
</tbody>
</table>
</div>
</div> <!-- /container -->
</body>
</html>
@GetMapping("/members")에서 model을 통해 전달된 데이터(members)를 루프를 돌면서 렌더링한다.
'Courses > Spring' 카테고리의 다른 글
[스프링 입문 - 코드로 배우는 스프링 부트, 웹 MVC, DB 접근 기술] 7. AOP (0) | 2023.09.24 |
---|---|
[스프링 입문 - 코드로 배우는 스프링 부트, 웹 MVC, DB 접근 기술] 6. 스프링 DB 접근 기술 (0) | 2023.09.24 |
[스프링 입문 - 코드로 배우는 스프링 부트, 웹 MVC, DB 접근 기술] 4. 스프링 빈과 의존관계 (0) | 2023.09.21 |
[스프링 입문 - 코드로 배우는 스프링 부트, 웹 MVC, DB 접근 기술] 3. 회원 관리 예제 - 백엔드 개발 (0) | 2023.09.21 |
[스프링 입문 - 코드로 배우는 스프링 부트, 웹 MVC, DB 접근 기술] 2. 스프링 웹 개발 기초 (0) | 2023.09.21 |