एक्सप्रेस के साथ टाइप करें

वेब एप्लिकेशन बनाने के लिए एक्सप्रेस लोकप्रिय जावास्क्रिप्ट ढांचे में से एक है। आइए जानें कैसे इस्तेमाल करेंTypeORM इस अध्याय में व्यक्त रूपरेखा के साथ।

एक सरल अनुप्रयोग बनाना

TypeORM CLI एक पूर्ण कार्य एक्सप्रेस वेब एप्लिकेशन (रेस्टेबल एपीआई एप्लिकेशन) के साथ एकीकृत करने के लिए एक आसान विकल्प प्रदान करता है TypeORM। एप्लिकेशन बनाने के लिए CLI कमांड निम्नानुसार है -

cd /path/to/workspace typeorm init --express --name typeorm-express-sample --database mysql

ऊपर कमांड टाइपोर्म-एक्सप्रेस-सैंपल फ़ोल्डर के तहत एक नया वेब एप्लिकेशन बनाएगा। आवेदन की संरचना इस प्रकार है -

│ .gitignore 
│ ormconfig.json 
│ package.json 
│ README.md 
│ tsconfig.json 
│ └───src 
      │ index.ts 
      │ routes.ts 
      │ 
      ├───controller 
      │      UserController.ts 
      │ 
      ├───entity 
      │      User.ts 
      │ 
      └───migration

यहाँ,

जैसा कि हम जानते हैं, ormconfig.json है TypeORMविन्यास फाइल। कोड निम्नानुसार है,

{ 
   "type": "mysql", 
   "host": "localhost", 
   "port": 3306, 
   "username": "test", 
   "password": "test", 
   "database": "test", 
   "synchronize": true, 
   "logging": false, 
   "entities": [
      "src/entity/**/*.ts" 
   ], 
   "migrations": [ "src/migration/**/*.ts" 
   ], 
   "subscribers": [ "src/subscriber/**/*.ts" 
   ], 
   "cli": { 
      "entitiesDir": "src/entity", "migrationsDir": "src/migration", "subscribersDir": "src/subscriber" 
   } 
}

यहां, अपने स्थानीय डेटाबेस सेटिंग से मिलान करने के लिए डेटाबेस सेटिंग बदलें।

package.json फ़ाइल अनुप्रयोग का मुख्य विन्यास है।

tsconfig.json फ़ाइल में टाइपस्क्रिप्ट से संबंधित कॉन्फ़िगरेशन है।

entity फ़ोल्डर में है TypeORMमॉडल। एक डिफ़ॉल्ट उपयोगकर्ता मॉडल सीएलआई द्वारा बनाया जाएगा और यह इस प्रकार है -

import {Entity, PrimaryGeneratedColumn, Column} from "typeorm"; 

@Entity() 
export class User { 
   
   @PrimaryGeneratedColumn() 
   id: number; 
   
   @Column() 
   firstName: string; 
   
   @Column() 
   lastName: string; 
   
   @Column() 
   age: number; 
}

controllerफ़ोल्डर में एक्सप्रेस नियंत्रक होते हैं। CLI उपयोगकर्ता विवरण जोड़ने / सूची / हटाने के साथ एक डिफ़ॉल्ट उपयोगकर्ता एपीआई नियंत्रक बनाते हैं। कोड इस प्रकार है -

import {getRepository} from "typeorm"; import {NextFunction, Request, Response} from "express"; import {User} from "../entity/User"; 

export class UserController {

   private userRepository = getRepository(User); 
   
   async all(request: Request, response: Response, next: NextFunction) { 
      return this.userRepository.find(); 
   } 
   
   async one(request: Request, response: Response, next: NextFunction) { 
      return this.userRepository.findOne(request.params.id); 
   } 
   
   async save(request: Request, response: Response, next: NextFunction) { 
      return this.userRepository.save(request.body); 
   } 
   
   async remove(request: Request, response: Response, next: NextFunction) { 
      let userToRemove = await this.userRepository.findOne(request.params.id); 
      await this.userRepository.remove(userToRemove); 
   } 
}

यहाँ,

all डेटाबेस से सभी उपयोगकर्ताओं को लाने के लिए विधि का उपयोग किया जाता है।

one विधि का उपयोग डेटाबेस से एक उपयोगकर्ता को लाने के लिए किया जाता है user id

save डेटाबेस में उपयोगकर्ता की जानकारी को बचाने के लिए विधि का उपयोग किया जाता है।

delete विधि का उपयोग उपयोगकर्ता को डेटाबेस से हटाने के लिए किया जाता है user id

routes.ts फाइल यूजर यूजर मेथड के तरीके को उचित URL और कोड निम्नानुसार है -

