SPRING 입문 [ 코드로 배우는 스프링 부트 ]

[스프링 입문] 섹션 5.3 웹 MVC 개발 (회원 웹 기능 - 조회)

wlalsu_u 2023. 1. 10. 12:37

5.3.1  회원 웹 기능 - 등록 화면 작성

 

 

앞선 MemberController 에 다음과 같은 코드를 추가로 작성한다.

 

 

    @GetMapping("/members")
    public String list(Model model){
        List<Member> members = memberService.findMembers();
        model.addAttribute("members", members);
        return "members/memberList";
    }

 

 

@GetMapping("/members")

 

- http://localhost:8080/members 로 url에 직접 작성하면 get 방식으로 mapping

 

 

List<Member> members = memberService.findMembers()

 

- findMembers() 를 사용하여, 멤버를 모두 가져온다

 

- member를 List에 담는다.

 

 

model.addAttribute("members", members)

 

- member 전체를 model에 담아서 화면에 넘겨준다.

 

 

return "members/memberList"

 

- template 폴더의 memberList.html 로 연결된다.

 

 

 

 

 

다음으로, html 코드를 작성해보자.

 

src  >  main  >  resources  > template > 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>

 

 

th : each

 

- thymeleaf 템플릿 엔진 문법으로, 루프를 돌면서 로직을 실행

 

- 템플릿 엔진이 model 로 넘겨받은 members 를 읽고, 소스코드를 새롭게 랜더링함

 

 

 

${members} / ${member.id} / ${member.name}

 

- ${ } 를 사용하면, 앞서 model 안에 넣은 값을 꺼낼 수 있음.

 

- 첫번째 객체를 members 에서 꺼낸 후, id 와 name 출력.

   계속 루프를 돌면서 로직을 반복 수행

 

 

 

 


 

 

MemberController.java 의 전체 코드는 다음과 같다.

 

 

 

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;

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


    @GetMapping("/members")
    public String list(Model model){
        List<Member> members = memberService.findMembers();
        model.addAttribute("members", members);
        return "members/memberList";
    }

}

 

 

 

 

+ 추가 )
위의 코드에서, 회원가입 시 저장된 정보는 메모리 안에 있으므로,
서버를 내렸다가 다시 켜면 데이터가 모두 지워짐

데이터를 파일이나 데이터베이스에 저장하는 방법이 필요!

 

 

 

 

 

 

 

 

 

김영한 '스프링 입문 - 코드로 배우는 스프링 부트, 웹 MVC, DB 접근 기술' 강의를 기반으로 작성하였습니다.

https://www.inflearn.com/course/%EC%8A%A4%ED%94%84%EB%A7%81-%EC%9E%85%EB%AC%B8-%EC%8A%A4%ED%94%84%EB%A7%81%EB%B6%80%ED%8A%B8/dashboard