'Java > Spring Boot' 카테고리의 다른 글
구글 Oauth2 access token 발급 (0) | 2024.06.18 |
---|---|
Lombok | @Builder 동작 원리 (0) | 2023.09.21 |
[API 작성법] GET API 만드는 법 핵심 정리 (0) | 2023.09.14 |
구글 Oauth2 access token 발급 (0) | 2024.06.18 |
---|---|
Lombok | @Builder 동작 원리 (0) | 2023.09.21 |
[API 작성법] GET API 만드는 법 핵심 정리 (0) | 2023.09.14 |
어디서든 값을 변경 할 수 있는 setter 대신에 빌더 메서드를 사용하는 것을 지향한다.
빌더 메서드를 사용하기 위해서는 빌더 클래스를 직접 생성해도 되지만
Lombok에서 제공해주는 @Builder 어노테이션으로 간단하게 생성 할 수 있다.
@Builder 어노테이션은 클래스 단에 붙여도 되지만 그보다는 생성자 메서드 단에 붙이는 것이 더 좋다.
그 이유는 설명을 너무 잘 해둔 블로그가 있어 소개하겠다.
https://velog.io/@park2348190/Lombok-Builder%EC%9D%98-%EB%8F%99%EC%9E%91-%EC%9B%90%EB%A6%AC
클래스 레벨에서는 가능한 모든 필드에 대하여 빌더 메서드를 생성했다면 생성자 레벨에서는 생성자의 파라미터 필드에 대해서만 빌더 메서드를 생성한다는 점이 차이가 있다.
클래스 레벨과 달리 생성자를 직접 생성해서 @Builder 를 적용하면 빌더로 설정하도록 제공하는 항목 역시 직접 고를 수 있다는 장점이 있다. 특히 JPA 엔티티 같은 경우 영속되기 전에는 식별자가 존재하지 않아 필연적으로 null 값을 가져야 한다. 이런 경우 생성자로 null 값을 전달하기보다는 아예 생성자에서 null 값을 받지 않도록 직접 구성하는 편이 좋다.
구글 Oauth2 access token 발급 (0) | 2024.06.18 |
---|---|
[Thymeleaf] 문법 (0) | 2023.09.21 |
[API 작성법] GET API 만드는 법 핵심 정리 (0) | 2023.09.14 |
Thymeleaf를 이용해 view를 구현하고 있는데 th:object에 객체가 담기지 않는 오류가 발생했다.
컨트롤러에서 메서드를 어떻게 만져도 해결되지 않았다.
상단의 타임리프 라이브러리 추가하는 부분에 www.를 제거하면 된다.
<html xmlns:th="http://www.thymeleaf.org">
<html xmlns:th="http://thymeleaf.org">
말끔히 해결..ㅎ
코드 오류가 아닌 라이브러리 주소 참조 오류였다..
이렇게 배우는 것 없는 오류 잡는게 제일 허무한 것 같다.
그래도 이런 라이브러리 참조에서도 오류가 날 수 있다는 점을 깨달았다.
다음에 같은 오류를 만나게 되면 더 빨리 오류를 해결할 수 있을 것 같다!
4~5시간은 이 오류를 해결하는데 시간 투자를 한거 같다.. 아무튼 오류 잡았으니 해^ㅡㅡ^피!
출처 : https://stackoverflow.com/questions/38710585/spring-boot-thymeleaf-in-intellij-cannot-resolve-vars
3가지 코드로 해결했다.
npm uninstall -g create-react-app
npm add create-react-app
npx create-react-app [프로젝트명]
설치 후
Happy hacking!
이렇게 뜨면 해결 완료!
출처
- 데이터의 복사본을 저장하여 이후 요청 시 데이터 접근 속도를 높이는 메커니즘
서버가 클라이언트의 브라우저에 저장할 수 있는 작은 데이터 조각
- 클라이언트가 서버에 요청을 보낼 때, 서버는 캐시된 데이터를 반환 할 수있음
- 클라이언트는 캐시에서 데이터를 찾을 수 있음
- 사용자의 브라우저에 저장이 되고 통신 할 때 HTTP 헤더에 포함되는 데이터 파일
= 웹 서버가 클라이언트의 브라우저에 저장할 수 있는 작은 데이터 조각
- 키와 값으로 구성
- 만료일을 설정할 수 있으며, 만료일이 지나면 브라우저가 쿠키를 삭제
- 브라우저를 닫아도 유지됨(-> 서버가 아닌 브라우저가 발급하는 거니까 브라우저는 여전히 정보를 알고 있음)
- 특정 경로와 도메인에만 유효함. 쿠키의 범위를 제한 할 수 있음
- 주로 자동 로그인 유지, 위시 리스트 저장, 팝업창 보지 않기, 뷰 설정값에 사용
브라우저에 저장되므로 해당 사용자의 컴퓨터를 사용하면 누구나 쿠키에 입력된 값을 쉽게 확인 가능 ==> 보안성이 낮다!
- 클라이언트와 서버 간의 상태를 유지하기 위해 서버에서 관리하는 메커니즘
클라이언트가 서버에 접속 시, 세션 ID를 발급해주고 서버에서는 클라이언트에게 발급해준 세션 ID를 이용해서 저장
= 서버에 저장되는 쿠키로 클라이언트와 서버의 통신 상태
- 서버가 발급하고 내용을 다 들고 있는 것이 아니라 자기가 발급해준 JsessionID로만 비교함
- 일반적으로 브라우저가 열려 있는 동안 또는 세션이 만료될 때까지 유지됨(-> 서버 측에서 세션 만료 시간을 설정할 수 있음)
- 주로 중요한 데이터를 저장 할 때 사용
사용자의 로컬이 아닌 서버에 직접 저장되므로 클라이언트 측에서 세션 내의 데이터에 접근하기 어려움 ==> 비교적 보안성이 높다!
[작동 방식]
클라이언트가 서버에 요청을 보낼 때, 서버는 세션을 생성하고 세션 ID를 클라이언트에 쿠키로 보내줍니다.
클라이언트는 이후의 요청에서 이 세션 ID를 포함시키며, 서버는 이 ID를 통해 해당 세션의 데이터를 참조합니다.
토큰은 웹 애플리케이션 및 API에서 인증과 권한 부여를 처리하는 데 널리 사용되는 메커니즘입니다. 일반적으로 JSON 웹 토큰(JSON Web Token, JWT)과 같은 형태로 사용됩니다.
1. 토큰의 기본 개념
2. JSON 웹 토큰 (JWT)
3. 토큰의 작동 방식
4. 토큰의 장점
5. 보안 고려 사항
6. 토큰의 종류
토큰은 사용자 인증 및 권한 부여를 처리할 때 유용하며, 클라이언트와 서버 간의 효율적인 통신을 지원합니다.
URL에 대해 알아보자 (0) | 2023.05.06 |
---|---|
헷갈리기 쉬운 경로표기법 (0) | 2023.02.06 |
서버에서 URL을 통해 값을 가져올 때 사용하는 API이다.
@RequestMapping 어노테이션을 별다른 설정 없이 선언하게 되면 HTTP의 모든 요청을 다 받게 되므로
RequestMethod.GET으로 설정하여 요청 형식을 GET으로만 설정한다
스프링 4.3 버전 이후로는 새로 나온 다음의 어노테이션을 사용한다.
특별히 @RequestMapping을 활용해야 하는 내용이 아니라면 잘 사용하지 않는다.
@RequestMapping(value="/hello", method= RequestMethod.GET)
public String getHello(){
return "!Hello World!";
}
스프링 4.3 버전 이후부터만 사용 가능
별도의 매개변수가 없이 url로 값을 보내는 GET API를 구현하는 경우
ex) 맵핑된 해당 링크로 접근하면 값이나 view 이름을 반환해줄 때 등
@GetMapping(value="/name")
public String getName(){
return "Flature";
}
여기까지는 실무에서 잘 쓰이지 않는 방식
실무에서는 매개변수를 받지 않는 메서드
@RequestMapping 어노테이션을 별다른 설정 없이 선언하게 되면 HTTP의 모든 요청을 다 받게 되므로
RequestMethod.GET으로 설정하여 요청 형식을 GET으로만 설정한다
부족한 설명은 추후 추가 예정
참고 자료
[위키북스] 스프링 부트 핵심가이드
구글 Oauth2 access token 발급 (0) | 2024.06.18 |
---|---|
[Thymeleaf] 문법 (0) | 2023.09.21 |
Lombok | @Builder 동작 원리 (0) | 2023.09.21 |