수정중

This commit is contained in:
root
2025-09-04 13:01:13 +09:00
parent 5762f80bcd
commit 840ce1d4ce
5 changed files with 60 additions and 39 deletions

View File

@@ -3,8 +3,8 @@ import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.reactive.function.client.WebClient; import org.springframework.web.reactive.function.client.WebClient;
import jakarta.servlet.http.HttpServletRequest; import jakarta.servlet.http.HttpServletRequest;
import site.ocr.prd.dto.LoginRequest; import site.ocr.prd.dto.LoginRequestDto;
import site.ocr.prd.dto.LoginResponse; import site.ocr.prd.dto.LoginResponseDto;
import site.ocr.prd.services.LoginService; import site.ocr.prd.services.LoginService;
import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.GetMapping;
@@ -16,27 +16,30 @@ import org.springframework.web.bind.annotation.RequestBody;
@RestController @RestController
public class LoginController { public class LoginController {
@GetMapping("login/oauth-kakao-token") //service 선언
public LoginResponse kakaoLoginRequest(HttpServletRequest query) { private LoginService loginService = new LoginService(WebClient.builder());
System.out.println("data ::: ");
String accessToken = query.getParameter("code"); @GetMapping("login/oauth-kakao-authorize") //kakao에서 get으로 요청 보냄
public void kakaoLoginRequestDto(HttpServletRequest request) {
String accessToken = request.getParameter("code");
System.out.println(accessToken); System.out.println(accessToken);
LoginRequest requestDTO = new LoginRequest(); LoginRequestDto requestDTO = new LoginRequestDto();
requestDTO.setGrantType("authorization_code"); requestDTO.setGrantType("authorization_code");
requestDTO.setClientId("a1d6afef2d4508a10a498b7069f67496"); requestDTO.setClientId("a1d6afef2d4508a10a498b7069f67496");
requestDTO.setRedirectUri("http://localhost:9001/login/oauth-kakao-response"); requestDTO.setRedirectUri("http://localhost:9001/login/oauth-kakao-authorize");
requestDTO.setCode(accessToken); requestDTO.setCode(accessToken);
LoginResponse response = new LoginService(WebClient.builder()).loginService(requestDTO);
return response; loginService.getToken(requestDTO);
} }
@PostMapping("login/oauth-kakao-response") @PostMapping("login/oauth-kakao-token")
public String kakaoLoginResponse( entity) { public String kakaoLoginResponseDto(@RequestBody LoginResponseDto response) {
//TODO: process POST request //TODO: process POST request
System.out.println("response :: "); System.out.println("response :: ");
System.out.println(entity); System.out.println(response.getAccessToken());
return entity; return response.getAccessToken();
} }

View File

@@ -1,5 +1,7 @@
package site.ocr.prd.dto; package site.ocr.prd.dto;
import com.fasterxml.jackson.annotation.JsonProperty;
import lombok.Getter; import lombok.Getter;
import lombok.Setter; import lombok.Setter;
import lombok.ToString; import lombok.ToString;
@@ -7,10 +9,13 @@ import lombok.ToString;
@ToString @ToString
@Getter @Getter
@Setter @Setter
public class LoginRequest { public class LoginRequestDto {
@JsonProperty("grant_type")
String grantType; //authorization_code String grantType; //authorization_code
@JsonProperty("client_id")
String clientId; // REST API String clientId; // REST API
@JsonProperty("redirect_uri")
String redirectUri; //인가코드가 리다이렉트된 uri String redirectUri; //인가코드가 리다이렉트된 uri
String code; //인가코드 요청으로 얻은 인가코드 String code; //인가코드 요청으로 얻은 인가코드
} }

View File

@@ -1,16 +0,0 @@
package site.ocr.prd.dto;
import lombok.Getter;
import lombok.Setter;
import lombok.ToString;
@ToString
@Getter
@Setter
public class LoginResponse {
String grantType; //authorization_code
String clientId; //앱 REST API 키
String redirectUri; //인가코드가 리다이렉트된 uri
String code; //인가코드 요청으로 얻은 인가코드
}

View File

@@ -0,0 +1,27 @@
package site.ocr.prd.dto;
import com.fasterxml.jackson.annotation.JsonProperty;
import lombok.Getter;
import lombok.Setter;
import lombok.ToString;
@ToString
@Getter
@Setter
public class LoginResponseDto {
@JsonProperty("token_type")
String tokenType; //토큰타입, bearer 고정
@JsonProperty("access_token")
String accessToken; //사용자 엑세스 토큰 값
@JsonProperty("id_token")
String idToken; //ID 토큰값, openID connect가 활성화된 경우만 발급
@JsonProperty("expires_in")
Integer expiresIn; //엑세스토큰과 id토큰의 만료시간(초))
@JsonProperty("refresh_token")
String refreshToken; //사용자 리프레시 토큰 값
@JsonProperty("refresh_token_expires_in")
Integer refreshTokenExpiresIn; //리프레시 토큰 만료 시간(초)
String scope; //인증된 사용자의 정보조회 범위, 여러개일 경우 공백으로 구분
}

View File

@@ -1,10 +1,11 @@
package site.ocr.prd.services; package site.ocr.prd.services;
import org.springframework.stereotype.Service; import org.springframework.stereotype.Service;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.reactive.function.client.WebClient; import org.springframework.web.reactive.function.client.WebClient;
import site.ocr.prd.dto.LoginRequest; import site.ocr.prd.dto.LoginRequestDto;
import site.ocr.prd.dto.LoginResponse; import site.ocr.prd.dto.LoginResponseDto;
@Service @Service
public class LoginService { public class LoginService {
@@ -15,17 +16,18 @@ public class LoginService {
this.webClient = builder.build(); this.webClient = builder.build();
} }
public LoginResponse loginService(LoginRequest request) { public String getToken(LoginRequestDto request) {
LoginResponse response = new LoginResponse(); System.out.println("요청 ::: " + request.toString());
System.out.println(request.toString()); String result = webClient.post()
response = webClient.post()
.uri("https://kauth.kakao.com/oauth/token/") .uri("https://kauth.kakao.com/oauth/token/")
.bodyValue(request) .bodyValue(request)
.retrieve() .retrieve()
.bodyToMono(LoginResponse.class) //.bodyToMono(LoginResponseDto.class)
.bodyToMono(String.class)
.block(); .block();
return response; System.out.println("성공여부 ::: " + result);
return result;
} }