이번 프로젝트에서는 Github, Google 을 이용한 로그인을 구현하였고, 어떤 방식으로 진행되었는지 적어보려고 한다. OAuth 2.0 Login 기존에 필자가 알고있는 OAuth 로그인 방식은 아래와 같다 Authorization code를 클라이언트 단으로 리다이렉션 후, 이를 서버에 요청한 뒤 응답으로 Access Tokend을 받는 방식이다. 위의 방식과는 다르게 백엔드 분께서, Spring Security를 사용해보고 싶다하셨고, 이를 사용할 경우 Authorization code를 서버 단으로 으로 리다이렉션 후 Access Token까지 발급한 뒤 이 Access Token을 클라이언트로 리다이렉션 하는 방식으로 진행된다고 말씀하셨다. 새롭게 알게된 방식으로 진행하니, 프론트 단에서는 ..
React-quill 내부의 이미지 사이즈를 조절하려고 quill-image-resize-module-ts을 install 후에 quill에 적용해주었다. quill-image-resize-module 을 설치했을 때는 타입 지정이 되어있지않아서 import에 오류가 발생하였다. 따라서 2시간정도를 구글링하면서 quill-image-resize-module-ts 을 설치하여 import 문제를 해결 할 수 있었다. import { ImageResize } from 'quill-image-resize-module-ts'; Quill.register('modules/ImageResize', ImageResize); .... const modules = useMemo(() => { return { // syn..
redux에서 react query로의 전환 이유 redux에서 비동기처리를 해주기 위해서는 redux-saga 같은 미들웨어를 사용하여 상태에 저장시켜야 한다. saga에서 api의 응답을 받고 redux에 저장하는 과정 속에서 api 상태에 따라 렌더링을 해야되는 상황이 발생한다. 이 때 isLoading, isSucess, isError 같이 상태를 별도로 지정해주고 이에 따라 렌더링을 해줄 수 있다. (이처럼 Redux에서 비동기 처리를 할때 api 응답상태를 별도로 만들어 주어야한다.) 반면 react-query에서는 이를 기본 옵션으로 제공하고 있다. 이외에도 Redux를 사용시 다른 saga에 dependency를 두는 saga가 무수히 늘어나게 된다면, 중간 api 에 문제가 생겨도 에러 ..
현재 구현한 react quill 내부에 사진을 넣은 후, 에디터 속 콘텐츠를 콘솔에 찍어보았다. 사진 하나를 넣었는데도 불구하고 너무 길어서 콘솔에 찍히지도 않고, 사진이 들어있을 경우에는 서버로 전송도 되지 않았다. 현재 파일을 추가하면, base64형식을 이미지의 src로 받기 때문에 위의 사진과 같이 방대한 양의 콘솔이 찍힌 것을 알고 있었다. 따라서 base64가 아닌 url로 바꾸어 보는 과정을 가지기로 하였다. 문제점 현재 작성된 API는 포트폴리오를 전송하거나, 수정할 때 에디터에 들어갈 이미지들을 파일형태로 전송하는 방식이었다. 하지만, 에디터를 사용할 경우에는 포트폴리오 전송, 수정 전 이미지의 src에 넣어줄 url을 받아와야 하였다. 포트폴리오 전송, 수정 전에 이미지의 url을 받..
로그인 기능을 구현하면서, isLogin, accessToken, refreshToken 을 전역상태로 관리해주기로 하였다. 로컬 스토리지를 이용하여서 관리를 하려고 하였지만, redux-persist가 로컬 스토리지에서 상태를 저장해주면서, 보안 측면에서 더 낫다고 하여서 redux-persist로 상태를 관리해주었다. 타입스크립트, redux-toolkit, redux-persist 등 사용해보지 못한 기술들을 접해보아서 정신이 없긴했다. store/slice/loginSlice.ts Login이라는 타입을 지정해 준뒤, 내부의 값까지 타입을 지정해주었다. 그 후 초기 상태를 지정해준 뒤, loginSlice를 생성해주었다. 생성된 loginSlice 안의 login, logout 이라는 reudce..
등장배경 기존 방식은 설정, 미들웨어 설치, 반복되는 코드, 불변성 유지의 어려움 기존의 리덕스는 하나의 거대한 store로 관리하는 데에 반해서 redux toolkit은 slice라 부르는 작은 store로 state 관리 가능 reduxtoolkit 은 createSlice를 통해서 작은 저장소를 만들고, reducers를 통해서 reducer를 정의 해준다. 위의 예시는 reduxtoolkit 사용방식과 redux 사용방식을 나타낸 것이다. 이 작은 Slice들을 모아서 사용할 경우에는 configureStore를 생성한다. 만약 counter의 state 사용할 경우 store에 저장된 counter의 value를 가져오면 된다. dispatch의 경우 자동으로 생성된 action creater..
포트폴리오 작성페이지에, 웹 에디터의 필요성을 느껴 react quill 라이브러리를 사용하였다. 툴바에 있는 여러 기능을 테스트 해보았는데, 몇몇 기능이 적용되지 않았다. 예시로 글자를 굵게하는 기능이 적용되지 않아서, 관련 요소를 확인해보았다. 분명 요소에는 넣어져있었는데, 스타일에 사용자 에이전트 스타일시트 라는 것이 내가 적용한 속성을 무시하였다. 왜 이런일이 발생하는지 궁금해서, 관련 내용을 찾아보았다. User agent stylesheet은, 사용자가 명시해두어야 할 속성을 override 해주지 않거나, 등으로 html 파일에서 html의 최신 버전을 알려주지 않아 브라우저가 임의로 설정해둔 것으로, 한마디로 각 브라우저마다 정해놓은 CSS의 기본 규칙이다. 따라서 의도치 않거나 설정해두지..
프로젝트 배포에 들어가기 전에, 최종테스트를 하며 질문의 view 숫자가 미친듯이 올라가는 것을 발견했다. API를 통해서 question의 정보를 받아올 때마다, 질문의 viewCount가 증가하는 구조인데 질문 수정, 타임라인 페이지를 이동한 때마다, API를 통해서 question의 정보를 받아오기 때문에 view의 속도가 빠르게 증가하였다. Question 페이지와 editQuestion, Timeline 페이지는 별개의 페이지이기 때문에, props로 정보를 전달하지 못하여 그냥 서버에서 정보를 받아오는 식으로 해결하였다. 서버의 정보를 받는대신, 기존의 방식을 활용하는 방법은 내 생각으로는 2가지가 있었다. 1. 전역 상태 관리 2. Link태그로 props 전달하기 1번의 방식을 사용하는 것..
Eslint를 설정한 뒤, 설정없이 사용하던 환경에 비해서 제약이 많이 생겼다. 예를 들어 buttton의 타입을 정하지 않으면 에러가 생기거나, 아래의 예시처럼 span 요소에 onClick 이벤트를 적용시키면 오류가 발생하였다. 찾아보니 이것은 eslint의 rule에 의한 에러여서 조건과 해결방법을 조사하였다. 아래는 eslint의 제약 조건과 해결 방법들이다. 비대화형 요소의 클릭 핸들러는 최소 하나의 키보드 리스너가 필요하다. 그 이유는 마우스를 사용할 수 없는 사람들이 키보드를 쓸 수 있게 함이다. onKeyUp, onKeyDown, onKeyPress 이벤트를 할당 해당 엘리먼트를 button으로 바꿈 모든 브라우저와 스크린리더들이 대화형 요소(interactive element)를 이용 가..
오늘은 기존 작성했던 UI에 간단한 기능들을 추가하였다. 현재로서는 아직 백엔드쪽 구축이 덜 되서 json-server를 이용하여 간단하게 글의 정보를 받아오는 정도만 구현했다. components/CommentBox 댓글을 작성하고 제출 시, 알림 버튼을 누르면 댓글이 작성되는 기능을 추가하였다. 댓글의 남은 글자 수도 하단에 위치해 두었다. // Comment 출력시 사용되는 컴포넌트 function CommentBox({ commentList }) { const [isWrite, setIsWrite] = useState(false); const [comments, setComments] = useState([]); const [newComment, setNewComment] = useState(''..
- Total
- Today
- Yesterday
- SEB43기
- 스택오버플로우
- 프론트엔드
- 회고
- 인적성
- React quill
- seb
- Redux
- 감정일기장
- Python
- 다이나믹 프로그래밍
- 백준
- 프리프로젝트
- dfs
- 그리디 알고리즘
- dictionary
- 감정 일기장
- 기술면접
- 코테
- 프로그래머스
- SEB43
- 프로젝트
- BFS
- SEB 43
- SEB 43기
- 코드스테이츠
- 개인 프로젝트
- 브루드포스
- useContext
- til
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |