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

前言

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协议无关,与浏览器处理有关。vue

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

想办法解决呀

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

url上带query参数

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

添加HSTS

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

add_header strict-transport-security max-age=31536000;
复制代码

Update: 20180615

能够在这里试了下不一样浏览器http的301带hash跳转web


打个广告

公司如今急招前端开发,坐标深圳南山,有兴趣的能够看这里,直接把简历发我邮箱吧。teal.yao@corp.to8to.comvue-router

相关文章
相关标签/搜索