mongodb 当我尝试发布新产品从本地主机得到错误消息

2ic8powd  于 2022-11-22  发布在  Go
关注(0)|答案(1)|浏览(123)

这是我的后API工作问候 Postman

router.post(`/`,  uploadOptions.single('image'), async (req, res) =>{
    const category = await Category.findById(req.body.category);
    if(!category) return res.status(400).send('Invalid Category')

    const file = req.file;
    if(!file) return res.status(400).send('No image in the request')
    const fileName = req.file.filename
    const basePath = `${req.protocol}://${req.get('host')}/public/uploads/`;

    let product = new Product({
        name: req.body.name,
        description: req.body.description,
        richDescription: req.body.richDescription,
        image: `${basePath}${fileName}`,
        brand: req.body.brand,
        price: req.body.price,
        category: req.body.category,
        countInStock: req.body.countInStock,
        rating: req.body.rating,
        numReviews: req.body.numReviews,
        isFeatured: req.body.isFeatured,
    })

    product = await product.save();
    
    if(!product)
    return res.status(500).send('The product cannont be created')
    res.send(product);
})

这是我的表格

<div class="container">
  <div class="fadein">
    <h2 class="page-header">add new product </h2>
    <!-- <div class="alert alert-danger" *ngIf="" role="alert"></div> -->
    <form #addProductForm="ngForm" (ngSubmit)="SubmitData(addProductForm)">
      <div class="form-group">
          <label for="name">Name
              <sup class="red">*</sup>
          </label>
          <input required name="name" id="name" #name="ngModel" ngModel type="text" class="form-control">
      </div>
        <div class="form-group">
            <label for="description">description
                <sup class="red">*</sup>
            </label>
            <input required name="description" id="description" #description="ngModel" ngModel type="text" class="form-control">
        </div>
        <div class="form-group">
          <label for="richDescription">richDescription
              <sup class="red">*</sup>
          </label>
          <input required name="richDescription" id="richDescription" #richDescription="ngModel" ngModel type="text" class="form-control">
      </div>
      <div class="form-group">
        <label for="brand">brand
            <sup class="red">*</sup>
        </label>
        <input required name="brand" id="brand" #brand="ngModel" ngModel type="text" class="form-control">
    </div>
    <div class="form-group">
      <label for="price">price
          <sup class="red">*</sup>
      </label>
      <input required name="price" id="price" #price="ngModel" ngModel type="number" class="form-control">
  </div>
  <div class="form-group">
    <label for="category">category
        <sup class="red">*</sup>
    </label>
    <input required name="category" id="category" #category="ngModel" ngModel type="text" class="form-control">
</div>
<div class="form-group">
  <label for="countInStock">countInStock
      <sup class="red">*</sup>
  </label>
  <input required name="countInStock" id="countInStock" #countInStock="ngModel" ngModel type="number" class="form-control">
</div>
<div class="form-group">
  <label for="image">image
      <sup class="red">*</sup>
  </label>
  <input required  type="file" name="file" #file="ngModel" [ngModel]  accept="image/*">

</div>
        <br>
        <input type="submit" class="btn btn-primary" value="Add Product" [disabled]="!addProductForm.valid">
    </form>
  </div>
</div>

且这来自组件

SubmitData(form: { value:  {
    category: string; name: string; description: string;  brand: string;  richDescription: string;
    price: number; countInStock: number; image: File;
}; }){
    const data = {
      name: form.value.name,
      description: form.value.description,
      richDescription: form.value.richDescription,
      brand: form.value.brand,
      price: form.value.price,
      category: form.value.category,
      countInStock: form.value.countInStock,
      image: form.value.image,
    };

    this.productService.postData(data).subscribe(response => {

      console.log(response);

      });
}

产品服务

import { HttpClient, HttpHeaders , HttpEvent} from "@angular/common/http";
import { Injectable } from '@angular/core';
import { Product } from "../models/Product";
import { map, Observable, switchMap, tap } from "rxjs";

@Injectable({
  providedIn: 'root'
})

export class ProductService {
  // jsonURL = 'assets/data.json';
  warehouseURL = 'http://localhost:5000/v1/products/';


  constructor(private http: HttpClient) { }

  getProducts(): Observable<Product[]> {
    return this.http.get<Product[]>(this.warehouseURL)
      .pipe(
        tap(data => console.log('All: ', JSON.stringify(data))),
      );
  }
  getProduct(_id: string): Observable<Product | any> {
    return this.getProducts()
      .pipe(
        map((products: Product[]) => products.find(p => p._id === _id)
        )
      )
  }

  RemoveProduct(_id: string){
    this.http.delete<Product[]>(this.warehouseURL+ _id)
    .subscribe(()=>{
    })
  }
  postData(data: any): Observable<any>{
    return this.http.post(`${this.warehouseURL}`, data)
    .pipe(
      tap(data => console.log('All: ', JSON.stringify(data))),
    );
  }

}

当我尝试使用 Postman 后,它的工作很好,但我不能从应用程序后的数据,它自己,并产生一个错误消息“400没有图像的请求”。2所以你们能告诉我我的错误是什么吗?3非常感谢!

r6l8ljro

r6l8ljro1#

将图像输入标记的name属性更改为image,而不是file,并且还需要添加文件侦听器,并在提交时将其包含到表单中:

<input type="file" name="image" #image="ngModel" [ngModel] accept="image/*" (change)="onFileChange($event)">

此外,您需要准备form-data并发送它而不是对象。

// file holder
image?: File | any;

// file listener
onFileChange(event: any) {
if (event.target.files.length > 0) {
  const file = event.target.files[0];
  this.image = file
}
}

SubmitData中的构造形式:

const data = new FormData();

    data.append('name', form.value.name);
    data.append('description', form.value.description);
    data.append('richDescription', form.value.richDescription);
    data.append('brand', form.value.brand);
    data.append('price', form.value.price);
    data.append('category', form.value.category);
    data.append('countInStock', form.value.countInStock);
    data.append('image', this.image);

相关问题