前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >从301跳转看vue-router的hash模式

从301跳转看vue-router的hash模式

作者头像
用户2845596
发布2021-01-21 15:08:02
1K0
发布2021-01-21 15:08:02
举报
文章被收录于专栏:劝学

前言

vue-router的模式默认是hash的,另外还有historyabstract。想要设置为在这里

代码语言:javascript
复制
let router = new VueRouter({
    mode: 'history',
    routes: []
})

那默认的hash模式有什么潜在的弊端呢,直到站点切https时,用到了301的跳转,从http://domain.com/path/to#fragment跳转到https://domain.com/path/to#fragment,那服务器是不认hash值的,我们看301的http responseLocation: https://domain.com/path/to,并没有#fragment呀,那浏览器是自动加上的咯。

问题本质

其实这是一个浏览器的Bug,只是后来被修复了而已。这是与HTTP协议无关,与浏览器处理有关。

像QQ浏览器fork了webkit内核后,后续并没有同步修改这个Bug,导致url的hash部分,301跳转后就丢失了。所以这也算是vue-router设置为hash模式的一个坑吧。

想办法解决呀

那有什么办法解决呢,本人想到的办法,有其它更好想法的,欢迎在下面留言

url上带query参数

需要有分享链接的页面,可以定义特殊的query参数,由nginx或apache接收query参数后,在Location里返回hash部分 http://domain.com/path/to?hash=/fragment => Location: https://domain/path/to#/fragment

添加HSTS

没错,HSTS就是HTTP Strict Transport Security。这里是MDN的具体文档。服务器设置如下头部,浏览器就会强制使用https来访问,而不用需要额外发送一次http接收301定向了

代码语言:javascript
复制
add_header strict-transport-security max-age=31536000;
Update: 20180615

可以在这里试了下不同浏览器http的301带hash跳转

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

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

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

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

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 前言
  • 问题本质
  • 想办法解决呀
    • url上带query参数
      • 添加HSTS
        • Update: 20180615
        领券
        问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档