Не удалось декодировать загруженный шрифт


149

Это ошибка, которую я получаю в Chrome, и, к сожалению, ее поиск не дал мне особых результатов. Сам шрифт отображается правильно. Однако я все еще получаю эту ошибку / предупреждение. Более конкретно, это полное предупреждение:

"Не удалось декодировать загруженный шрифт: http: // localhost: 8000 / app / fonts / Lato / "

Мой CSS это:

@font-face {
    font-family:"Lato";
    src: url("../fonts/Lato/");
}

html, body {
    font-family:'Lato';
}

Я просто не понимаю. Шрифт применяется правильно, но предупреждение всегда есть. Попытка использования Sans-Serifзаставляет шрифт вернуться к обычному шрифту браузера, так что, возможно, это так, но я не уверен, и даже после поиска я ничего не нашел. Спасибо!

РЕДАКТИРОВАТЬ

Существуют различные файлы шрифтов, все из одной семьи. Я пытаюсь загрузить их всех. Файлы шрифтов есть .ttf. Я загружаю их из локальной папки, и есть различные файлы шрифтов, например Lato-Black.ttf, Lato-Bold.ttfи Lato-Italic.ttfт. Д.


2
Почему косая черта в URL? Вы пытаетесь загрузить все файлы из каталога, или это на самом деле перенаправление в один файл шрифта?
Альваро Гонсалес

@ ÁlvaroG.Vicario Привет, спасибо, что уделили время. Я отредактировал вопрос, чтобы сделать его более понятным.
Луис Феррейра

Ответы:


101

В правиле CSS вы должны добавить расширение файла. Этот пример с самой глубокой возможной поддержкой:

