클린건축이란? 이 글은 Clean Architecture를 안내하고 Node.js를 사용하여 Clean Architecture를 구현하는 방법에 대해 설명합니다. 도움이 되기를 바랍니다.
Clean Architecture
Clean Architecture는 Robert C. Martin이 제안한 소프트웨어 아키텍처 패턴입니다. 목적은 시스템을 계층화하고 관심사를 분리하여 시스템을 더 쉽게 이해하고 유지 관리하고 확장하는 것입니다. 이 아키텍처는 시스템을 내부에서 외부까지 엔터티 계층, 사용 사례 계층, 프레젠테이션 계층, 인프라(리포지토리, 프레임워크 등)의 네 가지 수준으로 나눕니다.
이 기사에서는 Node.js를 사용하여 Clean Architecture를 구현하는 방법을 소개하고 아키텍처의 주요 개념을 보여주는 몇 가지 샘플 코드를 제공합니다.
다음으로 TypeScript 프로젝트 예제(github.com/lulusir/cle…)를 사용하겠습니다. 이 프로젝트는 Monorepo 구조를 사용하며 Rush.js를 사용하여 관리됩니다. 서버 폴더에는 core, koa 및 Nestjs-app이라는 세 개의 하위 프로젝트가 포함되어 있습니다. Core는 핵심 비즈니스 로직이고, Koa는 기본 프레임워크 웹 프로젝트로 koa+prisma를 사용하며, Nestjs-app은 Nestjs + Typeorm의 프로젝트를 사용합니다. 기본 프레임워크. 목적은 동일한 비즈니스 논리가 어떻게 서로 다른 프레임워크를 연결할 수 있는지 보여주는 것입니다. [관련 튜토리얼 추천: nodejs 비디오 튜토리얼, 프로그래밍 교육]
이 프로젝트에서 엔터티 레이어에는 엔터티 객체와 관련 비즈니스 규칙 및 로직이 포함되어 있고, 유스 케이스 레이어에는 시스템의 유스 케이스와 비즈니스 로직이 포함되어 있습니다. 저장소 계층은 데이터를 저장하고 검색하는 역할을 담당하며 프레젠테이션 계층은 외부 http 인터페이스에 노출됩니다.
프로젝트 기능:
포스트 게시 및 열람 기능 구현
사용자 생성, 쿼리
포스트 게시, 편집, 쿼리, 삭제
프로젝트 구조
rreee-
core: core는 핵심 비즈니스 로직의 코드입니다.
- Domain: 비즈니스 관련 모델 등 엔터티 관련 코드를 저장합니다.
- Use Cases: 비즈니스 로직, 데이터 처리 등 비즈니스 로직 관련 코드를 저장합니다.
- Repository: 외부 저장소 시스템을 위한 저장소 및 관련 인터페이스
-
koa/nestjs-app: 코어의 실제 소비자
- 코어의 인터페이스에 따라 특정 라우터 및 저장소를 구현
프로젝트 기능
- DDD 및 Clean Architecture의 아이디어를 사용하여 프레임워크 구현에서 비즈니스 로직을 분리합니다.
- 모노레포 프로젝트 구조를 사용하여 여러 관련 프로젝트를 쉽게 관리하세요.
- 쉽고 빠르게 시작할 수 있도록 다양한 샘플 애플리케이션이 제공됩니다.
- TypeScript를 기반으로 코드 가독성과 유지 관리성이 향상되었습니다.
핵심에는 핵심 비즈니스 로직 코드가 있습니다. 이 수준에는 도메인, 저장소 인터페이스 및 사용 사례가 포함됩니다. 도메인에는 특정 비즈니스 모델과 같은 엔터티와 관련된 코드가 포함되어 있습니다. 저장소에는 외부 스토리지 시스템에 대한 관련 인터페이스가 포함되어 있습니다. 사용 사례에는 비즈니스 로직 처리, 데이터 유효성 검사, 리포지토리 호출 등 비즈니스 로직과 관련된 코드가 포함되어 있습니다.
koa/nestjs-app 레벨에서는 핵심 레벨에 실제 소비자가 있습니다. 이들은 코어 레이어에서 제공하는 인터페이스를 기반으로 특정 라우터와 리포지토리를 구현합니다. Clean Architecture를 사용하는 주요 이점 중 하나는 비즈니스 로직을 기술 구현과 분리한다는 것입니다. 이는 핵심 비즈니스 로직을 변경하지 않고도 다양한 프레임워크와 라이브러리 간에 쉽게 전환할 수 있음을 의미합니다. 이 예에서는 동일한 핵심 비즈니스 로직을 유지하면서 koa와 Nestjs-app 간에 전환할 수 있습니다.
코드 구현
엔티티 레이어 정의
├── server │ ├── core // 核心业务逻辑 │ │ └── src │ │ ├── domain │ │ ├── repository │ │ └── useCase │ ├── koa │ │ └── src │ │ ├── post │ │ └── user │ └── nestjs-app │ ├── src │ ├── post │ │ ├── dto │ │ └── entities │ └── user │ └── entities └── web
저장 인터페이스 정의
// server/core/src/domain/post.ts import { User } from "./user"; export class Post { author: User | null = null; content: string = ""; updateAt: Date = new Date(); // timestamp; createdAt: Date = new Date(); // timestamp; title: string = ""; id: number = -1; } // server/core/src/domain/user.ts export class User { name: string = '' email: string = '' id: number = -1 }
사용 사례 레이어 정의
import { Post } from "../domain/post"; export interface IPostRepository { create(post: Post): Promise<boolean>; find(id: number): Promise<Post>; update(post: Post): Promise<boolean>; delete(post: Post): Promise<boolean>; findMany(options: { authorId: number }): Promise<Post[]>; } ... import { User } from "../domain/user"; export interface IUserRepository { create(user: User): Promise<boolean>; find(id: number): Promise<User>; }
koa 프로젝트
구현됨 in koa 프로젝트 스토리지 레이어 인터페이스
import { User } from "../domain/user"; import { IUserRepository } from "../repository/user"; export class UCUser { constructor(public userRepo: IUserRepository) {} find(id: number) { return this.userRepo.find(id); } create(name: string, email: string) { if (email.includes("@test.com")) { const user = new User(); user.email = email; user.name = name; return this.userRepo.create(user); } throw Error("Please use legal email"); } }
koa 프로젝트에서 HTTP 라우팅(프레젠테이션 레이어) 구현하기
// server/koa/src/user/user.repo.ts import { PrismaClient } from "@prisma/client"; import { IUserRepository, User } from "core"; export class UserRepository implements IUserRepository { prisma = new PrismaClient(); async create(user: User): Promise<boolean> { const d = await this.prisma.user_orm_entity.create({ data: { email: user.email, name: user.name, }, }); return !!d; } async find(id: number): Promise<User> { const d = await this.prisma.user_orm_entity.findFirst({ where: { id: id, }, }); if (d) { const u = new User(); u.email = d?.email; u.id = d?.id; u.name = d?.name; return u; } throw Error("user id " + id + "not found"); } }
nest-js 프로젝트
nestjs 프로젝트 예시는 이 경로(github.com/lulusir/cle…게시하지 않겠습니다.) 여기 코드
마지막으로
실제 프로젝트에서는 핵심 비즈니스 로직을 별도의 웨어하우스(즉, 코어)에 두지 않을 것이라는 점에 유의하세요. 이는 단지 다른 프레임워크에서 동일한 비즈니스 로직을 사용하는 것을 보여주기 위한 것입니다
비즈니스를 배치하여 로직은 프레임워크와 분리되어 있으며 핵심 비즈니스 로직을 변경하지 않고도 다양한 프레임워크와 라이브러리 간에 쉽게 전환할 수 있습니다. 확장 가능하고 유지 관리 가능한 애플리케이션을 구축하려면 Clean Architecture를 고려해 볼 가치가 있습니다.
다른 프레임워크에 연결하는 방법을 보여주고 싶다면 댓글 영역에 올려주세요
프로젝트 주소 (github.com/lulusir/cle… 괜찮다고 생각하시면 별점을 주셔도 됩니다.) , 감사합니다
더 많은 노드 관련 지식을 얻으려면 nodejs 튜토리얼을 방문하세요!
위 내용은 클린 아키텍처란 무엇인가? Node로 어떻게 구현하나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

