Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
Expand Up @@ -31,8 +31,9 @@ public BasicLoginController(AuthService authService) {
@GetMapping("/members/me/basic")
public ResponseEntity<MemberResponse> findMyInfo(HttpServletRequest request) {
// TODO: authorization 헤더의 Basic 값에 있는 email과 password 추출 (hint: authorizationExtractor 사용)
String email = "";
String password = "";
AuthInfo authInfo = authorizationExtractor.extract(request);
String email = authInfo.getEmail();
String password = authInfo.getPassword();

if (authService.checkInvalidLogin(email, password)) {
throw new AuthorizationException();
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,7 @@
import cholog.auth.dto.MemberResponse;
import jakarta.servlet.http.HttpServletRequest;
import jakarta.servlet.http.HttpSession;
import org.springframework.http.HttpRequest;
import org.springframework.http.ResponseEntity;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PostMapping;
Expand Down Expand Up @@ -35,15 +36,14 @@ public SessionLoginController(AuthService authService) {
*/
@PostMapping("/login/session")
public ResponseEntity<Void> sessionLogin(HttpServletRequest request, HttpSession session) {
// TODO: HttpRequest로 받은 email과 password 추출
String email = "";
String password = "";
String email = request.getParameter("email");
String password = request.getParameter("password");

if (authService.checkInvalidLogin(email, password)) {
throw new AuthorizationException();
}

// TODO: Session에 인증 정보 저장 (key: SESSION_KEY, value: email값)
session.setAttribute(SESSION_KEY, email);

return ResponseEntity.ok().build();
}
Expand All @@ -57,8 +57,7 @@ public ResponseEntity<Void> sessionLogin(HttpServletRequest request, HttpSession
*/
@GetMapping("/members/me/session")
public ResponseEntity<MemberResponse> findMyInfo(HttpSession session) {
// TODO: Session을 통해 인증 정보 조회 (key: SESSION_KEY)
String email = "";
String email = (String) session.getAttribute(SESSION_KEY);
MemberResponse member = authService.findMember(email);
return ResponseEntity.ok().body(member);
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -8,9 +8,7 @@
import cholog.auth.infrastructure.BearerAuthorizationExtractor;
import jakarta.servlet.http.HttpServletRequest;
import org.springframework.http.ResponseEntity;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.bind.annotation.*;

@RestController
public class TokenLoginController {
Expand All @@ -35,10 +33,10 @@ public TokenLoginController(AuthService authService) {
* }
*/
@PostMapping("/login/token")
public ResponseEntity<TokenResponse> tokenLogin() {
// TODO: email, password 정보를 가진 TokenRequest 값을 메서드 파라미터로 받아오기 (hint: @RequestBody)
TokenRequest tokenRequest = null;
TokenResponse tokenResponse = authService.createToken(tokenRequest);
public ResponseEntity<TokenResponse> tokenLogin(@RequestBody TokenRequest tokenRequest) {
TokenRequest tokenRequest1 = tokenRequest;

TokenResponse tokenResponse = authService.createToken(tokenRequest1);
return ResponseEntity.ok().body(tokenResponse);
}

Expand All @@ -51,8 +49,7 @@ public ResponseEntity<TokenResponse> tokenLogin() {
*/
@GetMapping("/members/me/token")
public ResponseEntity<MemberResponse> findMyInfo(HttpServletRequest request) {
// TODO: authorization 헤더의 Bearer 값을 추출 (hint: authorizationExtractor 사용)
String token = "";
String token = authorizationExtractor.extract(request);
MemberResponse member = authService.findMemberByToken(token);
return ResponseEntity.ok().body(member);
}
Expand Down
23 changes: 19 additions & 4 deletions spring-mvc-1/initial/src/main/java/cholog/MemberController.java
Original file line number Diff line number Diff line change
@@ -1,18 +1,33 @@
package cholog;

import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.ResponseBody;

@Controller
public class MemberController {

public String world() {
@GetMapping("/hello")
public String world(@RequestParam(name = "name", required = false) String name, Model model) {
// TODO: /hello 요청 시 resources/templates/static.html 페이지가 응답할 수 있도록 설정하세요.
// TODO: 쿼리 파라미터로 name 요청이 들어왔을 때 해당 값을 hello.html에서 사용할 수 있도록 하세요.
return null;
if (name == null){
// 쿼리 파라미터가 없는 경우
return "static";
} else {
// 쿼리 파라미터가 있는 경우.
model.addAttribute("name", name);
return "hello";
}


}

@GetMapping("/json")
@ResponseBody
public Person json() {
// TODO: /json 요청 시 {"name": "brown", "age": 20} 데이터를 응답할 수 있도록 설정하세요.
return null;
return new Person("brown", 20);
}
}
26 changes: 13 additions & 13 deletions spring-mvc-2/initial/src/main/java/cholog/MemberController.java
Original file line number Diff line number Diff line change
Expand Up @@ -5,12 +5,11 @@
import java.util.List;
import java.util.Objects;
import java.util.concurrent.atomic.AtomicLong;

import org.springframework.http.HttpStatus;
import org.springframework.http.ResponseEntity;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.DeleteMapping;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.PutMapping;
import org.springframework.web.bind.annotation.*;

@Controller
public class MemberController {
Expand All @@ -19,41 +18,42 @@ public class MemberController {
private final AtomicLong index = new AtomicLong(1);

@PostMapping("/members")
public ResponseEntity<Void> create() {
public ResponseEntity<Void> create(@RequestBody Member member) {
// TODO: member 정보를 받아서 생성한다.
Member newMember = Member.toEntity(null, index.getAndIncrement());
Member newMember = Member.toEntity(member, index.getAndIncrement());
members.add(newMember);
return ResponseEntity.created(URI.create("/members/" + newMember.getId())).build();
}

@GetMapping("/members")
public ResponseEntity<List<Member>> read() {
// TODO: 저장된 모든 member 정보를 반환한다.
return null;
return new ResponseEntity<>(members, HttpStatus.OK);
}

@PutMapping("/members/{id}")
public ResponseEntity<Void> update() {
public ResponseEntity<Void> update(@PathVariable Long id, @RequestBody Member newMember) {
// TODO: member의 수정 정보와 url 상의 id 정보를 받아 member 정보를 수정한다.
Member member = members.stream()
.filter(it -> Objects.equals(it.getId(), null))
.filter(it -> Objects.equals(it.getId(), id))
.findFirst()
.orElseThrow(RuntimeException::new);

member.update(null);
member.update(newMember);
//return new ResponseEntity<>(null, HttpStatus.NO_CONTENT); 이건 왜 안되는지?
return null;
}

@DeleteMapping("/members/{id}")
public ResponseEntity<Void> delete() {
public ResponseEntity<Void> delete(@PathVariable Long id) {
// TODO: url 상의 id 정보를 받아 member를 삭제한다.
Member member = members.stream()
.filter(it -> Objects.equals(it.getId(), null))
.filter(it -> Objects.equals(it.getId(), id))
.findFirst()
.orElseThrow(RuntimeException::new);

members.remove(member);

return null;
return new ResponseEntity<>(HttpStatus.NO_CONTENT);
}
}