我正在使用 NestJs 作為后端服務,我正在使用一些第三方 api 并希望將回應保存在 mongodb 中。我無法獲得如何在 mongodb 中保存資料,因為我有要保存的資料的 DTO 類。
下面是我的代碼:
app.module.ts
import { Module } from '@nestjs/common';
import { MongooseModule } from '@nestjs/mongoose';
import { AppController } from './app.controller';
import { AppService } from './app.service';
import { UserModule } from './user/user.module';
@Module({
imports: [UserModule,
MongooseModule.forRoot('mongodb://localhost/status')],
controllers: [AppController],
providers: [AppService],
})
export class AppModule {}
用戶模塊.ts
import { HttpModule } from '@nestjs/axios';
import { Module } from '@nestjs/common';
import { MongooseModule } from '@nestjs/mongoose';
import { ScheduleModule } from '@nestjs/schedule';
import { StatusSchema } from './schemas/status.schema';
import { UserController } from './user.controller';
import { UserService } from './user.service';
@Module({
imports:[HttpModule,
ScheduleModule.forRoot(),
MongooseModule.forFeature([{ name: 'Status', schema: StatusSchema }])],
controllers: [UserController],
providers: [UserService]
})
export class UserModule {}
狀態.schema.ts
import { Prop, Schema, SchemaFactory } from "@nestjs/mongoose";
import { Document } from "mongoose";
export type StatusDocument = Status & Document;
@Schema()
export class Status{
@Prop()
total:String;
}
export const StatusSchema = SchemaFactory.createForClass(Status);
狀態.dto.ts
export class StatusDto{
total:string;
}
用戶服務.ts
@Injectable()
export class UserService {
constructor(private httpService:HttpService,
private schedulerRegistry:SchedulerRegistry,
@InjectModel('Status') private readonly statusModel:Model<Status>){}
private readonly logger = new Logger(UserService.name);
async dynamicJob(){
this.logger.log("in main function");
const dat = await this.nameFun();
this.logger.warn(dat);
//Here I want to save the dat inside mongodb
}
nameFun = async () =>{
const url = 'https://reqres.in/api/unknown';
const result = await axios.get(url);
this.logger.log("In nameFun " result.data.total);
return result.data.total;
}
}
有人請讓我知道如何在上述函式的指定位置在 mongodb 中添加資料。
uj5u.com熱心網友回復:
這是一個帶有json 占位符資料的作業示例,我可以使用它進行測驗,因為我不知道您的回應是什么樣的。我只是將title回應欄位中的文本傳遞到total您的Status架構欄位中。
你的 2 個函式UserService看起來像這樣。
async dynamicJob() : Promise<Status> {
this.logger.log('in main function');
const dat = await this.nameFun();
this.logger.warn(dat);
const dto = { total: dat }; // creating dto in the form of your schema
this.logger.log(dto);
return await this.statusModel.create(dto); // saves and returns saved object
}
nameFun = async () => {
const url = 'https://jsonplaceholder.typicode.com/todos/2';
const result = await axios.get(url);
// you'll need to change this back to correct parsing of your actual response
this.logger.log('In nameFun ' result.data.title);
return result.data.title;
};
然后你的相應函式UserController看起來像這樣,無論你想使用什么端點。這里我只是使用from-api.
@Get('from-api')
async getFromApi() : Promise<Status> {
return this.userService.dynamicJob();
}
從此端點獲取請求
http://localhost:3000/user/from-api/
回傳 Mongo 中新創建的檔案
{
"total": "quis ut nam facilis et officia qui",
"_id": "622a1a6e990efa55c984dc4b",
"__v": 0
}
轉載請註明出處,本文鏈接:https://www.uj5u.com/qiye/443297.html
