nginx/apache配置,如何识别svg及字体文件?
发布于 作者:苏南大叔 来源:程序如此灵动~data:image/s3,"s3://crabby-images/0c48a/0c48ad88a9ad140ea27e7173360ee7e153998878" alt=""
苏南大叔,在折腾wordpress
皮肤的时候,发现:一些皮肤下面出现了奇怪的500
问题,仔细看看确,都是些字体和svg
资源的请求,会显示500
错误。但是同样配置下面的普通站点,却没有这种情况发生。所以,可以怀疑和wordpress
的特殊机制有关系。wordpress
是要把所有的请求都转移到index.php
上面进行处理的。也许这就是问题所在。不过,这个结论还有待观察。
修改nginx
设置
解决方案,却是去修改nginx
的相关配置,修改nginx
的mime.types
文件,使之能够识别字体文件类型:
application/x-font-ttf ttc ttf;
application/x-font-otf otf;
application/font-woff woff;
application/font-woff2 woff2;
application/vnd.ms-fontobject eot;
image/svg+xml svg svgz;
注意:请按需要添加。
添加成功后,在nginx
的vhost.conf
的合适位置,添加如下代码即可。
location ~* \.(eot|otf|ttf|woff|woff2|svg)$ {
add_header Access-Control-Allow-Origin *;
}
配置完成,执行nginx
重载配置即可生效。
nginx -s reload
apache
类似设置
Apache
下面的类似设置如下:
AddType application/x-font-ttf ttc ttf
AddType application/x-font-otf otf
AddType application/font-woff woff
AddType application/font-woff2 woff2
AddType application/vnd.ms-fontobject eot
<FilesMatch ".(eot|ttf|otf|woff|woff2)">
Header set Access-Control-Allow-Origin "*"
</FilesMatch>
当然,apache
除了写在httpd.conf
文件下面之外,还可以写在开启了htaccess
功能站点的.htaccess
文件中。
结语
感谢您的阅读,希望本篇文章能够顺利解决困扰你的问题。想查看苏南大叔的更多nginx
经验文章么?请点击这里查看:https://newsn.net/tag/nginx/ 。
data:image/s3,"s3://crabby-images/0f5f1/0f5f1ed65a4322c1d5f1eae97227e101845eb910" alt=""
data:image/s3,"s3://crabby-images/0c48a/0c48ad88a9ad140ea27e7173360ee7e153998878" alt=""
data:image/s3,"s3://crabby-images/00986/00986edcc341d6fbc7e875c3dc93f1b0d0506e8c" alt=""