74.根路径总是被访问两次,都是favicon.ico惹出来的

厚土火烟 · · 4621 次点击 · · 开始浏览    
这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。

在使用golang做web开发的时候,如果在根路径上直接输出内容,你会发现,你的访问总是被执行 2 次。
根路径的 handler 是这个样子的

func indexHandler(writer http.ResponseWriter, request *http.Request) {
    tms := time.Now().Format("2006-01-02 15:04:05.00000000")
    fmt.Println(tms,"Yes you in path: ",)
    fmt.Fprintln(writer, tms,"你正在访问的路径:index")
}

可是执行效果是这样的
服务器显示


服务器显示效果

web界面显示


web界面显示

很显然,这样的服务器显示会对维护人员造成困扰。
这个多出来的一次访问,是因为每当我们访问一个web站点的根路径时,会默认的访问寻找一下 favicon.ico 文件。对,就是我们常见的网站网址前面的那个小图标。
如果你的web站点包含这样的小图标了。

需要在模板页面中指定此图标的路径,这个问题就没有了。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>后台管理界面</title>
    <link rel="icon" href="/userLogin/css/favicon.ico" type="image/x-icon" />
</head>
<body>
{{.}}
</body>
</html>

执行结果


只显示一次

如果没有ico文件,也可以通过代码回避这个问题。

    //取消获取facicon.ico的访问
    if request.RequestURI == "/facicon.ico" {
        return
    }

这段代码添加到根路径对应的handler中即可。
这样,你就不用担心,在跟路径页面上的访问记录会多一次的事情了。


有疑问加站长微信联系(非本文作者)

本文来自:简书

感谢作者:厚土火烟

查看原文:74.根路径总是被访问两次,都是favicon.ico惹出来的

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

4621 次点击  ∙  1 赞  
加入收藏 微博
1 回复  |  直到 2019-01-08 18:45:57
暂无回复
添加一条新回复 (您需要 登录 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传