请在评论之前阅读所有这些.
我目前正在一个由Amazon Web Services(AWS)上托管的大型网站上工作.这使我们能够在网站可能需要大量流量负载的情况下使用可扩展性功能.
最初我们开始分离网站的代码,混合使用HTML / PHP / Java等,并在单独的服务器上具有静态资产.当我第一次尝试使用这个设置中的Font-face时,我发现firefox和IE不会加载字体,很快就发现这是一个跨域的问题.有各种各样的解决方案,其中包括修改头以允许访问字体文件.但是,我们使用的存储系统不允许这种类型的头修改.
为了看看是否可以让所有浏览器的字体都能正常工作,我把它们和CSS文件一起调用到与该网站相同的域上.但是,它们似乎还没有加载到firefox或IE中.如果我在我的文档中复制代码并在本地运行,所有浏览器中的所有内容似乎都很好(所以文件不会被破坏). firefox绝对是找到这些文件,因为我可以看到它们通过FireBUG加载.
我已检查所有网址,以确保它们是正确的,并解决他们应该在哪里.
这是我用笑脸黑客使用的Font-face CSS:
@Font-face { Font-family : "AllerRegular"; src : url('aller_rg-webFont.eot'); src : local('☺'),url('aller_rg-webFont.woff') format('woff'),url('aller_rg-webFont.ttf') format('truetype'),url('aller_rg-webFont.svg#webFontooYDBZYS') format('svg'); Font-weight : normal; Font-style : normal;}
CSS文件位于与字体相同的目录中.
我也有一个.htaccess文件中设置的MIME类型,它们位于与字体相同的文件夹中.
AddType application/vnd.ms-Fontobject .eotAddType Font/truetype .ttfAddType Font/opentype .otfAddType Font/opentype .woffAddType image/svg+xml .svg .svgzAddEnCoding gzip .svgz<filesMatch "\.(ttf|otf|eot|woff|svg)$"> <IfModule mod_headers.c> header set Access-Control-Allow-Origin "*" </IfModule></filesMatch>
如果您有任何想法,请提出建议.我一直在搜索网站几天,但所有的解决方案都让我失望.
解决方法 目前来说,由于AWS不支持Access-Control-Origin-header,因此在AWS和IE 9中提供的WebFonts可能不起作用.在AWS论坛上看到这个 post.似乎是很多人的问题.更新7/17/12:
作为AWS的替代方案,Google的云服务支持跨原始文件服务.我只是设置一个桶来提供web字体,似乎是正常工作.有关更多信息,请参阅此博客post和documentation.
总结以上是内存溢出为你收集整理的html – 跨域字体问题全部内容,希望文章能够帮你解决html – 跨域字体问题所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)