python 简单的 HTTP 服务器不加载超棒的字体

python simple HTTP server not loading font-awesome fonts

我正在尝试让简单的 HTTP 服务器加载超棒的字体,但可以让它工作,我只得到小方块。

我认为这可能是某种 MIME 类型的问题。 HTML 页面和 font-awesome 字体在浏览器中直接打开时会加载,但通过简单的 HTTP 服务器加载时不会加载。

这个问题看起来是一样的,但是

<meta charset="UTF-8"> 

在 HTML 代码中没有帮助我。

from BaseHTTPServer import BaseHTTPRequestHandler,HTTPServer
from os import curdir, sep
import cgi

import subprocess as sub
import time

PORT_NUMBER = 8080


class myHandler(BaseHTTPRequestHandler):


    def do_GET(self):
        if self.path=="/":
            self.path="/index.html"

        try:

            sendReply = False
            if self.path.endswith(".html"):
                mimetype='text/html'
                sendReply = True
            if self.path.endswith(".jpg"):
                mimetype='image/jpg'
                sendReply = True
            if self.path.endswith(".png"):
                mimetype='image/png'
                sendReply = True
            if self.path.endswith(".gif"):
                mimetype='image/gif'
                sendReply = True
            if self.path.endswith(".svg"):
                mimetype='image/svg+xml'
                sendReply = True
            if self.path.endswith(".css"):
                mimetype='text/css'
                sendReply = True
            if self.path.endswith(".js"):
                mimetype='application/javascript'
                sendReply = True
            if self.path.endswith(".ttf"):
                mimetype='application/x-font-ttf'
                sendReply = True
            if self.path.endswith(".otf"):
                mimetype='application/x-font-opentype'
                sendReply = True
            if self.path.endswith(".woff"):
                mimetype='application/font-woff'
                sendReply = True

            if sendReply == True:
                #Open the static file requested and send it
                f = open(curdir + sep + self.path, 'rb')
                self.send_response(200)
                self.send_header('Content-type',mimetype)
                self.end_headers()
                self.wfile.write(f.read())
                f.close()
                print(curdir + sep + self.path)
            return

        except IOError:
            self.send_error(404,'File Not Found: %s' % self.path)

    def do_POST(self):

        if self.path=="/run":
            form = cgi.FieldStorage(
                fp=self.rfile,
                headers=self.headers,
                environ={'REQUEST_METHOD':'POST',
                         'CONTENT_TYPE':self.headers['Content-Type'],
            })


                        #self.send_response(200)
                        #self.end_headers()
            return

这是 html 页面的一部分:

<html>
    <head>
        <meta charset="UTF-8">
        <title>HW Test</title>

        <!-- Bootstrap -->

        <link href = "css/bootstrap.min.css" rel="stylesheet"></link>
        <link href = "css/custom.css" rel="stylesheet"></link>
        <link href = "css/font-awesome.min.css" rel="stylesheet"></link>

        <script src="js/bootstrap.min.js"></script>

</head>


<body>
    <div class = "container"> 
        <div class="row">
            <input id="box1" type="checkbox" />
            <label for="box1">Checkbox 1</label>
            <input id="box2" type="checkbox" />
            <label for="box2">Checkbox 2</label>
        </div>
...

复选框显示为小方块,而不是复选框。 这些应该由不会加载的超棒字体显示。

我认为问题出在字体文件名上,例如,font-awesome.css 的最新版本包含:

@font-face {
  font-family: 'FontAwesome';
  src: url('../fonts/fontawesome-webfont.eot?v=4.7.0');
  src: url('./fonts/fontawesome-webfont.woff2?v=4.7.0') ...

这意味着 self.path 包含如下内容:

/fonts/fontawesome-webfont.woff2?v=4.7.0

并且像 if self.path.endswith(".woff") 这样的检查会失败。