码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 实现fastdfs防盗链功能


    目录
    • 1、背景
    • 2、实现原理
      • 2.1 开启防盗链
      • 2.2 重启 nginx
      • 2.3 Java代码生成token
        • 1、token生成规则
        • 2、java生成token
    • 3、测试
      • 3.1 带正确token访问
      • 3.2 带错误token访问
    • 4、项目代码
    • 5、参考链接

    1、背景

    我们可以通过fastdfs实现一个分布式文件系统,如果我们的fastdfs部署在外网,那么任何一个人知道了我们的上传接口,那么它就可以文件的上传和访问。那么我们如何阻止他人访问我们fastdfs服务器上的文件呢?此处就需要使用fastdfs的防盗链功能。

    2、实现原理

    fastdfs的防盗链是通过token机制来实现的。当我们开启防盗链功能后,需要在url后增加2个额外的参数token和ts。token和ts的生成都是需要在服务端。

    2.1 开启防盗链

    vim /etc/fdfs/http.conf

    # true 表示开启防盗链
    http.anti_steal.check_token = true
    # token的过期时间,单位为秒
    http.anti_steal.token_ttl = 60
    # 密钥,不可泄漏,用于生成token
    http.anti_steal.secret_key = thisisasecuritykey
    # 当图片拒绝访问后,显示的图片,此图片需要可访问,不然可能会出现问题
    http.anti_steal.token_check_fail = /data/fastdfs/401.jpg

    http.anti_steal.token_check_fail 指定的图片需要可访问,否则可能会出现问题

    2.2 重启 nginx

    /usr/local/nginx/sbin/nginx -s reload

    2.3 Java代码生成token

    1、token生成规则

    token = md5(文件ID+私钥+时间戳)

    文件ID:不能包含group

    group1/M00/00/00/wKh5iWNBl7-AKvj1AAAwWD4VeAg577.jpg
    `需要替换成`
    M00/00/00/wKh5iWNBl7-AKvj1AAAwWD4VeAg577.jpg

    私钥:需要和 /etc/fdfs/http.conf 中的 http.anti_steal.secret_key 值一致
    时间戳:单位秒

    2、java生成token

    /**
    * 生成token
    *
    * @param fileId the filename return by FastDFS server,不能含有组
    * @param timestampSecond 时间戳 单位秒
    * @return token
    * @throws NoSuchAlgorithmException
    */
    private String generatorToken(String fileId, Long timestampSecond) throws NoSuchAlgorithmException {
    // 需要去掉 group
    fileId = fileId.substring(fileId.indexOf("/") + 1);
    byte[] bsFilename = fileId.getBytes(StandardCharsets.UTF_8);
    byte[] bsTimestamp = timestampSecond.toString().getBytes(StandardCharsets.UTF_8);
    // thisisasecuritykey 需要和 /etc/fdfs/http.conf 中的 http.anti_steal.secret_key 值一致
    byte[] bsKey = "thisisasecuritykey".getBytes(StandardCharsets.UTF_8);
    byte[] buff = new byte[bsFilename.length + bsKey.length + bsTimestamp.length];
    System.arraycopy(bsFilename, 0, buff, 0, bsFilename.length);
    System.arraycopy(bsKey, 0, buff, bsFilename.length, bsKey.length);
    System.arraycopy(bsTimestamp, 0, buff, bsFilename.length + bsKey.length, bsTimestamp.length);
    return md5(buff);
    }
    public static String md5(byte[] source) throws NoSuchAlgorithmException {
    char hexDigits[] = {'0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'a', 'b', 'c', 'd', 'e', 'f'};
    java.security.MessageDigest md = java.security.MessageDigest.getInstance("MD5");
    md.update(source);
    byte tmp[] = md.digest();
    char str[] = new char[32];
    int k = 0;
    for (int i = 0; i < 16; i++) {
    str[k++] = hexDigits[tmp[i] >>> 4 & 0xf];
    str[k++] = hexDigits[tmp[i] & 0xf];
    }
    return new String(str);
    }

    3、测试

    3.1 带正确token访问

    带正确token访问

    3.2 带错误token访问

    带错误token访问

    这个地方返回的图片是 http.anti_steal.token_check_fail = /data/fastdfs/401.jpg 这个配置中配置的图片。

    4、项目代码

    https://gitee.com/huan1993/spring-cloud-parent/tree/master/springboot/springboot-fastdfs

    5、参考链接

    1. 使用FastDFS的内置防盗链功能官方文章 http://bbs.chinaunix.net/thread-1916999-1-1.html
    2. fastdfs faq http://bbs.chinaunix.net/thread-1920470-1-1.html
  • 相关阅读:
    css步骤条
    【小程序】实现经典2048小游戏
    jsp科研管理系统Myeclipse开发mysql数据库web结构java编程计算机网页项目
    C语言进阶——深度剖析数据在内存中的存储
    VPN的不同种类及现网应用场景
    C primer plus学习笔记 —— 12、宏定义
    (JavaEE) 多线程基础3——多线程的代码案例 (单例模式, 阻塞队列,定时器)详解!!!
    java版工程管理系统Spring Cloud+Spring Boot+Mybatis实现工程管理系统源码
    Android 消息恢复 - 如何在 Android 上检索已删除的短信
    如何向客户推广 API 商品数据接口,如何跟进项目和程序员对接?
  • 原文地址:https://www.cnblogs.com/huan1993/p/16773595.html
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号