javascript - 从 NodeJS 提供静态文件时出现奇怪的 mime 类型覆盖问题

标签 javascript html css node.js mime-types

我正在使用 NodeJS 来提供我的 View 目录中的文件(不明确)。我遵循一个应用程序、服务器、路由器、处理程序结构,处理程序几乎拥有所有代码。

这里是 handler.js 的代码:

const fs = require('fs'),
path = require('path'),
formidable = require('formidable');

function handle(pathname, method, viewDir, response){
    let filePath;
    console.log(pathname);
    if(pathname==='/'){
        pathname = '/main.html';
    }

    if(pathname==='/favicon.ico'){
        debugger;
        response.end();
    }
    else{
        filePath = viewDir + pathname;
        //fileext = pathname.substr(pathname.lastIndexOf('.')+1);   
        fileExt = path.extname(pathname);
        console.log(filePath+'\n'+fileExt);
        if(fileExt!==''){
            fs.readFile(filePath, function(err,data){
                if(err){
                    response.writeHead(400, {'Content-Type': 'text/html'});
                    response.end('<h1>Error reading file!</h1>');
                }
                if(data){
                    debugger;
                    // console.log({'Content-Type': 'text/' + fileExt.substr(1)=='js'?'javascript':fileExt.substr(1)});
                    let mimeType = 'text/' + (fileExt.substr(1)=='js'?'javascript':fileExt.substr(1));
                    console.log(mimeType);
                    response.writeHead(200, {'Content-Type': mimeType});
                    response.write(data);
                    response.end();
                }
            });
        }   
        else if(pathname==='/upload' && method.toLowerCase()==='post'){
            //some formidable code here
            response.end();
        }
        else{
            response.writeHead(404, {'Content-Type': 'text/html'});
            response.end('<h1>404 File not found!</h1>');
        }
    }

}

    exports.handle = handle;

这是 main.html:

    <!DOCTYPE html>
<html>
<head>
    <title>Caption generator for images</title>
    <meta charset="utf-8">
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha384-BVYiiSIFeK1dGmJRAkycuHAHRg32OmUcww7on3RYdg4Va+PmSTsz/K68vbdEjh4u" crossorigin="anonymous">
    <link rel="stylesheet" type="text/css" href="./main.css"></link>
    <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.2.0/jquery.min.js"></script>
</head>
<body>
    <div class="jumbotron">
        <h1>Caption generator for images</h1>
        <h3>Generates a list of captions appropriate for your uploaded picture by visual recognition.</h3>
    </div>
    <div class="container">
        <div class="page-header">
            <h1>Upload image</h1>
        </div>
        <form enctype="multipart/form-data">
            <div class="form-group">
                <label for="imageInputFile">Image input</label>
                <input id="image-input-file" type="file" class="form-control-file" name="image-input-file" aria-describedby="fileHelp" accept="image/*">
                <small id="fileHelp" class="form-text text-muted">Upload an image file or use already uploaded image.</small>
            </div>
            <button type="submit" id="file_submit" class="btn btn-primary">Submit</button>
        </form>
    </div>
    <script type="text/javascript" src="main.js"></script>
</body>
</html>

现在,如果我从 main.html 中删除最后一个脚本标记,一切都可以正常加载,但如果它存在,我的 main.css 文件将使用 mime 类型的文本/javascript 提供服务。

我没看到什么?

我还看到两个 text/javascript 被记录下来,它们都是在 main.js 得到服务之后。如果我在我的脚本标记之后剪切并粘贴我的 main.css 的链接标记,它们都将作为文本/css 提供。

这是否与我的 fileExt 是一个全局变量有关?

最佳答案

我认为您混淆了 ServerSide 和 ClientSide 之间的路径。 在您的 HTML 中,css 与 ./main.css 一起使用,但对于 JS,您直接使用 main.js

我没有完整的元素来检查正在加载的文件夹/URL。

有没有理由不使用 ExpressJS? 例如,如果您的目录如下:

app/
app/index.js
app/public/{here your css, main}

在 index.js 中 你只需要

const express = require('express');
const app = express();

app.use('/', express.static('public'));

app.listen(3000, function () {
  console.log('Example app listening on port 3000!')
});

关于javascript - 从 NodeJS 提供静态文件时出现奇怪的 mime 类型覆盖问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46675568/

相关文章:

javascript - Canvas ,沿弧线从一个点移动到另一个点

javascript - 使用背景 mousemove 脚本平滑移动

css - 使用 gulp 在相同结构的多个目录中编译 SASS

javascript - React-Native Firebase 使用 FlatList 显示对象数组

javascript - 刷新 View 以应用新选择的主题

html - 如何将输入文本和 ngMessage 放入指令 templateUrl 中?是否可以?

javascript - 根据php数组值更改td的背景颜色

javascript - 单击 iframe 时如何隐藏父元素

javascript - 使用 JavaScript/ajax 在单击按钮上更改特定 TD 的背景颜色

jquery - 通过自动页面滚动,单击时将 div 浮出窗口顶部