CSS 파일(등)이 로드되고 있는데 반영되지 않는다! ! (Resource interpreted as Stylesheet but transferred with MIME type text/plain)
증상
개인이 운영하는 서비스의 인프라 주변을 완전히 잡는 작업 중에 발생했습니다.
환경은 Rails + Nginx on GKE 같은 느낌입니다.
data:image/s3,"s3://crabby-images/7ad48/7ad487e46b18e83935202934bb2a0f2bf8691f29" alt=""
그림과 같이 CSS가 전혀 맞지 않고, 처음에는 서버의 설정 실수로 에셋 파일이 제공되지 않았는지 생각했습니다만, 잘 보면 에셋은 모두 200 OK로 읽혀지고 있습니다.
data:image/s3,"s3://crabby-images/4e578/4e578671dc9ebff3c624171d6853bb74247a92d1" alt=""
(inkscape로 그리는 것이 들키는 버림 ...)
또한 JPG와 PNG와 같은 일부 이미지 만 정상적으로 표시되고 CSS, SVG, JS는 표시되지/반영되지 않는 이상한 현상입니다.
원인과 해결책
위 이미지의
Type
부분을 잘 보면 알 수 있지만 titlelogo
라는 svg 파일의 Type이 text/plain
입니다.data:image/s3,"s3://crabby-images/86009/86009b1011b321e332fad0b751214a6a1895d449" alt=""
이 Type(MIME Type)이 일치하지 않으면 데이터가 완전하더라도 정상적으로 표시되지 않는 것 같습니다. (처음 알았다)
잘 보면 Console에도
Resource interpreted as Stylesheet but transferred with MIME type text/plain
라는 경고가 나왔습니다. (Error가 아니라 Warning이므로 좀처럼 알아차리기 어렵다)data:image/s3,"s3://crabby-images/7ce94/7ce94ae8ef91b9df89372f0a9be34991eb808bfd" alt=""
왜 갑자기 이러한 증상이 나왔는가 하면, 인프라 주위를 전부 파악할 때에 nginx.conf를 재작성한 것이 원인이었습니다. MIME Type을 확장자로부터 판별하기 위한 이하의 2행을 붙여 잊어버렸습니다.
/etc/nginx/nginx.conf
include mime.types;
default_type application/octet-stream;
1행째는
nginx.conf
와 같은 계층에 있는, 확장자와 MIME Type의 페어를 나열하고 있는 mime.types
를 읽어들이는 코드입니다.2행째는
mime.types
에 기재되지 않은 데이터를 「알 수 없는 바이너리 데이터」를 의미하는 application/octet-stream
로서 취급하기 위한 코드입니다. (이것을 붙이면 브라우저가 어느 정도 좋게 취급 해 준다? 미 검증)그래서 무사히 CSS나 SVG가 표시되게 되었습니다.
data:image/s3,"s3://crabby-images/625d6/625d636392053b0ec82a599cca39c59c5e583fb5" alt=""
죄송합니다.
이번에 사용한 nginx.conf 전문
다음에 이번에 정상적으로 표시된 nginx.conf 전문을 실어 둡니다.
전제는 다음과 같습니다.
- Rails
public/
를 /var/www/static_files/
에 mount하고 있다- Rails 컨테이너는 동일한 Pod의 3000 포트에서 시작됩니다.
- SSL 통신에 관해서는 Ingress상에서 해결하고 있다
/etc/nginx/nginx.conf
events {
worker_connections 1024;
}
http{
charset UTF-8;
server_tokens off;
sendfile on;
tcp_nopush on;
tcp_nodelay on;
keepalive_timeout 65;
types_hash_max_size 2048;
include mime.types;
default_type application/octet-stream;
server{
listen 80;
# Rooting for /public
location / {
root /var/www/static_files;
try_files $uri @rails;
}
# Rooting for rails
location @rails {
proxy_pass http://localhost:3000;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
}
}
}
Reference
이 문제에 관하여(CSS 파일(등)이 로드되고 있는데 반영되지 않는다! ! (Resource interpreted as Stylesheet but transferred with MIME type text/plain)), 우리는 이곳에서 더 많은 자료를 발견하고 링크를 클릭하여 보았다 https://qiita.com/furikake6000/items/fb97779659dddfc2c196텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
우수한 개발자 콘텐츠 발견에 전념
(Collection and Share based on the CC Protocol.)