前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >django 配置 favicon

django 配置 favicon

作者头像
kirin
发布2021-02-22 10:51:39
1.8K0
发布2021-02-22 10:51:39
举报
文章被收录于专栏:Kirin博客Kirin博客

起步

默认情况下,浏览器会访问网站 "/favicon.ico" 这个地址获取网站的图标。如果没有配置的话,Django 会返回一个 404 错误。这对于强迫症的人来说,真的很烦。我们有现有的图标,且按开发规范一般存放 static/ 下。

网上的方法

网上找了大概两种处理方式,但都不够优雅。

方法一:使用重定向

在项目的 urls.py 中添加规则:

代码语言:javascript
复制
from django.urls import path
from django.views.generic.base import RedirectView

urlpatterns=[
    ...
    path('favicon.ico', RedirectView.as_view(url='static/img/favicon.ico')),      
]

这种方式我认为是最不好的一种方式,它会让浏览器产生一个新的请求。

方法二:指定图标地址

这种方法就是告诉浏览器,网站图片的正确地址,因此需要在模板中的头部指定:

代码语言:javascript
复制
{% load staticfiles %}
<head lang="zh">
    <meta charset="UTF-8">
    <link rel="shortcut icon" href="{%static "img/favicon.ico"  %}" /> <!-- 添加这行 -->
    <title></title>
</head>

这种方法也挺好的。但我还是想从 /favicon.ico 这个地址中解决这个问题。

最优雅的方式

django 有自己的静态文件的处理方法,那就可以设置 url 规则,返回某个静态文件的:

代码语言:javascript
复制
from django.contrib.staticfiles.views import serve

urlpatterns = [
    ...
    path('favicon.ico', serve, {'path': 'img/favicon.ico'}),
]

从根本上解决还不反弹,很棒,很好很强大。

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2021-02-04 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 起步
  • 网上的方法
  • 最优雅的方式
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档