Quickstarters
CRUD Samples
Building a CRUD App with Inferno.js: A Comprehensive Walkthrough
41 분
개요 이 가이드는 inferno js를 사용하여 전체 기능을 갖춘 crud(생성, 읽기, 업데이트, 삭제) 애플리케이션을 구축하는 방법을 보여줍니다 효율적으로 정보를 조작하고 업데이트하는 crud 시스템을 개발하여 기본 데이터 작업을 처리하는 방법을 배우게 됩니다 우리의 백엔드 기반은 back4app에 의해 지원되며, 여기서 데이터 관리를 원활하게 하기 위해 basic crud app infernojs 라는 프로젝트를 설정합니다 먼저 back4app 프로젝트를 설정하고 클래스를 정의하여 확장 가능한 데이터베이스 스키마를 설계합니다 이 과정은 crud 작업을 위한 데이터 구조가 충분히 견고하도록 보장합니다 그 다음, 데이터 관리를 간단하게 해주는 코드 없는 드래그 앤 드롭 도구인 back4app 관리 인터페이스를 활용합니다 마지막으로, sdk(설정에 맞는 경우) 또는 api 호출을 통해 inferno js 프론트엔드를 back4app과 연결하며, 보안을 위해 엄격한 접근 제어를 적용합니다 이 튜토리얼이 끝나면 사용자 인증, 동적 데이터 처리 및 반응형 인터페이스를 갖춘 프로덕션 수준의 웹 애플리케이션을 갖게 됩니다 핵심 통찰 back4app에서 강력한 백엔드로 crud 기능을 마스터하세요 확장 가능한 데이터베이스 스키마를 설계하고 이를 inferno js 프론트엔드와 통합하는 방법을 이해하세요 생성, 읽기, 업데이트 및 삭제 작업을 손쉽게 실행할 수 있는 시각적 관리 도구를 탐색하세요 docker를 사용한 컨테이너화 등 배포 전략을 배우세요 요구 사항 back4app 계정과 새로 생성된 프로젝트입니다 안내가 필요하면 back4app 시작하기 https //www back4app com/docs/get started/new parse app 를 확인하세요 inferno js 개발 환경입니다 좋아하는 inferno 스타터나 보일러플레이트를 사용하세요 node js(버전 14 이상)가 설치되어 있는지 확인하세요 javascript, inferno js 및 rest api 원칙에 대한 기본 이해입니다 추가 세부정보는 inferno 문서 https //infernojs org/docs/introduction 를 참조하세요 시작하기 전에 다음 사항을 확인하세요 1단계 – 프로젝트 초기화 새로운 back4app 프로젝트 시작하기 back4app 계정에 로그인하세요 대시보드에서 “새 앱” 옵션을 선택하세요 프로젝트 이름을 지정하세요 basic crud app infernojs 그리고 화면의 지침에 따라 생성 완료하세요 새 프로젝트 만들기 생성 후, 프로젝트가 대시보드에 나타나며 앱을 위한 견고한 백엔드 플랫폼을 제공합니다 2단계 – 데이터베이스 스키마 작성하기 데이터 모델 정의하기 이 crud 애플리케이션을 위해 여러 클래스를 설정할 것입니다 아래는 crud 작업을 지원하도록 설정된 두 개의 필수 클래스 예시입니다 1\ 항목 클래스 필드 유형 세부사항 id 객체 id 자동 생성된 기본 키 제목 문자열 항목의 제목 설명 문자열 항목에 대한 간단한 설명 생성일 날짜 항목이 생성된 시간을 표시하는 타임스탬프 업데이트됨 날짜 가장 최근 업데이트의 타임스탬프 2\ 사용자 클래스 필드 유형 세부사항 id 객체 id 자동 생성된 기본 키 사용자 이름 문자열 사용자를 위한 고유 식별자 이메일 문자열 사용자의 고유 이메일 주소 비밀번호 해시 문자열 안전한 인증을 위한 암호화된 비밀번호 생성일 날짜 계정 생성 타임스탬프 업데이트됨 날짜 마지막 계정 업데이트의 타임스탬프 back4app 대시보드에서 "새 클래스"를 선택하고 필요한 열을 추가하여 이러한 클래스를 수동으로 생성합니다 새 클래스 만들기 각 필드는 데이터 유형을 선택하고, 이름을 제공하며, 기본값이나 요구 사항을 설정하여 정의할 수 있습니다 열 만들기 스키마 설정을 위한 back4app ai 어시스턴트 활용하기 back4app ai 어시스턴트는 설명을 기반으로 클래스를 자동 생성하여 스키마 생성을 간소화합니다 ai 어시스턴트 사용 방법 ai 어시스턴트에 접근하기 back4app 대시보드에 로그인하고 설정에서 ai 어시스턴트를 찾습니다 데이터 모델 상세 설명하기 필요한 클래스와 필드에 대한 포괄적인 설명을 입력합니다 검토 및 적용하기 어시스턴트가 클래스 정의를 제안합니다 이 설정을 확인하고 적용합니다 예시 프롬프트 create the following classes in my back4app app 1\) class items \ fields \ id objectid (auto generated) \ title string \ description string \ created at date (auto set) \ updated at date (auto update) 2\) class users \ fields \ id objectid (auto generated) \ username string (unique) \ email string (unique) \ password hash string \ created at date (auto set) \ updated at date (auto update) ai 어시스턴트를 사용하면 설정이 간소화되어 일관성과 효율성을 보장합니다 3단계 – 관리자 인터페이스 및 crud 기능 활성화 관리자 인터페이스 소개 back4app 관리자 인터페이스는 강력한 노코드 도구로, 백엔드를 관리하기 위한 드래그 앤 드롭 경험을 제공합니다 crud 작업을 손쉽게 실행할 수 있습니다 관리자 인터페이스 활성화 “더보기” 섹션으로 이동 당신의 back4app 대시보드에서 “관리자 앱” 클릭 그리고 “관리자 앱 활성화 ” 초기 관리자 사용자 생성으로 관리자 계정을 설정하세요 이 과정은 자동으로 역할과 필수 시스템 클래스를 구성합니다 관리자 앱 활성화 활성화 후, 데이터 관리를 위해 관리자 인터페이스에 로그인하세요 관리자 앱 대시보드 관리자 인터페이스를 통한 crud 수행 관리자 인터페이스 내에서 다음을 수행할 수 있습니다 항목 생성 클래스 내에서 “레코드 추가” 옵션을 사용하여 새 데이터를 삽입합니다 항목 읽기/수정 레코드를 클릭하여 세부 정보를 보거나 업데이트합니다 항목 제거 삭제 기능을 사용하여 원하지 않는 레코드를 삭제합니다 이 인터페이스는 모든 crud 작업을 단순화하여 사용성을 크게 향상시킵니다 4단계 – inferno js와 back4app 연결하기 관리자 인터페이스를 통해 백엔드를 구성했으므로 이제 inferno js 프론트엔드를 통합할 시간입니다 옵션 a parse sdk 활용하기 parse sdk 설치하기 npm install parse inferno 앱에서 parse 초기화하기 구성 파일을 생성하세요 (예 src/parseconfig js ) // src/parseconfig js import parse from 'parse'; // 여기에 back4app 자격 증명을 입력하세요 parse initialize('your application id', 'your javascript key'); parse serverurl = 'https //parseapi back4app com'; export default parse; inferno 컴포넌트에서 parse 구현하기 예를 들어, 항목을 검색하고 나열하는 컴포넌트를 만드세요 // src/components/itemslist js import { component } from 'inferno'; import parse from ' /parseconfig'; class itemslist extends component { constructor(props) { super(props); this state = { items \[] }; } componentdidmount() { this loaditems(); } async loaditems() { const items = parse object extend("items"); const query = new parse query(items); try { const results = await query find(); this setstate({ items results }); } catch (err) { console error("항목 로드 중 오류 ", err); } } render() { return ( \<div> \<h2>항목\</h2> \<ul> {this state items map(item => ( \<li key={item id}> {item get("title")} — {item get("description")} \</li> ))} \</ul> \</div> ); } } export default itemslist; 옵션 b rest 또는 graphql api 사용하기 parse sdk가 귀하의 시나리오에 적합하지 않은 경우, rest 또는 graphql을 통해 crud 작업을 실행할 수 있습니다 예를 들어, rest를 사용하여 항목을 검색하는 방법은 다음과 같습니다 // rest api call to retrieve items const fetchitems = async () => { try { const response = await fetch('https //parseapi back4app com/classes/items', { headers { 'x parse application id' 'your application id', 'x parse rest api key' 'your rest api key' } }); const data = await response json(); console log('items retrieved ', data results); } catch (err) { console error('error fetching items ', err); } }; fetchitems(); 필요에 따라 inferno 구성 요소 내에 이러한 api 호출을 포함하세요 5단계 – 백엔드 강화하기 액세스 제어 목록(acl) 구현하기 acl을 할당하여 데이터 보안을 보장하세요 예를 들어, 개인 항목을 생성하는 방법은 다음과 같습니다 async function createprivateitem(itemdata, owner) { const items = parse object extend('items'); const item = new items(); item set('title', itemdata title); item set('description', itemdata description); // set acl so only the owner has access const acl = new parse acl(owner); acl setpublicreadaccess(false); acl setpublicwriteaccess(false); item setacl(acl); try { const saveditem = await item save(); console log('private item created ', saveditem); } catch (err) { console error('error creating item ', err); } } 클래스 수준 권한(clp) 구성하기 back4app 대시보드 내에서 각 클래스의 clp를 조정하여 기본 액세스 정책을 시행하고, 권한이 있는 사용자만 민감한 데이터와 상호작용할 수 있도록 하세요 6단계 – 사용자 인증 관리하기 사용자 계정 설정하기 back4app은 인증 처리를 위해 사용자 클래스를(parse를 통해) 사용합니다 귀하의 inferno js 앱에서 아래와 같이 등록 및 로그인 기능을 구현하세요 // src/components/auth js import { component } from 'inferno'; import parse from ' /parseconfig'; export class signup extends component { constructor(props) { super(props); this state = { username '', password '', email '' }; } handlesignup = async (e) => { e preventdefault(); const user = new parse user(); user set('username', this state username); user set('password', this state password); user set('email', this state email); try { await user signup(); alert('registration successful!'); } catch (err) { alert('sign up error ' + err message); } }; render() { return ( \<form onsubmit={this handlesignup}> \<input type="text" placeholder="username" value={this state username} oninput={e => this setstate({ username e target value })} /> \<input type="password" placeholder="password" value={this state password} oninput={e => this setstate({ password e target value })} /> \<input type="email" placeholder="email" value={this state email} oninput={e => this setstate({ email e target value })} /> \<button type="submit">sign up\</button> \</form> ); } } 로그인 및 세션 관리에 대해서도 유사한 전략이 적용됩니다 소셜 인증, 이메일 확인 및 비밀번호 복구와 같은 추가 기능은 back4app 대시보드에서 설정할 수 있습니다 7단계 – inferno js 프론트엔드 배포 back4app의 웹 배포 옵션을 사용하면 github 리포지토리를 연결하여 inferno js 프론트엔드를 손쉽게 호스팅할 수 있습니다 7 1 프로덕션 빌드 터미널에서 프로젝트 디렉토리를 엽니다 프로덕션 빌드 명령을 실행합니다 npm run build 이 명령은 애플리케이션을 최적화된 정적 자산을 포함하는 build 폴더로 컴파일합니다 빌드 확인 build 폴더에 index html 파일과 기타 자산 폴더가 포함되어 있는지 확인합니다 7 2 코드 정리 및 업로드 귀하의 저장소에는 inferno js 프론트엔드의 전체 소스가 포함되어야 합니다 예시 디렉토리 구조 basic crud app infernojs frontend/ \| node modules/ \| public/ \| ` index html \| src/ \| | app js \| | parseconfig js \| ` components/ \| | itemslist js \| ` auth js \| package json ` readme md 샘플 파일 src/parseconfig js // src/parseconfig js import parse from 'parse'; // insert your back4app credentials here parse initialize('your application id', 'your javascript key'); parse serverurl = 'https //parseapi back4app com'; export default parse; src/app js // src/app js import { component } from 'inferno'; import parse from ' /parseconfig'; class app extends component { constructor(props) { super(props); this state = { items \[], newtitle "", newdescription "", editid null, edittitle "", editdescription "" }; } componentdidmount() { this loaditems(); } async loaditems() { const items = parse object extend("items"); const query = new parse query(items); try { const results = await query find(); this setstate({ items results }); } catch (err) { console error("error loading items ", err); } } handleadd = async () => { const items = parse object extend("items"); const item = new items(); item set("title", this state newtitle); item set("description", this state newdescription); try { await item save(); this setstate({ newtitle "", newdescription "" }); this loaditems(); } catch (err) { console error("error adding item ", err); } } handledelete = async (id) => { try { const item = await parse object createwithoutdata("items", id); await item destroy(); this loaditems(); } catch (err) { console error("error deleting item ", err); } } startedit = (item) => { this setstate({ editid item id, edittitle item get("title"), editdescription item get("description") }); } handleupdate = async () => { try { const items = parse object extend("items"); const item = new items(); item id = this state editid; item set("title", this state edittitle); item set("description", this state editdescription); await item save(); this setstate({ editid null, edittitle "", editdescription "" }); this loaditems(); } catch (err) { console error("error updating item ", err); } } render() { return ( \<div style={{ padding '2rem' }}> \<h1>items\</h1> \<div style={{ marginbottom '1rem' }}> \<h2>add new item\</h2> \<input type="text" placeholder="title" value={this state newtitle} oninput={e => this setstate({ newtitle e target value })} style={{ marginright '0 5rem' }} /> \<input type="text" placeholder="description" value={this state newdescription} oninput={e => this setstate({ newdescription e target value })} style={{ marginright '0 5rem' }} /> \<button onclick={this handleadd}>add item\</button> \</div> \<h2>items list\</h2> \<ul> {this state items map(item => ( \<li key={item id} style={{ marginbottom '1rem' }}> {this state editid === item id ? ( \<div> \<input type="text" value={this state edittitle} oninput={e => this setstate({ edittitle e target value })} style={{ marginright '0 5rem' }} /> \<input type="text" value={this state editdescription} oninput={e => this setstate({ editdescription e target value })} style={{ marginright '0 5rem' }} /> \<button onclick={this handleupdate}>save\</button> \<button onclick={() => this setstate({ editid null })} style={{ marginleft '0 5rem' }}> cancel \</button> \</div> ) ( \<div> \<strong>{item get("title")}\</strong> {item get("description")} \<button onclick={() => this startedit(item)} style={{ marginleft '1rem' }}> edit \</button> \<button onclick={() => this handledelete(item id)} style={{ marginleft '0 5rem' }}> delete \</button> \</div> )} \</li> ))} \</ul> \</div> ); } } export default app; 코드를 github에 푸시하기 git 초기화 프로젝트 폴더에서 git init 파일 스테이징 git add 변경 사항 커밋 git commit m "inferno js 프론트엔드 초기 커밋" github 리포지토리 생성 이름을 basic crud app infernojs frontend 으로 설정하세요 프로젝트 푸시 git remote add origin https //github com/your username/basic crud app infernojs frontend git git push u origin main 7 3 github와 back4app 웹 배포 연결하기 웹 배포로 이동하기 back4app에 로그인하고, 프로젝트( basic crud app infernojs )를 선택한 후 웹 배포 기능을 클릭합니다 github와 통합하기 프롬프트에 따라 github 계정을 연결하여 back4app이 귀하의 리포지토리에 접근할 수 있도록 합니다 리포지토리 및 브랜치 선택하기 리포지토리(예 basic crud app infernojs frontend )와 코드가 포함된 브랜치(일반적으로 main )를 선택합니다 7 4 배포 설정 추가 구성을 입력하세요 빌드 명령어 리포지토리에 미리 빌드된 build 폴더가 없으면 npm run build 와 같은 명령어를 지정하세요 back4app은 배포 중에 이를 실행합니다 출력 폴더 출력을 build 로 설정하여 back4app이 정적 파일이 어디에 있는지 알 수 있도록 하세요 환경 변수 구성 설정 내에 필요한 변수를 추가하세요 (예 api 키) 7 5 애플리케이션 도커화 컨테이너화를 선택하면, 다음과 유사한 dockerfile 을 리포지토리에 포함하세요 \# use an official node image for the build stage from node 16 alpine as build \# set the working directory workdir /app \# copy package files and install dependencies copy package json / run npm install \# copy remaining files and build the app copy run npm run build \# use nginx to serve the built app from nginx\ stable alpine copy from=build /app/build /usr/share/nginx/html expose 80 cmd \["nginx", " g", "daemon off;"] 이 방법을 선택하면 back4app에서 docker 배포를 선택하십시오 7 6 애플리케이션 시작하기 배포 클릭 모든 설정이 구성되면 배포 버튼을 누르십시오 빌드 보기 back4app이 코드를 가져오고, 프로젝트를 빌드하며, 컨테이너에 배포합니다 앱에 접근하기 배포 후 back4app은 inferno js 앱이 실시간으로 실행되는 url을 제공합니다 7 7 배포 확인하기 제공된 url 방문하기 브라우저에서 url을 엽니다 기능 테스트 앱이 로드되고, 모든 경로가 올바르게 작동하며, 자산(css, js, 이미지)이 예상대로 표시되는지 확인하십시오 문제 해결 개발자 도구를 사용하여 오류를 검사합니다 문제가 발생하면 back4app 로그를 확인하고 github 설정을 검증하십시오 8단계 – 마무리 및 향후 방향 축하합니다! inferno js와 back4app으로 완전한 crud 애플리케이션을 만들었습니다 프로젝트를 설정했습니다 basic crud app infernojs , 데이터 클래스를 설계하고 직관적인 관리 인터페이스를 사용하여 데이터 관리를 했습니다 이제 프론트엔드는 강력한 접근 제어로 연결되고 안전하게 보호됩니다 다음 단계 ui 개선 상세 보기, 검색 기능 및 실시간 알림으로 inferno js 앱을 확장하세요 기능 추가 추가 백엔드 기능(예 클라우드 코드) 구현, 타사 api 통합 또는 역할 기반 접근 도입을 고려하세요 더 탐색하기 back4app 문서 https //www back4app com/docs 및 성능 조정과 사용자 정의 통합을 위한 추가 튜토리얼을 살펴보세요 코딩을 즐기고 향후 프로젝트에 행운이 있기를 바랍니다!