본문 바로가기

정보

React v6 카드 목록 작성하기(4*4 상품 페이지 만들기, 쇼핑몰) 안녕하세요 인포돈 입니다. 최근에 변화된 React v6에 의거하여 작성되었습니다. 실행코드 ide는 vscode를 활용합니다! 리액트 이전에 html, css, js에 대한 기본 지식이 있어야 합니다. 4*4 상품 목록 카드 작성하기 저희가 일반적으로 카드 목록을 작성하게 되면, 아래 글과 같이 상품들이 나열되는 목록을 보여줘야 할 때가 있습니다. 이러한 목록을 만들어주는 방법을 소개해드리겠습니다! - HTML 기본적으로 저희는 아주 간단하게 코드를 작성하였습니다. 카드에 들어갈 내용은 이미지, 상품 제목, 상품 내용 요약, 가격, 상품 상세페이지 보러 가기 총 5가지의 정보를 담고 있는 카드를 만들어 보겠습니다. function App(){ return( 상품 목록 카드 작성하기 상품 제목 상품 내용.. 더보기
React v6 변화한 router 사용하기 (Link, Routes, Route 태그) 안녕하세요 인포돈 입니다. 최근에 변화된 React v6에 의거하여 작성되었습니다. 실행코드 ide는 vscode를 활용합니다! 리액트 이전에 html, css, js에 대한 기본 지식이 있어야 합니다. React Router란 웹 프런트엔드를 개발하다 보면 항상 document를 활용해 페이지를 넘겨주는 작업이 귀찮고, 사이트가 방대해질수록 점점 복잡한 구조 때문에 어려움을 겪기 일상입니다. 우리는 이러한 문제점을 보다 쉽게 해결하기 위해서 React에서 제공하는 Router를 사용하면 이러한 어려움을 해결할 수 있게 됩니다. 리액트에는 이러한 페이지 이동을 보다 쉽게 해주는 많은 라이브러리가 있지만, 대중적으로 가장 많이 사용하는 라이브러리가 바로 React Router입니다. 이러한 router는 .. 더보기
Linux / network - 리눅스기초를 활용한 데이터 통신 10(Select, fd_set, FD테이블) 안녕하세요 인포돈 입니다. 본 내용은 우분투를 기본으로 작성되었습니다. Cloud Computing을 활용하여 서버를 구축하였습니다. Select를 활용한 데이터 통합 후 통신 (클라이언트 3, 서버 1) 본 포스팅에서는 Select를 활용하여 3개의 클라이언트에서 들어온 단어를 " " 공백을 활용하여 구분하여 합치고, 정수의 경우 모두 합한 값을 한 줄로 표현하여 다시 클라이언트에 보내주는 프로그램을 목표로 합니다. 그러면 우리는 우선 select가 무엇인지에 대해서 알아야 합니다. - Select int select(in nfds, fd_set *readfds, fd_set *writefds, fd_set *exceptfds, struct timeval *timeout) ndfs : 감시할 파일의 개.. 더보기
Linux / network - 리눅스기초를 활용한 데이터 통신 9(멀티 쓰레드, Mutex, cond_wait, string회전) 안녕하세요 인포돈 입니다. 본 내용은 우분투를 기본으로 작성되었습니다. Cloud Computing을 활용하여 서버를 구축하였습니다. 스레드를 활용한 데이터 통신 (클라이언트 3, 서버 1) 본 포스팅에서는 이전에 프로세스들 간에 데이터를 통신하는 방법에 대해서 다뤄왔다. 그러나 현실적으로는 프로세스를 통해서 다루기보다는 한 프로세스에 여러 개의 스레드를 활용하는 방법이 더욱 대중적이다. 따라서 본 포스팅에서는 스레드를 활용하여 데이터를 통신하는 방법에 대해서 다뤄본다. (본격적인 내용에 앞서서 간단한 이론들을 살펴본다) - 스레드란 스레드를 학습해본 사람은 스레드는 프로세스 내에서 실제로 일을 하는 주체를 의미한다고 알고 있다. 그러나 처음 접해보는 사람은 이해하기가 힘들 수 있다. 따라서 쓰레드를 좀.. 더보기
Linux / network - 리눅스기초를 활용한 데이터 통신 8(sharedmemory, semaphore) 안녕하세요 인포돈 입니다. 본 내용은 우분투를 기본으로 작성되었습니다. Cloud Computing을 활용하여 서버를 구축하였습니다. 3개의 클라이언트 공유 메모리를 활용한 데이터 변환 본 포스팅의 목적은 3개의 클라이언트에서 받은 값들을 rotation 즉, 초당 회전을 시켜서 계속해서 클라이언트에 보내주는 프로그램을 작성해 보려 합니다. 이해가 어려우신 분들을 위해서 이번에는 실행화면을 먼저 띄어 드리겠습니다. 보시는 실행화면과 같이 앞의 string은 한 칸씩 옆으로 이동하고 뒤의 int는 1씩 증가하는 프로그램입니다. 본 프로그램은 pipe를 사용하기보다는 shared memory를 활용해서 사용하는 방법에 대해서 다루어 보겠습니다. - Shared Memory란? 한 프로세스에 해당하는 메모리는.. 더보기
Linux / network - 리눅스기초를 활용한 데이터 통신 7(fork, pipe) 안녕하세요 인포돈 입니다. 본 내용은 우분투를 기본으로 작성되었습니다. Cloud Computing을 활용하여 서버를 구축하였습니다. 3개의 클라이언트 fork를 활용한 데이터 통합 이전 포스팅까지 1개의 서버와 3개의 클라이언트가 연동되어 데이터를 통합하는 형식이었습니다. 그러나 이런 클라이언트가 만약 1억 개라면? 서버는 모든 클라이언트와 순서대로 데이터를 주고받아야 하기 때문에 처리 속도가 떨어질 수밖에 없습니다. 이러한 문제점을 해결하기 위해서 우리는 fork라는 기법을 사용하려 합니다. fork란? 프로세스를 복사하는 함수이다. fork는 기본적으로 복제가 되면 부모와 자식 프로세스가 생기게 된다. 이때 자식과 부모를 구분하기 위해서 pid를 할당해 주게 되는데 부모의 경우 무작위 양수를 할당하.. 더보기
Linux / network - 리눅스기초를 활용한 데이터 통신 6(서버, 클라이언트, 소켓통신, 데이터 합치기) 안녕하세요 인포돈입니다. 본 내용은 우분투를 기본으로 작성되었습니다. Cloud Computing을 활용하여 서버를 구축하였습니다. 3개의 클라이언트 데이터 최소, 최대, 평균값 통합하기 이번 코딩은 3개의 클라이언트에서 각 숫자 데이터를 보내오면 서버 측에서는 최댓값, 최솟값, 평균값을 통합하여 각 클라이언트에 보내줍니다. 이때 최대, 최소의 경우 어디 ip와 port에서 보내오는지 출력이 되게 합니다. 서버 코드 struct info{ char sin_addr[MAXBUF]; int sin_port; int value; }; struct mmv{ char max_addr[MAXBUF], min_addr[MAXBUF]; int max_port, min_port; int max, min; float av.. 더보기
Linux / network - 리눅스기초를 활용한 데이터 통신 5(서버, 클라이언트, 소켓통신, 데이터 합치기) 안녕하세요 인포돈입니다. 이번 포스팅부터 본격적인 리눅스 소켓 통신 코딩을 적어보겠습니다. 본 포스터에서는 기본적으로 널리 알려져 있는 기본 코드를 활용하여 클라이언트의 데이터를 서버에서 통합하여 각 클라이언트로 다시 보내주는 코드를 작성해보겠습니다. 본 내용은 우분투를 기본으로 작성되었습니다. Cloud Computing을 활용하여 서버를 구축하였습니다. 이번 코딩의 목적은 클라이언트 3개와 서버 1개로 구성하려 합니다. 여기서 각 클라이언트에서 어떠한 문장을 넘겨주면 서버 측에서는 3개의 문장을 공백으로 구분하여 3개의 클라이언트에 다시 뿌려주는 역할을 담당하게 됩니다. 클라이언트 측 코드는 사실 크게 손본 게 없으므로 마지막에 간단한 코드 리뷰만 남겨놓도록 하겠습니다. 서버 코드 및 설명 #incl.. 더보기