- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我正在使用 Cloud 9 IDE。当我这样做时构建成功
git add .
git commit -m "first_commit"
git push heroku master
其结果是这样的:
Counting objects: 3, done.
Delta compression using up to 8 threads.
Compressing objects: 100% (2/2), done.
Writing objects: 100% (3/3), 280 bytes | 0 bytes/s, done.
Total 3 (delta 1), reused 0 (delta 0)
remote: Compressing source files... done.
remote: Building source:
remote:
remote: -----> Node.js app detected
remote:
remote: -----> Creating runtime environment
remote:
remote: NPM_CONFIG_LOGLEVEL=error
remote: NPM_CONFIG_PRODUCTION=true
remote: NODE_VERBOSE=false
remote: NODE_ENV=production
remote: NODE_MODULES_CACHE=true
remote:
remote: -----> Installing binaries
remote: engines.node (package.json): 4.7.3
remote: engines.npm (package.json): 2.15.11
remote:
remote: Resolving node version 4.7.3...
remote: Downloading and installing node 4.7.3...
remote: npm 2.15.11 already installed with node
remote:
remote: -----> Restoring cache
remote: Loading 2 from cacheDirectories (default):
remote: - node_modules
remote: - bower_components (not cached - skipping)
remote:
remote: -----> Building dependencies
remote: Installing node modules (package.json)
remote:
remote: -----> Caching build
remote: Clearing previous node cache
remote: Saving 2 cacheDirectories (default):
remote: - node_modules
remote: - bower_components (nothing to cache)
remote:
remote: -----> Build succeeded!
remote: -----> Discovering process types
remote: Procfile declares types -> (none)
remote: Default types for buildpack -> web
remote:
remote: -----> Compressing...
remote: Done: 13.8M
remote: -----> Launching...
remote: Released v5
remote: https://still-reef-69131.herokuapp.com/ deployed to Heroku
remote:
remote: Verifying deploy... done.
To https://git.heroku.com/still-reef-69131.git
c263d3a..ad74a53 master -> master
这是我的app.js:
var express = require("express") ;
var app = express();
app.use(express.static("public")) ;
var sanitizer = require("express-sanitizer") ;
var methodOverride = require("method-override") ;
app.use(methodOverride("_method")) ;
var bodyparser = require("body-parser") ;
app.use(bodyparser.urlencoded({extended :true})) ;
app.use(sanitizer()) ;
var mongoose = require("mongoose") ;
mongoose.connect("mongodb://localhost/restful_blog") ;
var blogSchema = new mongoose.Schema({
title: String,
image: String,
body: String,
date: {type: Date, default: Date.now}
});
var blog = mongoose.model("blog", blogSchema);
app.get("/", function(req,res){
res.redirect("/blogs") ;
}) ;
app.get("/blogs" , function(req,res){
blog.find({},function(err , maal){
if(err) console.log(err) ;
else res.render("index.ejs",{blogs : maal}) ;
}) ;
}) ;
app.get("/blogs/new" , function(req,res){
res.render("new.ejs") ;
}) ;
app.post("/blogs" , function(req,res){
req.body.body = req.sanitize(req.body.body) ;
blog.create({title : req.body.title , body : req.body.body , image : req.body.image} , function(err,newblog){
if(err) console.log(err) ;
else res.redirect("/blogs") ;
}) ;
}) ;
app.get("/blogs/:id" , function(req,res){
blog.findById(req.params.id , function(err,maal){
if(err) console.log(err) ;
else {
res.render("show.ejs" , {readmore : maal}) ;
}
}) ;
}) ;
app.get("/blogs/:id/edit" , function(req,res){
blog.findById(req.params.id , function(err,maal){
if(err) console.log(err) ;
else {
res.render("edit.ejs",{ blog:maal }) ;
}
}) ;
}) ;
app.put("/blogs/:id/edit" , function(req,res){
req.body.body = req.sanitize(req.body.body) ;
blog.findByIdAndUpdate(req.params.id , req.body , function(err,maal){
if(err) console.log(err) ;
else {
res.redirect("/blogs/" + maal._id) ; }
}) ;
}) ;
app.delete("/blogs/:id" , function(req,res){
blog.findByIdAndRemove(req.params.id , function(err){ // No maal here as there is nothing
if(err) console.log(err) ;
else res.redirect("/blogs") ;
}) ;
}) ;
app.listen(process.env.PORT , process.env.IP , function(){
console.log("Server is ON") ;
}) ; // Server start
这是package.json:
{
"name": "restful_blog_app",
"version": "1.0.0",
"description": "",
"main": "app.js",
"scripts": {
"test": "echo \"Error: no test specified\" && exit 1",
"start": "node app.js"
},
"engines": {
"node": "4.7.3" ,
"npm": "2.15.11"
},
"author": "MeMyself&I",
"license": "ISC",
"dependencies": {
"body-parser": "^1.17.2",
"ejs": "^2.5.6",
"express": "^4.15.3",
"express-sanitizer": "^1.0.2",
"method-override": "^2.3.9",
"mongoose": "^4.11.1"
}
}
但在启动应用程序时仍然出现应用程序错误:
应用程序错误:
应用程序发生错误,无法提供您的页面。如果您是应用程序所有者,请检查您的日志以获取详细信息。
Heroku 日志:
2017-10-26T11:41:48.495327+00:00 app[web.1]:
2017-10-26T11:41:48.495329+00:00 app[web.1]: events.js:141
2017-10-26T11:41:48.495330+00:00 app[web.1]: throw er; // Unhandled 'error' event
2017-10-26T11:41:48.495330+00:00 app[web.1]: ^
2017-10-26T11:41:48.496369+00:00 app[web.1]: MongoError: failed to connect to server [localhost:27017] on first connect [MongoError: connect ECONNREFUSED 127.0.0.1:27017]
2017-10-26T11:41:48.496373+00:00 app[web.1]: at null.<anonymous> (/app/node_modules/mongoose/node_modules/mongodb/node_modules/mongodb-core/lib/connection/pool.js:280:12)
2017-10-26T11:41:48.496371+00:00 app[web.1]: at null.<anonymous> (/app/node_modules/mongoose/node_modules/mongodb/node_modules/mongodb-core/lib/topologies/server.js:336:35)
2017-10-26T11:41:48.496371+00:00 app[web.1]: at emitOne (events.js:77:13)
2017-10-26T11:41:48.496372+00:00 app[web.1]: at emit (events.js:169:7)
2017-10-26T11:41:48.496373+00:00 app[web.1]: at emitTwo (events.js:87:13)
2017-10-26T11:41:48.496373+00:00 app[web.1]: at g (events.js:260:16)
2017-10-26T11:41:48.496374+00:00 app[web.1]: at emit (events.js:172:7)
2017-10-26T11:41:48.496374+00:00 app[web.1]: at Socket.<anonymous> (/app/node_modules/mongoose/node_modules/mongodb/node_modules/mongodb-core/lib/connection/connection.js:187:49)
2017-10-26T11:41:48.496375+00:00 app[web.1]: at Socket.g (events.js:260:16)
2017-10-26T11:41:48.496375+00:00 app[web.1]: at emitOne (events.js:77:13)
2017-10-26T11:41:48.496376+00:00 app[web.1]: at Socket.emit (events.js:169:7)
2017-10-26T11:41:48.496376+00:00 app[web.1]: at emitErrorNT (net.js:1269:8)
2017-10-26T11:41:48.496377+00:00 app[web.1]: at nextTickCallbackWith2Args (node.js:458:9)
2017-10-26T11:41:48.496377+00:00 app[web.1]: at process._tickCallback (node.js:372:17)
2017-10-26T11:41:48.520747+00:00 app[web.1]: npm ERR! Linux 3.13.0-133-generic
2017-10-26T11:41:48.522269+00:00 app[web.1]: npm ERR! npm v2.15.11
2017-10-26T11:41:48.510469+00:00 app[web.1]:
2017-10-26T11:41:48.521254+00:00 app[web.1]: npm ERR! argv "/app/.heroku/node/bin/node" "/app/.heroku/node/bin/npm" "start"
2017-10-26T11:41:48.521574+00:00 app[web.1]: npm ERR! node v4.7.3
2017-10-26T11:41:48.522544+00:00 app[web.1]: npm ERR! code ELIFECYCLE
2017-10-26T11:41:48.522760+00:00 app[web.1]: npm ERR! restful_blog_app@1.0.0 start: `node app.js`
2017-10-26T11:41:48.523180+00:00 app[web.1]: npm ERR!
2017-10-26T11:41:48.522963+00:00 app[web.1]: npm ERR! Exit status 1
2017-10-26T11:41:48.523387+00:00 app[web.1]: npm ERR! Failed at the restful_blog_app@1.0.0 start script 'node app.js'.
2017-10-26T11:41:48.523612+00:00 app[web.1]: npm ERR! This is most likely a problem with the restful_blog_app package,
2017-10-26T11:41:48.523824+00:00 app[web.1]: npm ERR! not with npm itself.
2017-10-26T11:41:48.524012+00:00 app[web.1]: npm ERR! Tell the author that this fails on your system:
2017-10-26T11:41:48.524213+00:00 app[web.1]: npm ERR! node app.js
2017-10-26T11:41:48.524422+00:00 app[web.1]: npm ERR! You can get information on how to open an issue for this project with:
2017-10-26T11:41:48.524630+00:00 app[web.1]: npm ERR! npm bugs restful_blog_app
2017-10-26T11:41:48.525228+00:00 app[web.1]: npm ERR! npm owner ls restful_blog_app
2017-10-26T11:41:48.524834+00:00 app[web.1]: npm ERR! Or if that isn't available, you can get their info via:
2017-10-26T11:41:48.525418+00:00 app[web.1]: npm ERR! There is likely additional logging output above.
2017-10-26T11:41:48.525037+00:00 app[web.1]: npm ERR!
2017-10-26T11:41:48.530341+00:00 app[web.1]:
2017-10-26T11:41:48.530616+00:00 app[web.1]: npm ERR! Please include the following file with any support request:
2017-10-26T11:41:48.530813+00:00 app[web.1]: npm ERR! /app/npm-debug.log
2017-10-26T11:41:48.620147+00:00 heroku[web.1]: State changed from starting to crashed
2017-10-26T11:41:48.607867+00:00 heroku[web.1]: Process exited with status 1
2017-10-26T11:42:04.141504+00:00 heroku[router]: at=error code=H10 desc="App crashed" method=GET path="/" host=still-reef-69131.herokuapp.com request_id=525c4f82-20fc-4d02-9b21-848c0011e451 fwd="115.97.201.36" dyno= connect= service= status=503 bytes= protocol=https
2017-10-26T11:42:05.503594+00:00 heroku[router]: at=error code=H10 desc="App crashed" method=GET path="/favicon.ico" host=still-reef-69131.herokuapp.com request_id=648fd443-3661-49d1-87f7-7ba27c065dff fwd="115.97.201.36" dyno= connect= service= status=503 bytes= protocol=https
2017-10-26T11:43:56.405496+00:00 heroku[router]: at=error code=H10 desc="App crashed" method=GET path="/" host=still-reef-69131.herokuapp.com request_id=6e94416f-ac28-4196-8ecd-7f701e96785e fwd="115.97.201.36" dyno= connect= service= status=503 bytes= protocol=https
2017-10-26T11:43:57.089498+00:00 heroku[router]: at=error code=H10 desc="App crashed" method=GET path="/favicon.ico" host=still-reef-69131.herokuapp.com request_id=b2069968-30b5-4875-9b04-ad3fa5c38419 fwd="115.97.201.36" dyno= connect= service= status=503 bytes= protocol=https
<小时/>
有什么想法我哪里出错了吗?
最佳答案
问题出在你的 Mongoose 连接上。
你安装了heroku mongodb插件吗?
$heroku addons:create mongolab
有关在 Heroku 上使用 mongodb 的更多信息,请参见此处。 nodejs-mongoose
关于node.js - NodeJS 应用程序构建成功(Heroku),但启动时 Heroku 中出现应用程序错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46953756/
我正在通过 labrepl 工作,我看到了一些遵循此模式的代码: ;; Pattern (apply #(apply f %&) coll) ;; Concrete example user=> (a
我从未向应用商店提交过应用,但我会在不久的将来提交。 到目前为止,我对为 iPhone 而非 iPad 进行设计感到很自在。 我了解,通过将通用PAID 应用放到应用商店,客户只需支付一次就可以同时使
我有一个应用程序,它使用不同的 Facebook 应用程序(2 个不同的 AppID)在 Facebook 上发布并显示它是“通过 iPhone”/“通过 iPad”。 当 Facebook 应用程序
我有一个要求,我们必须通过将网站源文件保存在本地 iOS 应用程序中来在 iOS 应用程序 Webview 中运行网站。 Angular 需要服务器来运行应用程序,但由于我们将文件保存在本地,我们无法
所以我有一个单页客户端应用程序。 正常流程: 应用程序 -> OAuth2 服务器 -> 应用程序 我们有自己的 OAuth2 服务器,因此人们可以登录应用程序并获取与用户实体关联的 access_t
假设我有一个安装在用户设备上的 Android 应用程序 A,我的应用程序有一个 AppWidget,我们可以让其他 Android 开发人员在其中以每次安装成本为基础发布他们的应用程序推广广告。因此
Secrets of the JavaScript Ninja中有一个例子它提供了以下代码来绕过 JavaScript 的 Math.min() 函数,该函数需要一个可变长度列表。 Example:
当我分别将数组和对象传递给 function.apply() 时,我得到 NaN 的 o/p,但是当我传递对象和数组时,我得到一个数字。为什么会发生这种情况? 由于数组也被视为对象,为什么我无法使用它
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界. 这篇CFSDN的博客文章ASP转换格林威治时间函数DateDiff()应用由作者收集整理,如果你
我正在将列表传递给 map并且想要返回一个带有合并名称的 data.frame 对象。 例如: library(tidyverse) library(broom) mtcars %>% spl
我有一个非常基本的问题,但我不知道如何实现它:我有一个返回数据框,其中每个工具的返回值是按行排列的: tmp<-as.data.frame(t(data.frame(a=rnorm(250,0,1)
我正在使用我的 FB 应用创建群组并邀请用户加入我的应用群组,第一次一切正常。当我尝试创建另一个组时,出现以下错误: {"(OAuthException - #4009) (#4009) 在有更多用户
我们正在开发一款类似于“会说话的本”应用程序的 child 应用程序。它包含大量用于交互式动画的 JPEG 图像序列。 问题是动画在 iPad Air 上播放正常,但在 iPad 2 上播放缓慢或滞后
我关注 clojure 一段时间了,它的一些功能非常令人兴奋(持久数据结构、函数式方法、不可变状态)。然而,由于我仍在学习,我想了解如何在实际场景中应用,证明其好处,然后演化并应用于更复杂的问题。即,
我开发了一个仅使用挪威语的应用程序。该应用程序不使用本地化,因为它应该仅以一种语言(挪威语)显示。但是,我已在 Info.plist 文件中将“本地化 native 开发区域”设置为“no”。我还使用
读完 Anthony's response 后上a style-related parser question ,我试图说服自己编写单体解析器仍然可以相当紧凑。 所以而不是 reference ::
multicore 库中是否有类似 sapply 的东西?还是我必须 unlist(mclapply(..)) 才能实现这一点? 如果它不存在:推理是什么? 提前致谢,如果这是一个愚蠢的问题,我们深表
我喜欢在窗口中弹出结果,以便更容易查看和查找(例如,它们不会随着控制台继续滚动而丢失)。一种方法是使用 sink() 和 file.show()。例如: y <- rnorm(100); x <- r
我有一个如下所示的 spring mvc Controller @RequestMapping(value="/new", method=RequestMethod.POST) public Stri
我正在阅读 StructureMap关于依赖注入(inject),首先有两部分初始化映射,具体类类型的接口(interface),另一部分只是实例化(请求实例)。 第一部分需要配置和设置,这是在 Bo
我是一名优秀的程序员,十分优秀!