我正在开发一个Node.js应用程序,并且正在使用一个公开我的Twitter API令牌/秘密的 config.js 文件。我这样做是因为我计划在完成应用程序之后开源应用程序,并且希望将这些应用程序保密(因此,将该文件放在我的.gitignore
中。
无论如何,对于我的问题 - 我收到以下错误日志:
2012-04-09T22:41:12+00:00 app[web.1]: node.js:134
2012-04-09T22:41:12+00:00 app[web.1]: ^
2012-04-09T22:41:12+00:00 app[web.1]: throw e; // process.nextTick error, or 'error' event on first tick
2012-04-09T22:41:12+00:00 app[web.1]: Error: Cannot find module './config'
2012-04-09T22:41:12+00:00 app[web.1]: at require (module.js:348:19)
2012-04-09T22:41:12+00:00 app[web.1]: at Function._load (module.js:266:25)
2012-04-09T22:41:12+00:00 app[web.1]: at Function._resolveFilename (module.js:320:11)
2012-04-09T22:41:12+00:00 app[web.1]: at Object.<anonymous> (/app/app.js:6:19)
2012-04-09T22:41:12+00:00 app[web.1]: at Module._compile (module.js:404:26)
2012-04-09T22:41:12+00:00 app[web.1]: at Object..js (module.js:410:10)
2012-04-09T22:41:12+00:00 app[web.1]: at Function._load (module.js:297:12)
2012-04-09T22:41:12+00:00 app[web.1]: at EventEmitter._tickCallback (node.js:126:26)
2012-04-09T22:41:12+00:00 app[web.1]: at Module.load (module.js:336:31)
2012-04-09T22:41:12+00:00 app[web.1]: at Array.<anonymous> (module.js:423:10)
2012-04-09T22:41:13+00:00 heroku[web.1]: State changed from starting to crashed
2012-04-09T22:41:13+00:00 heroku[web.1]: Process exited with status 1
我的文件名是config.js
,我正在我的应用中执行:var config = require('./config')
。我没有将它列为package.json
文件中的依赖项,因为它不在NPM中。
与foreman和Procfile一起在本地运行(就像heroku的文档说的那样)工作得很好。但是,当我需要一个本地文件时,我很困惑为什么它会给我一个错误。 config.js
与我的app.js
位于同一目录级别,因此要求它的路径是正确的。
编辑:以下是我在app.js
中使用的代码部分:
var express = require('express')
, sys = require('sys')
, request = require('request')
, config = require('./config')
谢谢 - 非常感谢任何帮助!
答案 0 :(得分:15)
因为您将config.js
文件放在.gitignore
中,所以它没有被推送到Heroku服务器,就像您说的那样。对于您想要做的事情,您通常会使用Heroku's config vars设置环境变量,然后由应用程序读取:
$ heroku config:add TWITTER_TOKEN=<token> TWITTER_SECRET=<secret>
然后在app.js
文件中,您可以使用以下命令访问这些环境变量:
var token = process.env['TWITTER_TOKEN'];
var secret = process.env['TWITTER_SECRET'];