본문 바로가기

💐 Dev. 채영47

Styled-components 태그에 속성 추가하는 법 매번 className으로 모달 관리하기 번거로울 때매번 className으로 모달 관리하기 번거로울 때는 Styled-components 태그에 속성을 추가할 수 있다. 단, 단순 string 타입으로 작성할 경우, 대문자로 작성이 안된다던지 string 값 작성이 안되는 에러가 발생함으로 html 태그에서 변수값으로 인식하지 못하게 하는 $문자를 입력해주면 에러없이 잘 속성으로 이용할 수 있다.예시 : 모달interface ModalProps { isOpen : boolean; onClose: ()=> void; onClick: ()=> void;}function Modal ({isOpen, onClose, onClick}:ModalProps) => { return ( .. 2024. 7. 10.
🎯 Trouble Shooting 컴포넌트 리턴 후 발생하는 렌더링 에러 페이지가 첫 렌더링 된 후에 새로고침을 하면 위와같은 에러가 발생하는 이슈가 생겼다.🚨 Rendered more hooks than during the previous render.채팅 페이지 정보를 가져오다 발생한 에러.페이지 렌더링 후 새로고침 시 바운더리 에러 발생.로직 순서는useParams를 통해 채팅방 정보를 가져온다.currentUser를 이용해 로그인한 유저의 정보를 가져온다.유저의 정보와 채팅방 정보가 없다면 그대로 return 한다.유저의 역할에 따라 이름, 채팅방 권한 상태를 관리한다.채팅방 페이지를 렌더링한다.에러가 발생한 지점은 if 조건문으로 리턴을 한 후, 아래 useState hook이 발생하여 일어난 에러다.☑️ 문제 코드const ChatRoomPage = ()=> {c.. 2024. 7. 1.
JWT JWT(JSON Web Token)와 같은 토큰은 자체 포함된 토큰(self-contained token)이다. 토큰 자체에 인증 및 인가 정보를 포함하고 있어서 별도의 서버 저장소를 참조하지 않고도 필요한 정보를 검증할 수 있다.JWT의 구조JWT는 세 부분으로 구성된 토큰이다.Header (헤더)Payload (페이로드)Signature (서명)세 부분은 각각 Base64Url로 인코딩되며, 마침내 점(.)으로 구분되어 하나의 문자열로 결합된다.1. Header (헤더)헤더는 토큰의 타입과 사용된 서명 알고리즘을 지정한다.{ "alg": "HS256", "typ": "JWT"}2. Payload (페이로드)페이로드는 클레임(claims)이라고 불리는 JSON 객체를 포함한다. 클레임은 토큰에 포함.. 2024. 5. 19.
HTTP 완벽 가이드 13, 14장을 읽고 토론해보자 다이제스트 인증이 기본인증보다 안전하다고 하지만 현대의 보안 표준과 비교해서 얼마나 안전한지다이제스트 인증이 기본 인증보다 더 안전하다고 간주되는 이유는 비밀번호를 직접 전송하지않고, 해시된 값을 이용해 인증을 수행하기 때문이다. 그러나 현대의 보안 표준과 비교할 때 다이제스트 인증의 안전성은 nonce 재사용 문제나 무차별 대입 공격 등으로 한계가 있다. 또한 암호화 해시 알고리즘이 취약하다면 보안에 문제가 발생할 수 있다.기술이 발전함에따라 현대의 보안 표준이 당연 다이제스트 인증보다 훨씬 높은 수준의 보안을 제공한다. 흔히들 알고 있는 TLS/SSL(HTTPS)와 OAuth, JWT와 같은 인증 메커니즘이 더 높은 수준의 보안을 제공한다.TLS/SSL전송 계층 보안 : HTTPS는 TLS/SSL 프.. 2024. 5. 19.
ubuntu 22.04.4 에서 node , npm 버전 20, 10버전으로 업그레이드하기 24년 4월 기준VM 에 curl 설치커멘드 라인 툴 설치sudo apt-get install -y curlapt 패키지로 업데이트 + node 설치아래 명령어 순서대로 입력sudo apt updatesudo apt install nodejsnodejs -v sudo apt install npmcurl 로 nvm 설치node 사이트# installs NVM (Node Version Manager)curl -o- https://raw.githubusercontent.com/nvm-sh/nvm/v0.39.7/install.sh | bash# download and install Node.jsnvm install 20# verifies the right Node.js version is in the envir.. 2024. 4. 29.
맥 터미널에서 code .입력해서 vscode 실행하기 1. VS Code 실행2. Command + Shift + p 눌러서 명령 팔레트(command palette)(=아래와 같은 창) 나오게하기command palette\는 사용자 설정 할 수 있는 곳3. command palette에 shell 입력하기4. enter~~ 누르기end. 설정 완료! 2024. 4. 25.