import {UserController} from "./controller/UserController"; 

export const Routes = [{ 
      method: "get", 
      route: "/users", 
      controller: UserController, action: "all" 
   }, { 
      method: "get", 
      route: "/users/:id", controller: UserController, action: "one" 
   }, { 
      method: "post", 
      route: "/users", 
      controller: UserController, action: "save" 
   }, { 
      method: "delete", route: "/users/:id", controller: UserController,
      action: "remove" 
}];

यहाँ,

/ user url को यूजर कंट्रोलर को मैप किया जाता है। प्रत्येक क्रिया पोस्ट, विभिन्न तरीकों से मैप और डिलीट की जाती है।

आखिरकार, index.tsहमारा मुख्य वेब एप्लीकेशन एंट्री पॉइंट है। स्रोत कोड इस प्रकार है -

import "reflect-metadata"; 
import {createConnection} from "typeorm"; 
import * as express from "express"; import * as bodyParser from "body-parser"; 
import {Request, Response} from "express"; 
import {Routes} from "./routes"; import {User} from "./entity/User"; 

createConnection().then(async connection => { 

   // create express app const app = express(); app.use(bodyParser.json()); 

   // register express routes from defined application routes Routes.forEach(route => { 
      (app as any)[route.method](route.route, (req:   Request, res: Response, next: Function) => { 
         const result = (new (route.controller as any))[route.action](req, res, next); 
         if (result instanceof Promise) { 
            result.then(result => result !== null && result !== undefined ? res.send(result) : undefined); 
         } else if (result !== null && result !== undefined) { 
            .json(result); 
         } 
      }); 
   }); 
      
   // setup express app here 
   // ... 
      
   // start express server app.listen(3000); 
      
   // insert new users for test await connection.manager.save(connection.manager.create(User, { 
      firstName: "Timber",
      lastName: "Saw", 
      age: 27 
   }));
   await connection.manager.save(connection.manager.create(User, { 
      firstName: "Phantom", 
      lastName: "Assassin", 
      age: 24 
   })); 
      
   console.log("Express server has started on port 3000. Open http://localhost:3000/users to see results"); 
}).catch(error => console.log(error));

यहां, एप्लिकेशन मार्गों को कॉन्फ़िगर करता है, दो उपयोगकर्ताओं को सम्मिलित करता है और फिर पोर्ट 3000 पर वेब एप्लिकेशन शुरू करता है । हम इस एप्लिकेशन को एक्सेस कर सकते हैंhttp://localhost:3000

एप्लिकेशन को चलाने के लिए, नीचे दिए गए चरणों का पालन करें -

आइए नीचे दिए गए कमांड का उपयोग करके आवश्यक पैकेज स्थापित करें -

npm install

उत्पादन

npm notice created a lockfile as package-lock.json. You should commit this file. 
npm WARN [email protected] No repository field. 
npm WARN [email protected] No license field. 

added 176 packages from 472 contributors and audited 351 packages in 11.965s 

3 packages are looking for funding  run `npm fund` for details 

found 0 vulnerabilities

एप्लिकेशन शुरू करने के लिए नीचे दिया गया कमांड चलाएँ।

npm start

उत्पादन

> [email protected] start /path/to/workspace/typeorm-express-sample 
> ts-node src/index.ts 

Express server has started on port 3000. Open http://localhost:3000/users to see results

आइए नीचे दिए गए कर्ल कमांड का उपयोग करके अपने वेब एप्लिकेशन एपीआई तक पहुँचें -

curl http://localhost:3000/users

यहाँ,

curl कमांड प्रॉम्प्ट से वेब एप्लिकेशन को एक्सेस करने के लिए एक कमांड लाइन एप्लिकेशन है। यह सभी HTTP वर्ब्स जैसे गेट, पोस्ट, डिलीट, आदि को सपोर्ट करता है।

उत्पादन

[{"id":1,"firstName":"Timber","lastName":"Saw","age":27},{"id":2,"firstName":"Phantom","lastName":"Assassin","age":24}]

पहला रिकॉर्ड लाने के लिए, हम नीचे कमांड का उपयोग कर सकते हैं -

curl http://localhost:3000/users/1

उत्पादन

{"id":1,"firstName":"Timber","lastName":"Saw","age":27}

उपयोगकर्ता रिकॉर्ड को हटाने के लिए, हम नीचे कमांड का उपयोग कर सकते हैं -

curl -X DELETE http://localhost:3000/users/1

जैसा कि हमने इस अध्याय में देखा, TypeORM आसानी से एक्सप्रेस आवेदन में एकीकृत किया जा सकता है।