node.js+express+jade: style.css вътрешна сървърна грешка 500

Имам проблем с node.js+express+jade, който не знам как да разреша, вече търсих в google и stackoverflow без решение, така че ви моля да ми помогнете :)

Проблемът е, че всички работят с изключение на style.css:

Failed to load resource: the server responded with a status of 500 (Internal 
 Server Error)

P.S: преинсталирах най-новите версии на node.js и модули за сигурност, без решение

АКТУАЛИЗАЦИЯ: грешката излиза САМО когато добавя това: link(rel='stylesheet', href='/bgstyle.css') във файла jade

app.js

var express = require("express"); 
app = express(),
routes = require('./routes');

app.configure(function(){
    app.set('port', 8080);
    app.set('views', __dirname + '/views');
    app.set('view engine', 'jade');
    app.use(express.favicon());
    app.use(express.logger('dev'));
    app.use(express.urlencoded());
    app.use(express.methodOverride());
    app.use(app.router);
    app.use(express.static(__dirname + '/public'));
});

app.get("/", routes.index);

app.listen(app.get("port"), function() {
    console.log("App listening on port " + app.get("port"));
});

routes/index.js

exports.index = function(req, res) {
    res.render('index');
};

public/style.css

body {
    font-size: 20px;
}

Получих тази грешка:

my_path_privacy\nodejs-test>node app.js
    App listening on port 8080
    ←[90mGET / ←[32m200 ←[90m3674ms - 867b←[0m
    TypeError: Object #<SendStream> has no method 'on'
        at Object.staticMiddleware [as handle] (my_path_privacy\nodejs-test\node_modules\express\node_modules\connect\lib\middleware\static.js:89:8)
        at next (my_path_privacy\nodejs-test\node_modules\express\node_modules\connect\lib\proto.js:193:15)
        at pass (my_path_privacy\nodejs-test\node_modules\express\lib\router\index.js:110:24)
        at Router._dispatch (my_path_privacy\nodejs-test\node_modules\express\lib\router\index.js:173:4)
        at Object.router [as handle] (my_path_privacy\nodejs-test\node_modules\express\lib\router\index.js:33:10)
        at next (my_path_privacy\nodejs-test\node_modules\express\node_modules\connect\lib\proto.js:193:15)
        at Object.methodOverride [as handle] (my_path_privacy\nodejs-test\node_modules\express\node_modules\connect\lib\middleware\methodOverride.js:48:5)
        at next (my_path_privacy\nodejs-test\node_modules\express\node_modules\connect\lib\proto.js:193:15)
        at Object.urlencoded [as handle] (my_path_privacy\nodejs-test\node_modules\express\node_modules\connect\lib\middleware\urlencoded.js:41:37)
        at next (my_path_privacy\nodejs-test\node_modules\express\node_modules\connect\lib\proto.js:193:15)
    ←[90mGET /style.css ←[31m500 ←[90m52ms - 1.34kb←[0m

package.json

{
   "name": "app-test",
   "version": "0.0.1",
   "private": true,
   "scripts": {
       "start": "node app.js"
   },
   "dependencies": {
      "express": "3.4.7",
      "jade": "1.1.0"
   },
   "engines": {
      "node": "0.10.24",
      "npm": "1.3.21"
  }
}

index.jade

doctype html
html
  head
    title Hello world
    link(rel='stylesheet', href='/bgstyle.css')
  body
    p Hello world

person Manuel Di Iorio    schedule 08.01.2014    source източник
comment
Изглежда, че този отговор може да реши проблема ви.   -  person robertklep    schedule 08.01.2014
comment
@robertklep: вече опитах и ​​не се решава, но благодаря за помощта   -  person Manuel Di Iorio    schedule 08.01.2014


Отговори (2)


Не знам дали е свързано, имах много проблеми с вградения скрипт в jade файла. Синтаксисът е променен. Може да се наложи да добавите точка към маркерите на скрипта в jade файла, ако JS е последван в следващите редове.

Има още една лоша промяна, трябва да напишете doctype html вместо doctype 5

script
  var x=1

is now

script.
  var x=1
person user3062426    schedule 08.01.2014
comment
хм, нямам таг за скрипт в jade файла, но търся синтактични грешки - person Manuel Di Iorio; 08.01.2014

Изглежда като проблем с машината за шаблони, просто от любопитство, можете ли да опитате да изпратите масив или обект вместо „Hello , World“, просто заменете

res.render('index', {title: "Hello, world"});

с

res.render('index', {title: some array or object here});
person user3038427    schedule 08.01.2014
comment
обикновено грешните или никакви зависимости на двигателя причиняват това, може да искате да проверите и това (package.json) - person user3038427; 08.01.2014
comment
вижте новите актуализации на отворената публикация, проблемът е във връзката rel - person Manuel Di Iorio; 08.01.2014