zoukankan      html  css  js  c++  java
  • 防盗链之URL参数签名 总结

    一、概述

      传统的 IP 禁用、referer 防盗链、User-Agent 防盗链、地区访问控制等防盗链措施已经无法完全满足用户要求,所以开发出URL参数签名方式来防盗链

    二、实现

      Token防盗链是通过对时间有关的字符串进行签名,将时间、签名信息通过一定的方式传递给 web server节点服务器作为判定依据,web server节点依据约定的算法判断来访的 URL 是否有访问权限。如果通过,执行下一步;如果不通过,响应 HTTP 403 状态码或者通过 302 跳转到其他 URL。

      1、签名参数

        etime: URL 过期的时间,必须是 UNIX TIME 格式,如:2017/3/9 9:19:0 -> 1489022340

        secret: 和 平台约定的签名密钥,需要在 平台后端管理控制台配置,(服务->  配置 -> 防盗链 -> Token 防盗链);

      2、算法:

        sign = MD5( secret & etime & URI )

        Token = MD5( secret & etime & URI ){ 中间 8 位 } + etime

      假设当前的 UNIX TIME 时间为:1370000000,某图片资源(例如:http://test.example.com/dir/pic.jpg)10 分钟有效,则:

        etime = 1370000000 + 600 = 1370000600

        uri = '/dir/pic.jpg'

        sign = MD5( secret & etime & URI ) = xxxxxxxxxxxxabcdefghyyyyyyyyyyyy

        Token  = MD5( secret & etime & URI ){ 中间 8 位 } + etime = abcdefgh1370000600

      最后经过客户端业务服务器生成的 URL 为:

        http://test.example.com/dir/pic.jpg?token=abcdefgh137000060

     三、验证

    • 根据约定解析取出过期时间,和当前 web Server节点服务器时间进行比较,确认请求是否过期

    • 根据上文约定好的算法计算方式,计算出 MD5 加密串后,和 URL 中的加密串进行比较,验证加密串是否一致

    • 如果以上两个步骤都验证通过,请求才会被认为是合法的,这时 web server 会请求资源响应给客户端,否则会被认为是非法请求,直接响应 HTTP status code 403

  • 相关阅读:
    分段随机实践—模拟线上流量
    基于docker的分布式性能测试框架功能验证(二)
    将博客搬家至CSDN
    考研机试 98.棋盘游戏
    考研机试 100.路径打印
    考研机试 102.计算表达式
    考研机试 97.数字反转
    考研机试 90.简单密码
    考研机试 87.鸡兔同笼
    考研机试 79.浮点数加法
  • 原文地址:https://www.cnblogs.com/chris-cp/p/8012831.html
Copyright © 2011-2022 走看看