Node/Express - 拒绝应用样式,因为其 MIME 类型 ('text/html')

Node/Express - Refused to apply style because its MIME type ('text/html')

过去几天我一直遇到这个问题,似乎无法深入了解。我们正在做一个非常基本的 node/express 应用程序,并尝试使用类似这样的东西来提供我们的静态文件:

app.use(express.static(path.join(__dirname, "static")));

这在很大程度上符合我的预期。我们的 css 和 javascript 静态文件夹中有几个文件夹。我们正在尝试使用此静态路径将 css 加载到我们的 EJS 视图中:

<link rel="stylesheet" type="text/css" href="/css/style.css">

当我们到达路线 / 时,我们正在获取所有内容,但我们的 CSS 没有加载。我们特别收到此错误:

Refused to apply style from 'http://localhost:3000/css/style.css' because its MIME type ('text/html') is not a supported stylesheet MIME type, and strict MIME checking is enabled.

我尝试过的:

  1. 清除 NPM 缓存/全新安装
    • npm verify cache
    • rm -rf node_modules
    • npm install
  2. 清除浏览器缓存
  3. 对文件夹名称和引用的各种修改
  4. Adding/removing 正斜杠形成 href
  5. 将 css 文件夹移动到根目录并从那里提供它
  6. Adding/removing 来自 path.join(__dirname, '/static/')
  7. 的斜线
  8. github 问题报告中有一条关于服务人员可能把事情搞砸的评论,似乎解决了很多人的问题。我们的本地主机没有服务人员:https://github.com/facebook/create-react-app/issues/658
    • 我们没有使用 React,但我正在抓紧我能找到的任何 google 搜索

路线:

app.get("/", function(req, res) {
    res.render("search");
});

观点:

<!DOCTYPE html>
<html>
    <head>
        <title>Search for a Movie</title>
        <link rel="stylesheet" type="text/css" href="/static/css/style.css">
    </head>
    <body>
        <h1>Search for a movie</h1>
        <form method="POST" action="/results">
            <label for="movie-title">Enter a movie title:</label><br>
            <input id="movie-title" type="text" name="title"><br>
            <input type="submit" value="Submit Search">
        </form>
    </body>
</html>

package.json:

{
  "name": "express-apis-omdb",
  "version": "1.0.0",
  "main": "index.js",
  "scripts": {
    "start": "nodemon index.js",
    "lint:js": "node_modules/eslint/bin/eslint.js ./ ./**/*.js --fix; exit 0",
    "lint:css": "node_modules/csslint/cli.js public/css/; exit 0"
  },
  "license": "ISC",
  "devDependencies": {
    "babel-eslint": "^6.0.4",
    "csslint": "^0.10.0",
    "eslint": "^2.11.1",
    "eslint-config-airbnb": "^9.0.1",
    "eslint-plugin-import": "^1.8.1",
    "eslint-plugin-jsx-a11y": "^1.3.0",
    "eslint-plugin-react": "^5.1.1"
  },
  "dependencies": {
    "body-parser": "^1.18.2",
    "dotenv": "^5.0.0",
    "ejs": "^2.5.7",
    "express": "^4.13.4",
    "morgan": "^1.7.0",
    "path": "^0.12.7",
    "request": "^2.83.0"
  }
}

项目结构:

-app
--node_modules
--static
---img
---css
---js
--views
---movie.ejs
---results.ejs
---search.ejs
--index.js
--package-lock.json
--package.json

注意:我们目前没有为我们的 EJS 使用布局文件。

如果需要,我很乐意提供更多详细信息。

问题是文件命名不正确造成的。我们的学生在 style.css 文件的末尾有一个 space。对此有一些提示,第一个是文本编辑器中缺少语法高亮显示,第二个是文本编辑器检测其他新创建的 css 文件的文件类型,而不是不正确命名的文件。删除 space 解决了问题。

感谢 slebetman 帮助我指明了正确的方向。

这不是您问题的解决方案,但这可能会帮助像我这样的其他人寻找解决方案。如果你像下面这样使用 app.get:

app.get(express.static(path.join(__dirname,"public")));

将其更改为:

app.use(express.static(path.join(__dirname,"public")));

在带有 express 的 Nodejs 应用程序中,我们需要添加如下行来告诉服务器有关目录的信息

app.use(express.static(__dirname));

这将解决CSS无法渲染的问题

虽然答案与文件中的 space 有关,但我还有另一个可能的答案,它也会生成相同的错误代码。我将它张贴在这里,因为它也引发了这个常见的错误,引起了很多关注。

另一种方法是 styles.css 文件错位。如果引用它的地方不存在,Chrome 将吐出相同的错误代码。

我有一个 styles.css 实例在 express js 的 "public" 文件夹中,但不在 "public." 中的实际 "css" 子文件夹中(public 被用作静态文件夹。)

如果您使用 VS Code,左窗格中的文档视图会出现这种奇怪的视觉显示,让您误以为 styles.css 在 "css" 文件夹中,而实际上它不在.我是在使用普通的 windows 资源管理器并看到放错地方的文件后才发现这个问题的。要修复、检查,如果放错了地方,只需将 styles.css 放在应该放的地方。

希望这对其他人也有帮助!

我今天遇到了同样的问题。我的文件结构是这样的,所有静态文件的每个文件夹都在 public 文件夹中。 public 文件夹本身位于根目录中。我尝试使用相对路径,例如 ../public/css/index.css 等,但没有成功。这是我做的。

const app = express();
app.use(express.static("public"));

这样,您的应用程序将在 public 文件夹中查找静态文件。所以假设你有 cssjs 文件,你可以直接在 HTML 中引用它们,如下所示:

href="css/index.css"
src="js/script.js"

额外提示:

我遇到了同样的问题,但我的问题是当我尝试从一级路由器路径渲染静态文件时它正常工作

示例:站点。com/posts

但是当我尝试从像 site.com/posts/:id 这样的路径渲染静态文件时,它不起作用。

解决方案是在 href 开头添加“/”:

错误 : <link href="css/bootstrap.min.css" rel="stylesheet">

解决方法 :<link href="/css/bootstrap.min.css" rel="stylesheet">

OP 发布了他的方案的解决方案。

对于其他人,当节点服务器找不到样式表时会出现此错误 app.use() 中间件内指定路径中的文件(或任何文件)。 示例:

app.use(express.static(path.join(__dirname, "static")));

当您使用上述中间件时,快速服务器会从此目录(在本例中为静态/)搜索文件。 如果您将样式表路径指定为:

<link rel="stylesheet" type="text/css" href="/css/style.css">

然后 express 服务器将在路径 static/css/style.css 中查找。 如果文件不在此处,将抛出报告的错误。