📌 김영한 선생님의 스프링 입문 강의 강의를 들으면서 공부한 내용을 정리한 게시물입니다.
이전까지는 localhost:8080
으로 접속했을 때 staic/index.html
을 띄웠었는데,
오늘은 홈 화면을 띄우는 컨트롤러를 만들어서 우리가 만든 홈 화면을 띄워보자.
🔗
static/index.html
파일은 여기 참고
main/java/hello.hellospring/controller/HomeController.java
@Controller
public class HomeController {
@GetMapping("/")
public String home() {
return "home";
}
}
@GetMapping
을 사용해서 "/" URL 입력 시 home
메소드를 호출한다.home
메소드는 home.html
파일을 찾아서 화면에 띄워준다.main/resources/templates/home.html
<!DOCTYPE html>
<html xmlns:th="http://www.thymeleaf.org">
<head>
<meta charset="UTF-8">
<title>Home</title>
</head>
<body>
<div class="container">
<h1>Hello Spring</h1>
<p>회원 기능</p>
<p>
<a href="/members/new">회원 가입</a>
<a href="/members">회원 목록</a>
</p>
</div>
</body>
</html>
Run
→ localhost:8080
으로 접속아직은 홈 화면만 뜨게 설정했기 때문에 회원 가입, 회원 등록을 클릭하면 에러가 발생한다.
⭐ 컨트롤러가 정적 파일보다 우선 순위가 높다!
그래서 클라이언트에서 요청이 오면 먼저 스프링 컨테이너 안에서 컨트롤러를 찾아보고, 컨트롤러가 없으면
static
폴더 안에서 관련 파일을 찾아본다!
main/java/hello.hellospring/controller/MemberController.java
@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";
}
}
createForm()
메소드는 url에서 /members/new
요청을 받으면 members/createMembersForm
화면으로 이동한다.main/resources/templates/members/createMemberForm.html
<!DOCTYPE HTML>
<html xmlns:th="http://www.thymeleaf.org">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<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>
</body>
</html>
Run
→ 홈 화면에서 회원가입
버튼을 클릭 → @GetMapping
을 통해 members/new
로 이동 →/members/createMemberForm
화면이 나타난다.main/java/hello.hellospring/controller/MemberForm.java
public class MemberForm {
private String name;
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
}
main/java/hello.hellospring/MemberController.java
@Controller
public class MemberController {
...
@PostMapping(value="/members/new")
public String create(MemberForm form) {
Member member = new Member();
member.setName(form.getName());
memberService.join(member);
return "redirect:/";
}
}
Run
→ 회원가입
버튼 클릭 → 이름 입력 후 등록
버튼 클릭 → 홈 화면으로 redirect
이제 회원 목록
버튼을 클릭했을 때 현재 가입되어 있는 회원들을 조회하는 기능을 구현해보자.
main/java/hello.hellospring/controller/MemberController.java
@Controller
public class MemberController {
...
@GetMapping(value = "/members")
public String list(Model model) {
List<Member> members = memberService.findMembers();
model.addAttribute("members", members);
return "members/memberList";
}
}
main/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>
</body>
</html>
Run
→ 이름 입력하여 회원 등록 → 회원 목록
으로 들어가보면 회원 목록이 나타난다.
⭐ 서버를 껐다 키면 이 데이터가 사라진다. 그래서 따로 파일이나 데이터베이스에 저장을 해주어야 한다.
오늘은 홈 화면을 추가하고 회원 등록/조회하는 기능을 구현해보았다!