来自 Firefox 的错误:MIME 类型(“text/plain”)不匹配(X-Content-Type-Options: nosniff)

Posted

技术标签:

【中文标题】来自 Firefox 的错误:MIME 类型(“text/plain”)不匹配(X-Content-Type-Options: nosniff)【英文标题】:Error from Firefox: MIME type (“text/plain”) mismatch (X-Content-Type-Options: nosniff) 【发布时间】:2020-07-08 03:17:58 【问题描述】:

我正在用 Go 构建一个 Web 应用程序。在我尝试将我的 index.html 文件链接到名为 index.js 的 javascript 文件之前,我在这个项目中没有遇到任何问题:

<script type="text/javascript" src="javascript/index.js"></script>

我在 Firefox 中得到的确切错误是:

“https://10.78.80.22:8000/javascript/index.js”的资源由于 MIME 类型(“text/plain”)不匹配(X-Content-Type-Options: nosniff)而被阻止

我一直在进行广泛的故障排除。我发现与此错误有关的所有解决方案均未成功。只有一篇文章是针对特定的,但解决方案没有帮助。我已经确保js文件的路径是正确的。

我正在使用 gorilla mux 来处理路由。这是一个代码示例:

r := mux.NewRouter()
r.HandleFunc("/", middleware.AuthRequired(indexGetHandler)).Methods("GET")
r.HandleFunc("/", middleware.AuthRequired(indexPostHandler)).Methods("POST")
r.HandleFunc("/login", loginGetHandler).Methods("GET")
r.HandleFunc("/login", loginPostHandler).Methods("POST")
r.HandleFunc("/logout", logoutHandler).Methods("GET")
r.HandleFunc("/register", registerGetHandler).Methods("GET")
r.HandleFunc("/register", registerPostHandler).Methods("POST")
r.HandleFunc("/clumps", middleware.AuthRequired(clumpsGetHandler)).Methods("GET")
r.HandleFunc("/clumps", middleware.AuthRequired(clumpsPostHandler)).Methods("POST")   
log.Fatal(http.ListenAndServeTLS(":8000", "cert/cert.pem", "cert/key.pem", r))

这是我项目的相关结构:

main.go
>routes
    routes.go
>templates
    index.html
    >javascript
        index.js

请注意,上面的“代码示例”位于 routes.go

这是我的 main.go 文件供您参考:

package main

import (
    "log"
    "net/http"

    "./routes"
    "./templates"
)

func main() 
    templates.LoadTemplates("templates/*.html")
    r := routes.NewRouter()
    log.Fatal(http.ListenAndServeTLS(":8000", "cert/cert.pem", "cert/key.pem", r))

编辑:这里是索引获取处理程序(位于路由文件夹中)。如果 post 处理程序有帮助,请告诉我,但它似乎不相关:

func indexGetHandler(w http.ResponseWriter, r *http.Request) 
    templates.Execute(w, "index.html", nil)

这里是 index.html:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Compositum</title>
</head>
<body>
     if . 
    <div class="error"> . </div>
     end 
    <h1>Fill it out:</h1>
    <form method="POST">
        Name: <input name = "name"></textarea><br>
        URL: <input name = "url"></textarea><br>
        Login: <input name = "login"></textarea><br>
        Email: <input name = "email"></textarea><br>
        Password: <input name = "password"></textarea><br>
        <div>
            <button type="submit">Save</button>
        </div>
    </form>
    <!--  range . 
    <div> . </div>
     end  -->
    <script type="text/javascript" src="javascript/index.js"></script>
</body>
</html>

【问题讨论】:

在浏览器地址栏中输入javascript/index.js解析的URL,并确认您获得了您期望的文件。 @MuffinTop 抱歉回复晚了。我想我需要一些澄清,因为我以前从未这样做过。如果我在地址栏中输入“10.78.80.22:8000/javascript/index.js”,我会收到 404 错误。但是,如果我将地址输入到我确定应该加载的页面,例如“10.78.80.22:8000/index.html”,我也会收到 404 错误。这让我相信我输入的地址不正确,因为我不确定它是如何工作的。为了您的方便,我编辑了我的初始帖子以反映我的项目结构。谢谢! 我猜javascript/index.js 是纯文本未找到页面。问题中没有足够的信息来提供进一步的帮助。目前尚不清楚javascript/index.js 的绝对路径是什么或它如何映射到任何处理程序。 @MuffinTop index.js 的绝对路径是“/home/marc/compositum/templates/javascript”。索引处理程序已作为另一个编辑添加到我的原始帖子中。谢谢! @MuffinTop 为了您的方便,我还添加了 index.html。再次感谢! 【参考方案1】:

我与一位后端开发人员交谈,结果发现我对如何提供静态文件没有正确的理解。我没有用于提供静态文件的文件系统。我通过添加一个文件服务器来处理我的路由解决了这个问题:

fileServer := http.FileServer(http.Dir("./static/")
r.PathPrefix("/static/", fileServer)

将 index.js 添加到我新创建的“静态”目录后,一切正常。

谢谢!

【讨论】:

以上是关于来自 Firefox 的错误:MIME 类型(“text/plain”)不匹配(X-Content-Type-Options: nosniff)的主要内容,如果未能解决你的问题,请参考以下文章

来自 AWS Elastic Beanstalk 的 Mime 类型错误

上传文件中的 Mime 类型错误

来自 asp 应用程序的流式 mime 类型“应用程序/pdf”在 Google Chrome 中失败

防止 IE 中止具有错误 Mime 类型的图像

Firefox 无法识别 WebP MIME 类型

MEDIA12899:音频/视频:未知 MIME 类型: