互联网繁荣昌盛的今天,离不开核心技术团队的支持。就拿防止非法盗链来说吧,如果任意来源请求都可以盗链自己服务器的资源,那么将会降低企业的行业竞争力,还会导致企业为额外的非法流量买单。就此问题,光网烈火科技部上线了内部的资源鉴权服务器,可有效防止非法用户盗链光网资源,用户可查看演示地址,这种方法不仅适用于压缩包文件下载保护,也适用于音频、视频的有效保护,相比以前的referer防盗技术,此方法更为有效。

那么,什么是资源鉴权呢?鉴权功能用于保护用户站点资源不被非法下载盗用,并减少带宽资源的浪费,用于当其他防盗链方式(例如:IP禁用、referer 防盗链、UA 防盗链等)无法满足资源保护的高实时性及高安全性要求时的使用场景,所以它是一种更为安全可靠防盗方法。

目前阿里也在自己的CDN节点,部署了CDN鉴权功能。在接收到终端用户请求时,都需要去客户的鉴权服务器进行验证,验证通过之后才认为是合法请求,否则就会鉴权不通过,直接拒绝访问。从而实现有效保护用户站点资源。这里我们需要一台属于自己的鉴权服务器。由CDN客户站点提供给用户加密 URL (包含权限验证信息),用户使用加密后的 URL 向加速节点发起请求,加速节点对加密 URL 中的权限信息进行验证以判断请求的合法性,对合法请求给予正常响应,拒绝非法请求,从而有效保护CDN客户站点资源。

实战部署

下面,就发布出阿里CDN鉴权服务器中,需要部署的PHP代码片段给大家:

鉴权方式A

//http://DomainName/Filename?auth_key=timestamp-rand-uid-md5hash
//sstring = "URI-Timestamp-rand-uid-PrivateKey" (URI是用户的请求对象相对地址, 如 /Filename)
//HashValue = md5sum(sstring)
function PrivateKeyA(){
                  $time=strtotime("+8 hours");
                  $key="private.key";
                  $domain="https://www.lighttp.com";
                  $filename="/download/stream.mp4";
                  //$sstring = "URI-Timestamp-rand-uid-PrivateKey"
                  $sstring = $filename."-".$time."-0-0-".$key;
                  $md5=md5($sstring);
                  $auth_key="auth_key=".$time."-0-0-".$md5;
                  $url=$domain.$filename."?".$auth_key;
                  echo $url."\n";
}

鉴权方式B

//http://DomainName/timestamp/md5hash/FileName
//timestamp:用户访问时客户源服务器的时间,作为URL的一部分,同时作为计算 md5hash 的一个因子,格式为:YYYYMMDDHHMM ,有效时间1800s
//md5hash:以timestamp、FileName和预先设定好的 PrivateKey 共同做MD5获得的字符串,即 md5(PrivateKey + timestamp + FileName)
function PrivateKeyB(){
                  $time=date("YmdHi");
                  $key="private.key";
                  $domain="https://www.lighttp.com/";
                  $filename="/download/stream.mp4";
                  //$sstring = "PrivateKeytimestampFileName"
                  $sstring = $key.$time.$filename;
                  $md5=md5($sstring);
                  $url=$domain.$time."/".$md5.$filename;
                  echo $url."\n";
}

鉴权方式C

//http://DomainName/{/}/FileName
//md5hash = md5sum()
//time: 用户访问源服务器时间,取 UNIX 时间,以十六进制数字字符表示。
function PrivateKeyC(){
                  $time2=dechex(time());
                  $key="private.key";
                  $domain="https://www.lighttp.com/";
                  $filename="/download/stream.mp4";
                  //$sstring=PrivateKeyFileNametime
                  $sstring=$key.$filename.$time2;
                  $md5=md5($sstring);
                  $url=$domain.$md5."/".$time2.$filename;  
                  echo $url."\n";
}

注意事项

1.使用回源鉴权功能,每次请求都要鉴权,访问量大时,需考虑鉴权服务器的压力;

2.合法请求时,鉴权服务器需要响应合法的鉴权状态码或响应体,否则会鉴权失败;

3.可根据域名设置匹配规则添加多条鉴权配置;

4.匹配时依据序号由低到高开始逐条匹配,使用最早匹配上的规则配置进行鉴权。

鉴权错误都是返回 403
Md5计算类错误:
X-Lighttp-Com-Error:denied by req auth: invalid md5hash=de7bfdc915ced05e17380a149bd760be
时间类报错:
X-Lighttp-Com-Error:denied by req auth: expired timestamp=1439469547

技术分享:什么是CDN鉴权(by光网烈火)相关推荐

  1. CRM——验证码(JWT技术)、接口资源鉴权

    目录 1.登录 1.1登录验证 1.2JWT简介 是什么 什么用 组成 1.3生成JWT 1.4 使用JWT生成token 2.接口资源鉴权 1.登录 前端会保存用户的UUID(后端自动生成的作为验证 ...

  2. CDN > 域名管理 > 访问控制 > URL鉴权配置 > URL鉴权

    URL鉴权 更新时间:2020-03-05 18:09:03 编辑我的收藏 URL鉴权功能主要用于保护用户站点的资源不被非法站点下载盗用.通过防盗链方法添加Referer黑名单和白名单的方式可以解决一 ...

  3. 前端开发:关于鉴权的使用总结

    前言 前端开发过程中,关于鉴权(权限的控制)是非常重要的内容,尤其是前端和后端之间数据传递时候的请求鉴权校验.前端鉴权的本质就是控制前端视图层的显示和前端向后台所发送的请求,但是只有前端鉴权,没有后端 ...

  4. mysql ip鉴权_网站登录鉴权的实现

    什么是网站鉴权,目的是什么? 一般来说,一个网站不可能只有一种操作权限.举个例子,可能存在未登录的操作权限,登录的操作权限,以及管理 员的操作权限等.网站鉴权的目的就是用户在进行操作前,对用户的身份进 ...

  5. 技术分享|明源云天际集成开放平台接口中心基于IdentityServer4的鉴权机制

    源宝导读:企业数字化生态建设中为解决集成多样性和资源统一管理的痛点引入企业级网关,网关作为资源访问的大门,身份认证鉴权是其业务的重中之重,本文将介绍企业级网关-天际集成开放平台是如何通过Identit ...

  6. 技术探究|Apache Pulsar 认证与鉴权实践指南

    文章摘要 本文整理自 2022 年 8 月 Apache Pulsar Meetup 上傅腾题为<Apache Pulsar 企业级安全实践>的分享.数据安全已经成为企业的一项重要竞争优势 ...

  7. 微服务架构下的服务调用与鉴权——某保险公司微服务平台实施案例分享

    2019独角兽企业重金招聘Python工程师标准>>> 转载本文需注明出处:EAWorld,违者必究. 引言: 根据保险行业发展趋势,目前保险交易已经呈现高频化.碎片化.场景化等特点 ...

  8. 云服务器的CDN域名的远程鉴权配置,基于 Python

    实战场景 在项目实战中,会碰到一种特定的运维场景,对CDN访问进行限制,一般手段是开启 referer 防盗链,开启 IP黑白名单,开启UA黑白名单,本篇博客为大家展示的是通过我们自己的服务器,然后实 ...

  9. 实战美团Nuxt +Vue全家桶,服务端渲染,邮箱验证,passport鉴权服务,地图API引用,mongodb,redis等技术点

    koa koa-generator 直接创建koa项目,不需要自己配置 全局安装 npm i -g koa-generator 创建项目 koa2 -e project 其中-e 表示以ejs为模板 ...

最新文章

  1. Linux实时监控工具Nmon使用
  2. SSD成就了《扩散性百万亚瑟王》
  3. mysql for centos下载_python数据分析之路——centos下载并配置mysql与navicat的使用
  4. VTK:Utilities之CameraModifiedEvent
  5. Java EE拦截器
  6. 【 CodeForces - 1060B 】Maximum Sum of Digits(思维,构造)
  7. [Go] Template 使用简介
  8. iOS - UITableView reloadData滚动到顶部无效问题解决
  9. if vue 跳出_vue实现弹框遮罩点击其他区域弹框关闭及v-if与v-show的区别介绍
  10. storage theory
  11. python如何删除对象属性_如何销毁python中属性中的对象?
  12. 一个奇怪的DNS服务器故障
  13. android studio for android learning (六)在布局中常使用的单位
  14. 初级工程师该如何去学习,如何去研发开关电源?
  15. pyqt QTableView详细用法
  16. 生成自己的自签名证书
  17. 解决Rstudio打开空白
  18. mac 重启 ssh 服务
  19. 手绘 | 我说话直,你别介意——我呸!
  20. RTK模块性能测试分析对比-GNSS实测- RTK板卡100赫兹延迟实测及分析

热门文章

  1. Java线程池的工作原理与实现
  2. C#-datagriview的表头高度的设置
  3. JadePool应用范例:创建China软件项目
  4. NOD32客户端更新文件
  5. Enterprise Library Step By Step系列(一):配置应用程序块——入门篇
  6. CodeForces - 1350E Orac and Game of Life(bfs)
  7. 2019ICPC(南昌) - Fire-Fighting Hero(最短路+思维)
  8. php 聚类算法,科学网—matlab-聚类算法笔记 - 孙月芳的博文
  9. 排序算法-07归并排序(python实现)
  10. HDU3183(RMQ问题,ST算法)