仅使用部署版本的文件请求POST时出错:next.js +带多路复用器的MongoDB

3htmauhk  于 2023-03-02  发布在  Go
关注(0)|答案(1)|浏览(126)

早上好,我有一个问题,让我在总PLS,我找不到任何方法来解决它的任何地方,没有与谷歌搜索.和chatGPS告诉我配置我的数据库这样的SSL:1)登录您的MongoDB Atlas账户,然后导航到集群的“安全”页面。

  1. 2) Click on the "Add IP Address" button to add a new IP address to the authorized access list.
  2. 3) In the window that appears, select "Add current IP address" to add your current IP address to the authorized access list.
  3. 4) Select "Add another IP address" if you want to add a different IP address.
  4. 5) Check the "Enable Access from Anywhere" box to allow access to your cluster from any IP address.
  5. 6) Click on the "Add IP Address" button to add the new access rule to your cluster.
  6. 7) If your application uses an SSL connection to access the database, you must also add the SSL access rule. To do this, click the "Add CIDR" button and add your web server's IP address, followed by "/32" to specify a 32-bit subnet mask.
  7. 8) Check the "Require SSL" box to require all connections to your cluster to use SSL.
  8. 9) Click the "Save" button to save the changes.

但我的“添加IP地址”按钮只有字段“访问列表条目:“和“注解:“别的什么也没有,我不知道到哪儿去找它,我一定很傻,但它让我发疯。
这是我的API代码,GET可以工作,POST不行。

  1. import connectDb from '../../../data/db';
  2. import Student from '../../../models/Student';
  3. import { promises as fs } from 'fs';
  4. import path from 'path';
  5. const handler = async (req, res) => {
  6. const { studentId } = req.query;
  7. switch (req.method) {
  8. case 'GET':
  9. try {
  10. const student = await Student.findById(studentId);
  11. if (!student) {
  12. res.status(404).json({
  13. message: `Student with id ${studentId} not found`,
  14. });
  15. } else {
  16. res.status(200).json(student);
  17. }
  18. } catch (error) {
  19. res.status(500).json({ message: error.message });
  20. }
  21. break;
  22. case 'PUT':
  23. res.status(401).json({
  24. message: "You can't do it, delete and create a new student.",
  25. });
  26. break;
  27. case 'DELETE':
  28. try {
  29. const student = await Student.findByIdAndDelete(studentId);
  30. if (!student) {
  31. res.status(404).json({
  32. message: `Student with id ${studentId} not found`,
  33. });
  34. }
  35. const imgPath = path.join(process.cwd(), 'public', student.img);
  36. const cvPath = path.join(process.cwd(), 'public', student.cv);
  37. fs.unlink(imgPath);
  38. fs.unlink(cvPath);
  39. return res.status(200).json({
  40. message: `Student n°${studentId} as been deleted with succes.`,
  41. });
  42. } catch (error) {
  43. res.status(500).json({ message: error.message });
  44. }
  45. break;
  46. default:
  47. res.status(400).json({ message: 'Invalid request method' });
  48. break;
  49. }
  50. };
  51. export default connectDb(handler);

下面是我的表单的代码:

  1. import { useState } from 'react';
  2. import styles from './StudentForm.module.css';
  3. import 'formdata-polyfill';
  4. export default function StudentForm({ refresh, setIsForm }) {
  5. const [name, setName] = useState('');
  6. const [title, setTitle] = useState('');
  7. const [firstName, setFirstName] = useState('');
  8. const [img, setImg] = useState(null);
  9. const [cv, setCv] = useState(null);
  10. const [technologies, setTechnologies] = useState(['']);
  11. // fonction pour gérer la soumission du formulaire
  12. const handleSubmit = async (event) => {
  13. event.preventDefault();
  14. const formData = new FormData();
  15. formData.append('name', name);
  16. formData.append('title', title);
  17. formData.append('firstName', firstName);
  18. formData.append('img', img);
  19. formData.append('cv', cv);
  20. formData.append('technologies', JSON.stringify(technologies));
  21. try {
  22. const response = await fetch('/api/students', {
  23. method: 'POST',
  24. body: formData,
  25. });
  26. if (response.ok) {
  27. setName('');
  28. setTitle('');
  29. setFirstName('');
  30. setImg(null);
  31. setCv(null);
  32. setTechnologies(['']);
  33. refresh();
  34. setIsForm(false);
  35. event.target.reset();
  36. } else {
  37. console.error('Erreur lors de la création du student');
  38. }
  39. } catch (error) {
  40. console.error('Erreur lors de la création du student', error);
  41. }
  42. };
  43. const handleTechnologiesChange = (e, index) => {
  44. const newTechnologies = [...technologies];
  45. newTechnologies[index] = e.target.value;
  46. setTechnologies(newTechnologies);
  47. };
  48. const handleAddTechnologies = () => {
  49. setTechnologies([...technologies, '']);
  50. };
  51. return (
  52. <form className={styles.form_container} onSubmit={handleSubmit}>
  53. <div className={styles.form_field}>
  54. <label htmlFor="title" className={styles.label_form}>
  55. Titre :
  56. </label>
  57. <input
  58. className={styles.input_text}
  59. type="text"
  60. name="title"
  61. onChange={(e) => setTitle(e.target.value)}
  62. placeholder="Ex : Développeur C# full stack"
  63. required
  64. />
  65. </div>
  66. <div className={styles.form_field}>
  67. <label htmlFor="name" className={styles.label_form}>
  68. Nom :
  69. </label>
  70. <input
  71. className={styles.input_text}
  72. type="text"
  73. name="name"
  74. onChange={(e) => setName(e.target.value)}
  75. placeholder="Ex : DOH"
  76. required
  77. />
  78. </div>
  79. <div className={styles.form_field}>
  80. <label htmlFor="firstname" className={styles.label_form}>
  81. Prénom :
  82. </label>
  83. <input
  84. className={styles.input_text}
  85. type="text"
  86. name="firstname"
  87. onChange={(e) => setFirstName(e.target.value)}
  88. placeholder="Ex : John"
  89. required
  90. />
  91. </div>
  92. <div className={styles.form_field}>
  93. <label htmlFor="img" className={styles.label_form}>
  94. Image :
  95. </label>
  96. <input
  97. className={styles.input_file}
  98. type="file"
  99. name="img"
  100. onChange={(e) => setImg(e.target.files[0])}
  101. accept="image/*"
  102. required
  103. />
  104. </div>
  105. <div className={styles.form_field}>
  106. <label htmlFor="cv" className={styles.label_form}>
  107. CV :
  108. </label>
  109. <input
  110. className={styles.input_file}
  111. type="file"
  112. name="cv"
  113. onChange={(e) => setCv(e.target.files[0])}
  114. accept=".pdf"
  115. required
  116. />
  117. </div>
  118. <div className={styles.form_field}>
  119. <label htmlFor="technologies" className={styles.label_form}>
  120. Technologies:
  121. </label>
  122. {technologies.map((technology, index) => (
  123. <div key={index}>
  124. <input
  125. className={styles.input_text_techno}
  126. type="text"
  127. name="technologies"
  128. value={technology}
  129. placeholder="Ex : C#"
  130. onChange={(e) => handleTechnologiesChange(e, index)}
  131. />
  132. </div>
  133. ))}
  134. <div className={styles.btn_ajout_techno}>
  135. <svg
  136. className={styles.plus_svg}
  137. onClick={handleAddTechnologies}
  138. width="30"
  139. height="30"
  140. fill="none"
  141. stroke="currentColor"
  142. strokeLinecap="round"
  143. strokeLinejoin="round"
  144. strokeWidth="1.5"
  145. viewBox="0 0 24 24"
  146. xmlns="http://www.w3.org/2000/svg"
  147. >
  148. <path d="M12 5.75v12.5"></path>
  149. <path d="M18.25 12H5.75"></path>
  150. </svg>{' '}
  151. <span>{'← Ajouter une techno'}</span>
  152. </div>
  153. </div>
  154. <div className={styles.btn_container}>
  155. <button className={styles.btn_submit} type="submit">
  156. Envoyer
  157. </button>
  158. </div>
  159. </form>
  160. );
  161. }

