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")
这样的检查会失败。
我正在尝试让简单的 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")
这样的检查会失败。