heroku 错误[错误_不支持的目录导入]:尝试在本地启动Nodejs应用程序时导入目录

slhcrj9b  于 2022-11-13  发布在  其他
关注(0)|答案(5)|浏览(219)

I'm caught in a bit of a loop trying to deploy my app to Heroku. My import statements (e.g. import cors from 'cors' ) seem to prevent the app from launching in production, due to the "Cannot Load ES6 Modules in Common JS" error. Locally it runs just fine.
However, when I attempt to resolve the above error by adding "type": "module" to my package.json I get a whole new set of errors and the app will no longer run locally. I believe this error is due to the way I'm initializing sequelize and associated models but I am unsure. I'd like to resolve this error but need a hand with new syntax for the imports... I think.
Error, package.json and index.js include below.

Error Text

[nodemon] starting `babel-node src/index.js`
internal/process/esm_loader.js:74
    internalBinding('errors').triggerUncaughtException(
                              ^

Error [ERR_UNSUPPORTED_DIR_IMPORT]: Directory import '/Users/jeff/Clients/Bummer/Code/Server/src/models' is not supported resolving ES modules imported from /Users/jeff/Clients/Bummer/Code/Server/src/index.js
    at finalizeResolution (internal/modules/esm/resolve.js:272:17)
    at moduleResolve (internal/modules/esm/resolve.js:699:10)
    at Loader.defaultResolve [as _resolve] (internal/modules/esm/resolve.js:810:11)
    at Loader.resolve (internal/modules/esm/loader.js:85:40)
    at Loader.getModuleJob (internal/modules/esm/loader.js:229:28)
    at ModuleWrap.<anonymous> (internal/modules/esm/module_job.js:51:40)
    at link (internal/modules/esm/module_job.js:50:36) {
  code: 'ERR_UNSUPPORTED_DIR_IMPORT',
  url: 'file:///Users/jeff/Clients/Bummer/Code/Server/src/models'
}
[nodemon] app crashed - waiting for file changes before starting...

Package.JSON

{
  "name": "bummer",
  "type": "module",
  "version": "1.0.0",
  "description": "",
  "main": "index.js",
  "scripts": {
    "start": "node src/index.js",
    "dev": "nodemon --exec babel-node src/index.js",
    "test": "echo \"Error: no test specified\" && exit 1"
  },
  "keywords": [],
  "author": "",
  "license": "ISC",
  "devDependencies": {
    "@babel/core": "^7.9.6",
    "@babel/node": "^7.8.7",
    "@babel/preset-env": "^7.9.6",
    "nodemon": "^2.0.4",
    "sequelize-cli": "^6.2.0"
  },
  "dependencies": {
    "cookie-parser": "^1.4.5",
    "cors": "^2.8.5",
    "dotenv": "^8.2.0",
    "express": "^4.17.1",
    "pg": "^8.2.1",
    "querystring": "^0.2.0",
    "request": "^2.88.2",
    "sequelize": "^6.3.5",
    "sequelize-auto-migrations": "^1.0.3",
    "uuid": "^8.0.0"
  }
}

Index.js

import cors from 'cors';
import express from 'express';
import models, { sequelize } from './models';
// import routes from './routes';

//Initiaze Express
const app = express();
const routes = require('./routes');

//Helpers for Spotify oAuth
const cookieParser = require('cookie-parser')

// Include Middleware
app.use(express.static(__dirname + '/public'))
   .use(cors())
   .use(cookieParser())
   .use(express.json())
   .use(express.urlencoded({ extended: true }))
   require('dotenv').config()

   

// Include all Models
app.use((req, res, next) => {
  req.context = {
    models,
  };
  next();
});


// Load Routes from Router Index
app.use('/', routes);

sequelize.sync().then(() => {
  app.listen(process.env.PORT, () => {
    console.log(`Example app listening on port ${process.env.PORT}!`)
  });
});

Thoughts or pointers? Thank you!

m4pnthwp

m4pnthwp1#

明确指向主文件(通常为index.js)。例如:

import ... from './models'          // ❌
import ... from './models/index.js' // ✅
备选方式:

使用--experimental-specifier-resolution=node标志。例如:

node --experimental-specifier-resolution=node main.js

请访问:https://nodejs.org/api/esm.html#esm_customizing_esm_specifier_resolution_algorithm

6xfqseft

6xfqseft2#

尝试将--experimental-specifier-resolution=node标志添加到package.json中的start脚本中,特别是在本地运行时使用此标志的情况下--这是Heroku将用于启动服务器的脚本。

scripts": {
    "start": "node --experimental-specifier-resolution=node index",
    ...
},
xvw2m8pv

xvw2m8pv3#

在Node.js中,import语句只允许在ES模块中使用。因此,目录导入在Node.js中不起作用。请阅读Node.js文档。

mzsu5hc0

mzsu5hc04#

尝试在package.json中添加此代码

"scripts": {
  "start": "node --experimental-specifier-resolution=node src/index"
}
ipakzgxi

ipakzgxi5#

选项1“类型”:“模块”,应该在“主”之前:
选项:2将源文件更新为.mjs扩展名

相关问题