我和bbd的关系:

  1. import mongoose from 'mongoose';
  2. import dotenv from 'dotenv';
  3. dotenv.config();
  4. const db_adress = process.env.REACT_APP_DB_ADDRESS;
  5. const connectDb = (handler) => async (req, res) => {
  6. if (mongoose.connections[0].readyState) {
  7. return handler(req, res);
  8. }
  9. await mongoose
  10. .connect(db_adress, {
  11. useNewUrlParser: true,
  12. useUnifiedTopology: true,
  13. })
  14. .then(() => console.log('Connexion à MongoDB réussie !'))
  15. .catch(() => console.log('Connexion à MongoDB échouée !'));
  16. return handler(req, res);
  17. };
  18. export default connectDb;

文件存储中间件的配置:

  1. import multer from 'multer';
  2. import path from 'path';
  3. import fs from 'fs';
  4. const storage = multer.diskStorage({
  5. destination: (req, file, cb) => {
  6. const dir = path.join(process.cwd(), 'public', 'documents');
  7. fs.mkdirSync(dir, { recursive: true });
  8. cb(null, dir);
  9. },
  10. filename: (req, file, cb) => {
  11. const uniqueSuffix = Date.now() + '-' + Math.round(Math.random() * 1e9);
  12. cb(
  13. null,
  14. `${file.fieldname}-${uniqueSuffix}${path.extname(
  15. file.originalname.replace(/ /g, '_')
  16. )}`
  17. );
  18. },
  19. });
  20. const upload = multer({
  21. storage: storage,
  22. fileFilter: (req, file, cb) => {
  23. const ext = path.extname(file.originalname);
  24. if (
  25. ext !== '.pdf' &&
  26. ext !== '.png' &&
  27. ext !== '.jpg' &&
  28. ext !== '.jpeg'
  29. ) {
  30. cb(new Error('File type is not supported.'), false);
  31. return;
  32. }
  33. cb(null, true);
  34. },
  35. });
  36. export default upload;

最后是我的学生:

  1. import mongoose from 'mongoose';
  2. const { Schema } = mongoose;
  3. const StudentSchema = new Schema({
  4. title: {
  5. type: String,
  6. required: true,
  7. },
  8. name: {
  9. type: String,
  10. required: true,
  11. },
  12. firstName: {
  13. type: String,
  14. required: true,
  15. },
  16. img: {
  17. type: String,
  18. required: true,
  19. },
  20. cv: {
  21. type: String,
  22. required: true,
  23. },
  24. technologies: {
  25. type: [String],
  26. required: true,
  27. },
  28. });
  29. const Student =
  30. mongoose.models.Student || mongoose.model('Student', StudentSchema);
  31. export default Student;

一切都在本地运行。在localhost中没有问题。
联机时GET方法可以工作,但post返回控制台。错误:“创建学生时出错”和响应json:代码:400 {error“上传文件时出错。"}
求你救我出去我一直在找你。

luaexgnf

luaexgnf1#

伙计,你的POST在API中不工作?我不明白你的问题...但是,如果POST不工作,API中的方法在哪里?你没有在API中实现这个POST

相关问题