실제 세계에서 JavaScript의 응용 프로그램에는 서버 측 프로그래밍, 모바일 애플리케이션 개발 및 사물 인터넷 제어가 포함됩니다. 1. 서버 측 프로그래밍은 Node.js를 통해 실현되며 동시 요청 처리에 적합합니다. 2. 모바일 애플리케이션 개발은 재교육을 통해 수행되며 크로스 플랫폼 배포를 지원합니다. 3. Johnny-Five 라이브러리를 통한 IoT 장치 제어에 사용되며 하드웨어 상호 작용에 적합합니다.

일상적인 기술 도구를 사용하여 기능적 다중 테넌트 SaaS 응용 프로그램 (Edtech 앱)을 구축했으며 동일한 작업을 수행 할 수 있습니다. 먼저, 다중 테넌트 SaaS 응용 프로그램은 무엇입니까? 멀티 테넌트 SAAS 응용 프로그램은 노래에서 여러 고객에게 서비스를 제공 할 수 있습니다.

이 기사에서는 Contrim에 의해 확보 된 백엔드와의 프론트 엔드 통합을 보여 주며 Next.js를 사용하여 기능적인 Edtech SaaS 응용 프로그램을 구축합니다. Frontend는 UI 가시성을 제어하기 위해 사용자 권한을 가져오고 API가 역할 기반을 준수하도록합니다.

