我的 MERN 应用程序在部署到 heroku 时显示错误?

问题描述

尝试将我的应用程序部署到 heroku 时,构建成功,但后端路由 HLRoute 处理 dotenv 时出错,我不确定可能是什么问题?{{3} }

enter image description here

server.js



const express = require("express");
const cors = require('cors')
const app = express()

const path = require("path")
const mongoose = require('mongoose')
// const bodyParser = require("body-parser")


//MIDDLEWARE
app.use(cors())






// app.use(bodyParser.urlencoded({ extended: true }));

//App Routes files

const houseRouter = require('./Routes/HouseListing/HLRoute')
const houseFetchRoute = require('./Routes/HouseFetchRoutes/HouseFetch')





//App route
app.use(houseRouter)
app.use(houseFetchRoute)


if(process.env.NODE_ENV === "production") {
    app.use(express.static('client/build'))

    app.get("*",(req,res)=>{
        res.sendFile(path.join(__dirname,'client','build','index.html'))
    })
} else {
    app.get("/",res)=>{
        res.send("api running")
    })
}


//server entry point
const PORT = process.env.PORT || 5000;

app.listen(PORT,() =>{
    console.log(`Server is runnning on port: ${PORT}`)
})

HLRoute.js

// const express = require('express')
// const router = express.Router()
const router = require('express').Router();
const {House} = require('../../Models/House');
const Formidable = require('formidable');
const cloudinary = require('cloudinary').v2
const mongoose = require('mongoose');
// require("dotenv").config()
// const { request,response } = require('express');
const dotenv = require("dotenv");
dotenv.config();


//mongoDB and Cloudinary

const mongoURI = process.env.Mongo_URI;

cloudinary.config({
    cloud_name: process.env.CLOUD_NAME,api_key: process.env.API_KEY,api_secret: process.env.API_SECRET
})


mongoose.connect(mongoURI,{useNewUrlParser:true,useUnifiedTopology:true},(error)=>{
    if(error) {
        return console.log(error)
    }
    return console.log("database is connected")
})

router.post("/api/house-listing",async (request,response)=>{
    const form = new Formidable.IncomingForm();

    form.parse(request,(error,fields,files)=>{
        const {
            price,city,county,numOfbeds,numOfBaths,numOfGarages,isSaleOrRent,} = fields

        const { house_image } = files;

        console.log('Price: ',price)
        console.log('City: ',city)
        console.log('county: ',county)
        console.log('numOfGarages: ',numOfGarages)
        console.log('numOfbeds: ',numOfbeds)
        console.log('numOfBaths: ',numOfBaths)
        console.log('isSaleOrRent: ',isSaleOrRent)
        console.log('houseImage',house_image.path)

        cloudinary.uploader.upload( house_image.path,{folder:"/houseAgency/houses"},async(error,result)=>{
            if(error) {
                console.log(error)
            }
            const image_url = result.url;

            const newHouse = new House({
                house_location: {
                    
                    county: county,city: city,},house_details: {
                    price: price,numOfbeds: numOfbeds,numOfBaths: numOfBaths,numOfGarages: numOfGarages,isSaleOrRent: isSaleOrRent,house_image: image_url,}
            })
            const savedHouse = await newHouse.save();
            return response.status(200).json(savedHouse)
        })
    })
})



module.exports = router;

package.json

{
  "name": "real-estate-app","version": "1.0.0","description": "","main": "server.js","scripts": {
    "start": "node server.js","heroku-postbuild": "NPM_CONfig_PRODUCTION=false npm install --prefix client npm run build --prefix client","dev": "nodemon server.js"
  },"author": "","license": "ISC","dependencies": {
    "cloudinary": "^1.23.0","cors": "^2.8.5","express": "^4.17.1","formidable": "^1.2.2","mongoose": "^5.11.13","nodemailer": "^6.4.17","nodemon": "^2.0.7"
  },"devDependencies": {
    "dotenv": "^8.2.0"
  }
}

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...