@font-face {
  font-family: 'MyWebFont';
  src: url('webfont.eot'); /* IE9 Compat Modes */
  src: url('webfont.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */
       url('webfont.woff2') format('woff2'), /* Super Modern Browsers */
       url('webfont.woff') format('woff'), /* Pretty Modern Browsers */
       url('webfont.ttf')  format('truetype'), /* Safari, Android, iOS */
       url('webfont.svg#svgFontName') format('svg'); /* Legacy iOS */
}

РЕДАКТИРОВАТЬ:

«Не удалось декодировать загруженный шрифт» означает, что шрифт поврежден или неполон (отсутствуют метрики, необходимые таблицы, записи имен, миллион возможных вещей).

Иногда эта проблема вызвана самим шрифтом. Шрифт Google предоставляет правильный шрифт, который вам нужен, но если необходим шрифт, я использую Transfonter для генерации всех форматов шрифтов.

Иногда FTP-клиент повреждает файл (не в этом случае, потому что он находится на локальном компьютере). Обязательно передайте файл в двоичном формате, а не в ASCII.


Я отредактировал свой вопрос, чтобы сделать его более понятным. Я не уверен, что это изменит что-то из того, что вы опубликовали. Извините за беспорядок и спасибо за ваше время.
Луис Феррейра

1
Вы должны обязательно использовать @font face? Я знаю, что Лато доступен на шрифтах Google. В любом случае вы можете попробовать это: font-family: 'Lato'; font-style: normal; font-weight: 400; src: local('Lato Regular'), local('Lato-Regular'), url('../font/file for regular font.wof') format('wof');этот код для каждого типа шрифта, обычный, жирный и т. Д.
Джермано Плебани

1
Я закончил тем, что использовал опцию Google Fonts, и она работает хорошо. Спасибо. Я принял твой ответ.
Луис Феррейра

9
Этот вопрос помечен как «не удалось декодировать загруженный шрифт». Ответ является конкретной ситуацией и фактически не указывает, что означает ошибка.
Krii

24

Я столкнулся с подобной проблемой в Visual Studio, которая была вызвана неправильной url() путем к рассматриваемому шрифту.

Я перестал получать эту ошибку после изменения (например):

@@font-face{
    font-family: "Example Font";
    src: url("/Fonts/ExampleFont.eot?#iefix");

к этому:

@@font-face{
    font-family: "Example Font";
    src: url("../fonts/ExampleFont.eot?#iefix");

1
для меня ./ или ../ не сработало, но удаление / вообще сработало перешло /assets...в assets...Большое спасибо!
Шериф Марзук

21

Изменение формата ('woff') на формат ('font-woff') поможет мне решить эту проблему только сейчас.

Просто измените небольшое изменение здесь от ответа Джермано Плебани

 @font-face {
  font-family: 'MyWebFont';
  src: url('webfont.eot'); /* IE9 Compat Modes */
  src: url('webfont.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */
       url('webfont.woff2') format('woff2'), /* Super Modern Browsers */
       url('webfont.woff') format('font-woff'), /* Pretty Modern Browsers */
       url('webfont.ttf')  format('truetype'), /* Safari, Android, iOS */
       url('webfont.svg#svgFontName') format('svg'); /* Legacy iOS */
}

Пожалуйста, проверьте, если ваш браузер может открыть его и какой тип


7
неправильный формат font-woff, он должен читать "woff". И с этим, Chrome рассматривает шрифт woff как неизвестный формат и переходит к следующему лучшему формату (вероятно, ttf из woff2 здесь)
Артур

Большое спасибо, с этим решением я смог решить проблему и с другими форматами (ttf, woff2, ...).
Далеко

5
К сожалению, этот ответ неверен. Может быть неясно, что говорит @Arthur, но если вы измените имя формата шрифта, браузер буквально проигнорирует шрифт, потому что он не регистрируется как шрифт. В инструменте проверки Chrome (F12) перейдите на вкладку « Приложение », затем выберите «Кадры»> «Верх»> «Шрифты». Попробуйте использовать это решение, и вы увидите, что шрифты будут удалены. Я редко использую отрицательные голоса на SO, но в этом случае ответ на самом деле ухудшает читателей, потому что они могут подумать, что они решили проблему, но только замаскировали ее.
Андре С. Андерсен

Это решило мою проблему с импортом woff-файлов в проект Nextjs! Большое спасибо!
Тхань-Куи Нгуен

Как говорит @ AndréC.Andersen, ЭТОТ ОТВЕТ ТОЛЬКО ЗАКРЫВАЕТ ПРОБЛЕМУ И НЕ ИСПРАВЛЯЕТ .
ДжонК

12

Убедитесь, что ваш сервер отправляет файлы шрифтов с правильным MIME / тип .

Недавно у меня возникла та же проблема с использованием nginx, потому что некоторые типы шрифтов mime отсутствуют в его ванильном /etc/nginx/mime.typesфайле.

Я исправил проблему, добавив недостающие типы пантомимы в то место, где они были мне нужны:

location /app/fonts/ {

  #Fonts dir
  alias /var/www/app/fonts/;

  #Include vanilla types
  include mime.types;

  #Missing mime types
  types  {font/truetype ttf;}
  types  {application/font-woff woff;}
  types  {application/font-woff2 woff2;}
}

Вы также можете проверить это для расширения mime.types в nginx: расширение файла nginx mime.types по умолчанию


12

Я должен был добавить type="text/css"к моей ссылке тег. Я изменил это с:

<link href="https://fonts.googleapis.com/css?family=Roboto+Condensed:300,400,700" rel="stylesheet">

чтобы:

<link href="https://fonts.googleapis.com/css?family=Roboto+Condensed:300,400,700" rel="stylesheet" type="text/css">

После того, как я изменил его, ошибка исчезла.


Спасибо, это работает. Так что, если кто-то загружает шрифты из Google, просто добавьте это, type="text/css"и предупреждающее сообщение в консоли браузера исчезло после «жесткого» обновления
lewis4u


6

Для меня эта ошибка произошла, когда я ссылался на шрифт Google, используя https. Когда я переключился на http, ошибка ушла. (и да, я пробовал это несколько раз, чтобы подтвердить, что это было причиной)

Итак, я изменился:

@import url(https://fonts.googleapis.com/css?family=Roboto:300,400,100,500,900);

Для того, чтобы:

@import url(http://fonts.googleapis.com/css?family=Roboto:300,400,100,500,900);

3
Я также получал ту же ошибку со шрифтами Google, когда я сделал полную перезагрузку, проблема была решена автоматически!
Маулик Гангани,

1
-1, прости. следует не использовать падение httpsподдержки для этого! Это делает ваш сайт небезопасным . Наблюдательные работы @MaulikGangani! Подумайте о том, чтобы включить его в свой ответ
Ciprian Tomoiagă

4

Иногда эта проблема возникает, когда вы загружаете / скачиваете шрифты, используя неверный метод FTP. Шрифты должны быть обработаны по FTP с использованием двоичного метода, а не ASCII. (В зависимости от вашего настроения, это может показаться нелогичным, смеется). Если вы загрузили файлы шрифтов, используя метод ASCII, вы можете получить это сообщение об ошибке. Если вы выполняете ftp-файлы с помощью метода «auto» и получаете это сообщение об ошибке, попробуйте ftp принудительно применить двоичный метод.


3

У меня была та же проблема со шрифтом awesome v4.4, и я исправил его, удалив формат woff2. Я получал предупреждение только в Chrome.

@font-face {
  font-family: 'FontAwesome';
  src: url('../fonts/fontawesome-webfont.eot?v=4.4.0');
  src: url('../fonts/fontawesome-webfont.eot?#iefix&v=4.4.0') format('embedded-opentype'), url('../fonts/fontawesome-webfont.woff?v=4.4.0') format('woff'), url('../fonts/fontawesome-webfont.ttf?v=4.4.0') format('truetype'), url('../fonts/fontawesome-webfont.svg?v=4.4.0#fontawesomeregular') format('svg');
  font-weight: normal;
  font-style: normal;
}

1
Да! Я удалил формат ('woff2') и удалил предупреждения. Спасибо.
duyn9uyen

3

В моем случае это было вызвано неверным путем, в .htaccess. пожалуйста, проверьте правильность вашего пути к файлу.


2

Для меня ошибкой было забыть перевести FTP в двоичный режим перед загрузкой файлов шрифтов.

редактировать

Вы можете проверить это, загрузив другие типы двоичных данных, таких как изображения. Если они также не отображаются, то это может быть вашей проблемой.


Есть еще один термин для этого? Я не могу найти эту опцию ни в одном из моих FTP-клиентов.
Саркома

Я знаю только термины BIN и ASCII из браузеров командной строки * nix. Я предполагаю, что многие современные FTP-клиенты будут знать, какие файлы являются двоичными, а какие нет, поэтому, возможно, это не ваша проблема. Если вы хотите проверить, отправляет ли ваш FTP-клиент в двоичном режиме, используйте FTP для перемещения двоичных данных, например .jpg, а затем попробуйте просмотреть их. Если он был отправлен в режиме ASCII, он не будет отображаться. (См. Jscape.com/blog/… )
Роберт

Ах, я вижу, спасибо за объяснение. Все изображения, которые я загружаю, в порядке, в конце концов я нашел бинарный режим в FileZilla, к сожалению, он мне не помог. Я не смог найти вариант в PHP Storm для двоичного кода, но, как я уже сказал, изображения в порядке, поэтому я предполагаю, что это не та проблема, которая у меня возникла.
Саркома

1

У меня также была такая же проблема, но я решил добавить Content-Type: application / x-font-ttf в заголовок ответа для всех файлов .ttf.


1
как это сделать?
Baim Wrong

1

В моем случае это было вызвано созданием файла исправления SVN, который включал добавление файлов шрифтов. Вот так:

  1. Добавить файлы шрифтов из локальной файловой системы в подрывную магистраль
  2. Багажник работает как положено
  3. Создать SVN патч изменений ствола, чтобы включить добавление файлов шрифтов
  4. Применить патч к другой ветке
  5. Файлы шрифтов добавляются в подрывную ветвь (и могут быть зафиксированы), но они повреждены, что приводит к ошибке в OP.

Решением было загрузить файлы шрифтов прямо в ветку из моей локальной файловой системы. Я предполагаю, что это произошло потому, что файлы исправлений SVN должны преобразовывать все в формат ASCII и не обязательно сохранять двоичные файлы шрифтов. Но это только предположение.


1

В моем случае - используя React с Гэтсби - проблема была решена двойной проверкой всех моих путей. Я использовал React / Gatsby с Sass, и исходные файлы Gatsby искали шрифты в другом месте, чем скомпилированные файлы. После того, как я продублировал файлы в каждом пути, эта проблема исчезла.


1

В моем случае при загрузке шаблона файлы шрифтов были просто пустыми файлами. Вероятно, проблема с загрузкой. Хром дал эту общую ошибку об этом. Сначала я подумал о том, чтобы перейти от решения woffк font-woffрешению, но это только заставило Chrome игнорировать шрифты. Моим решением было найти шрифты один за другим и загрузить / заменить их.


0

Если вы используете экспресс, вам нужно разрешить показ статического контента, добавив что-то вроде: var server = express (); server.use (express.static ( './ общественности')); // где public - это корневая папка приложения с содержащимися в ней шрифтами на любом уровне, т. е. public / fonts или public / dist / fonts ... // Если вы используете connect, Google для аналогичной конфигурации.


0

Я использую .Net Framework 4.5 / IIS 7

Чтобы исправить это, я положил файл Web.config в папку с файлом шрифта.

Содержимое Web.config:

<?xml version="1.0"?>
<configuration>
  <system.web>
    <authorization>
      <allow users="*" />
    </authorization>
  </system.web>
</configuration>


0

Если он находится на сервере (не на локальном хосте), попробуйте загрузить шрифты вручную, потому что иногда FTP-клиент (например, FileZilla) повреждает файлы, и это может вызвать проблему. Для меня я загрузил вручную, используя интерфейс Cpanel.


0

Мой случай выглядел похожим, но шрифт был поврежден (и поэтому невозможно декодировать). Это было вызвано конфигурацией в Maven. Мне помогло добавление nonFilteredFileExtension для расширений шрифтов maven-resources-plugin:

<plugin>
    <groupId>org.apache.maven.plugins</groupId>
    <artifactId>maven-resources-plugin</artifactId>
    <configuration>
        <nonFilteredFileExtensions>
            <nonFilteredFileExtension>ttf</nonFilteredFileExtension>
            <nonFilteredFileExtension>otf</nonFilteredFileExtension>
            <nonFilteredFileExtension>woff</nonFilteredFileExtension>
            <nonFilteredFileExtension>woff2</nonFilteredFileExtension>
            <nonFilteredFileExtension>eot</nonFilteredFileExtension>
        </nonFilteredFileExtensions>
    </configuration>
</plugin>
Используя наш сайт, вы подтверждаете, что прочитали и поняли нашу Политику в отношении файлов cookie и Политику конфиденциальности.
Licensed under cc by-sa 3.0 with attribution required.