JavaScript는 현대 웹 개발의 핵심 언어이며 다양성과 유연성에 널리 사용됩니다. 1) 프론트 엔드 개발 : DOM 운영 및 최신 프레임 워크 (예 : React, Vue.js, Angular)를 통해 동적 웹 페이지 및 단일 페이지 응용 프로그램을 구축합니다. 2) 서버 측 개발 : Node.js는 비 차단 I/O 모델을 사용하여 높은 동시성 및 실시간 응용 프로그램을 처리합니다. 3) 모바일 및 데스크탑 애플리케이션 개발 : 크로스 플랫폼 개발은 개발 효율을 향상시키기 위해 반응 및 전자를 통해 실현됩니다.

JavaScript의 최신 트렌드에는 Typescript의 Rise, 현대 프레임 워크 및 라이브러리의 인기 및 WebAssembly의 적용이 포함됩니다. 향후 전망은보다 강력한 유형 시스템, 서버 측 JavaScript 개발, 인공 지능 및 기계 학습의 확장, IoT 및 Edge 컴퓨팅의 잠재력을 포함합니다.

JavaScript는 현대 웹 개발의 초석이며 주요 기능에는 이벤트 중심 프로그래밍, 동적 컨텐츠 생성 및 비동기 프로그래밍이 포함됩니다. 1) 이벤트 중심 프로그래밍을 사용하면 사용자 작업에 따라 웹 페이지가 동적으로 변경 될 수 있습니다. 2) 동적 컨텐츠 생성을 사용하면 조건에 따라 페이지 컨텐츠를 조정할 수 있습니다. 3) 비동기 프로그래밍은 사용자 인터페이스가 차단되지 않도록합니다. JavaScript는 웹 상호 작용, 단일 페이지 응용 프로그램 및 서버 측 개발에 널리 사용되며 사용자 경험 및 크로스 플랫폼 개발의 유연성을 크게 향상시킵니다.

Python은 데이터 과학 및 기계 학습에 더 적합한 반면 JavaScript는 프론트 엔드 및 풀 스택 개발에 더 적합합니다. 1. Python은 간결한 구문 및 풍부한 라이브러리 생태계로 유명하며 데이터 분석 및 웹 개발에 적합합니다. 2. JavaScript는 프론트 엔드 개발의 핵심입니다. Node.js는 서버 측 프로그래밍을 지원하며 풀 스택 개발에 적합합니다.

JavaScript는 이미 최신 브라우저에 내장되어 있기 때문에 설치가 필요하지 않습니다. 시작하려면 텍스트 편집기와 브라우저 만 있으면됩니다. 1) 브라우저 환경에서 태그를 통해 HTML 파일을 포함하여 실행하십시오. 2) Node.js 환경에서 Node.js를 다운로드하고 설치 한 후 명령 줄을 통해 JavaScript 파일을 실행하십시오.


핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

WebStorm Mac 버전
유용한 JavaScript 개발 도구

맨티스BT
Mantis는 제품 결함 추적을 돕기 위해 설계된 배포하기 쉬운 웹 기반 결함 추적 도구입니다. PHP, MySQL 및 웹 서버가 필요합니다. 데모 및 호스팅 서비스를 확인해 보세요.

SublimeText3 Linux 새 버전
SublimeText3 Linux 최신 버전

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기
