Web静态资源访问鉴权实现思路

1.背景

前端时间公司的测试产品的时候,曾经发现一个问题未登录鉴权的js,在知道其访问路径的情况下也可以访问,这违反了公司的安全要求,要求研发整改

2 思考

事实上,在web端,使用apache作为服务器,一般放在公开目录,所有用户都可以不鉴权就可以访问,要实现js鉴权访问,那么每次访问js必须访问到控制器,在控制器的方法里面写鉴权逻辑

3 方案

方案一

利用apache的.access文件重写规则,将需要的鉴权的js 重定向到一个指定的方法中进行鉴权

  RewriteEngine on   #开启mod_rewrite模块功能
  RewriteRule .*.(js)$ http://www.111cn.net/ [L]  

这种方案js每次访问都会请求两次,有点消耗性能

方案二

假设把需要进行鉴权的文件放到不公开的目录,对外不能直接访问,提供公共访问的接口来读取js,页面通过请求这个接口加载js的内容

这种方式可以解决方案一的缺点,但是这种方式改动的文件有点多,但是还存在一个问题,就是JS每次都是从服务端获取,浏览器客户端都不会缓存。解决这个问题,需要返回的javascript的请求头中添加一个属性

Cache-Control:max-age=36000

这样Javascript便可以缓存,加载更加迅速

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值