Next.js 集成防盗链功能的解决方案

什么是防盗链?

防盗链是指通过一些措施,防止你的图片、视频等媒体资源被其他网站非法使用。

一般情况下,我们需要在服务端对 HTTP 请求头中的 Referer(来自哪个页面) 进行判断,如果请求头中的 Referer 值不是当前站点的域名,则可以认为是盗链行为。此时,我们可以通过服务端响应状态码或者返回一张仅包含「禁止盗链」图片的响应内容给请求者。

Next.js 中如何实现防盗链?

Next.js 作为一个流行的 React 框架,本身并没有集成防盗链的功能。但是,我们可以通过使用 node.js 中的 http 模块来完成防盗链的功能。下面,我们就来详细介绍一下如何在 Next.js 中实现防盗链的功能。

Step 1: 安装依赖包

为了实现防盗链的功能,我们需要安装一些依赖包。在 Next.js 项目的根目录下,执行以下命令:

--- - ---- --- -- ------

其中,http 模块是 Node.js 自带的一个模块,用于处理 HTTP 请求和响应。url 模块则是 Node.js 自带的一个模块,用于解析并处理 URL。fs 模块是 Node.js 中的一个模块,用于文件的读写。

Step 2: 编写中间件函数

在 Next.js 项目的根目录下,创建一个名为 preventHotlinking.js 的中间件函数,代码如下:

----- ---- - ----------------
----- --- - ---------------
----- -- - --------------

-------------- - ----- ---- ----- -- -
  -- -------
  ----- --------- - ----------------------------
  
  -- ---------
  -- --------------------------------------------------- -
    -- -- -------
    ----- ------- - ------------------- -- -------------------- -- ---
    -- -----
    ----- - -------- - - ------------------ ------ ------
    ----- ----------- - -----------------
    
    -- --------------------------------------
    -- --------- -- ----------- -- -------- --- ------------ -
      ------------------ -
        --------------- ------------------------
      ---
      
      --------------------- - --------------------- ----- ----- -- -
        -- ----- -
          -----------------
          -------
        -
        --------------
      ---
      
      -------
    -
  -

  -------
-

上述代码首先通过 url.parse 函数获取图片的路径,然后正则表达式校验图片的扩展名是否符合标准。接着获取 referer(或者 referrer) 值,根据其值判断本次请求是否来自当前站点,如果来源不是本站点,则返回一个状态码为 HTTP 403 的响应。最后一个 no_hotlinking.jpg 是一个本地资源,表示防盗链的占位图片。

Step 3: 集成函数

在 Next.js 项目中,将编写的中间件函数作为 servermiddleware 数组的一部分集成起来。在 Next.js 项目的根目录下,打开 server.js 文件(如果不存在则需要手动创建),并编写以下代码:

----- ------- - -------------------
----- ---- - ----------------
----- ----------------- - -------------------------------

----- ------ - ----------
----- ---- - ---------------- -- -----
----- --- - -------------------- --- -------------
----- --- - ------ --- ---
----- ------ - ------------------------

--------------------- -- -
  ------------------------------
  --------------- ----- ---- -- -
    ------ ----------- -----
  ---

  ------------------- ----- -- -
    -- ----- ----- ----
    -------------- ----- -- ---------------------------
  ---
---

上述代码中,我们使用 express 来创建服务器。在应用中间件之前,应用程序必须配置如下代码,以允许能够在 HTTP 请求中读取请求正文。

---------------------------
------------------------------- --------- ---- ----

然后,我们将刚才编写的防盗链中间件作为 server 的中间件之一加入。server.all 函数就是为所有请求(*)指定回调函数,如果请求不符合路由,则使用 handle 处理器来处理。

Step 4: 正确设置 publicConfig

最后一步,打开 next.config.js,确保正确设置 publicConfig

-------------- - -
  ------------- -
    -------------------------- ----
  -
--

以上设置 publicConfigblockingPreventHotlinking 属性为 true 即可实现 Next.js 集成防盗链功能的解决方案。

总结

本文详细介绍了如何在 Next.js 项目中实现防盗链功能。通过 node.js 中的 http 模块、url 模块、fs 模块等组成,以及中间件函数和 publicConfig 的配合使用,为 Next.js 提供了简单且实用的防盗链功能,通过本文的学习,可以让开发者更好地保护自己的网站资源的安全性。

来源:JavaScript中文网 ,转载请联系管理员! 本文地址:https://www.javascriptcn.com/post/654cd7397d4982a6eb62b9fb


猜你喜欢

  • 利用 Custom Elements 和 SVG 实现可扩展图标库的构建

    随着前端开发的快速发展,图标库已经成为了一个不可或缺的组成部分。但是,传统的图标库存在着一些问题,比如图标数量有限、样式固定等。因此,本文将介绍如何利用 Custom Elements 和 SVG 实...

    1 年前
  • RxJS 与 Redux 如何实现双向数据流

    在现代的前端开发中,数据流管理已经成为一个重要的话题。RxJS 和 Redux 是两个常用的解决方案,它们可以协同工作实现双向数据流。 RxJS 和 Redux 简介 RxJS 是一个基于观察者模式的...

    1 年前
  • 如何使用 ES7 的 for-await-of 语句

    随着 JavaScript 语言的发展,在 ES7 中,添加了一个新的 for-await-of 语法,这个语法提供了一种优雅且简洁的方式来处理异步任务的集合。在这篇文章中,我们将学习如何在前端开发中...

    1 年前
  • SASS 中的 @import 标签使用教程

    前言 在前端开发中,我们经常会使用预处理器来编写 CSS,其中比较常用的是 SASS。SASS 是一种 CSS 预处理器,它提供了比 CSS 更加强大、灵活的语言和工具,可以让我们更高效地编写样式。

    1 年前
  • 怎样选择正确的 CSS Reset 方案

    在开发网站或者 Web 应用时,我们通常会使用 CSS Reset 来使不同浏览器中的元素默认样式表现统一。但是,选择正确的 CSS Reset 方案 却是一个比较复杂的问题。

    1 年前
  • 在 ES6/ES2015 中重构异步代码 ——promises 与 async/await

    在前端开发中,异步操作是非常常见的。在 ES6/ES2015 引入后,代码编写异步操作的方式也发生了很大的变化。其中 promises 和 async/await 就是两种非常常用的方式。

    1 年前
  • 解决 ES8 中的 Proxy 陷阱函数无限递归问题

    前言 在 ES6 中,我们有一个全新的对象代理(Proxy)特性,它可以对一个对象进行拦截、监视和修改。这个特性在很多场景下都非常有用,比如数据验证、日志、缓存,甚至是数据绑定等等。

    1 年前
  • 在 Mocha 测试中如何隔离测试环境

    Mocha 是一款流行的 JavaScript 测试框架,可以用于编写前端项目的单元测试、集成测试等。在编写测试用例时,我们希望能够隔离测试环境,确保每个测试用例执行时的环境都是独立的,不受其他测试用...

    1 年前
  • SQL Server 性能优化的经验总结

    SQL Server 性能优化的经验总结 在 Web 开发中,优化 SQL Server 数据库的性能是至关重要的。如果你的应用程序因为 SQL Server 的性能问题而变得缓慢,那么它就不能提供优...

    1 年前
  • ES12 中的循环列表:更好的循环方式

    在 ES12 中,新增了一种更高效、更便捷的循环方式:循环列表(loop list)。 循环列表是一种新型的迭代器,可以帮助我们更加轻松地遍历和操作数组、集合、对象和字符串等数据结构,提升开发效率和代...

    1 年前
  • 使用 Web Components 实现自定义表单控件

    什么是 Web Components? Web Components 是一种用于创建可重用和可组合的自定义元素的技术,它包括四个主要的功能: Custom Elements:定义自定义元素。

    1 年前
  • Node.js:使用 Express 和 MongoDB 构建在线存储库

    前言 在当今互联网飞速发展的时代,我们可以看到各种各样的数据都在不断地产生和积累。为了更好地管理和利用这些数据,使用在线存储库已经成为了一种必然趋势。而在上述应用中,Node.js 和 MongoDB...

    1 年前
  • 使用 Server-Sent Events 连接 MySQL 数据库

    简介 Server-Sent Events,即服务器推送事件,是一种基于 HTTP 的浏览器服务器通信技术,用于向浏览器推送数据。相比于 WebSockets,Server-Sent Events 更...

    1 年前
  • 使用 Express.js 和 Node.js 构建 RESTful API

    在前端开发过程中,经常会用到 RESTful API。REST(Representational State Transfer)是一种设计风格,用于构建基于 HTTP 协议的 Web 服务。

    1 年前
  • koa2+sequelize 如何实现数据库操作

    在网站开发中,数据库操作是非常重要的一环,而在前端领域中,Koa2 和 Sequelize 成为了非常流行的框架。下面,本文将详细介绍在 Koa2 中如何使用 Sequelize 进行数据库操作。

    1 年前
  • SPA 应用中如何利用 Node.js 搭建后台服务器?

    在单页面应用(SPA)中,前端的页面逻辑和数据请求是通过 JavaScript 实现的,并且前端实现的是一个独立的应用。这就需要后台服务器提供数据 API 接口,前端从后台获取数据,动态渲染页面。

    1 年前
  • 解决 Redis 遇到 “OOM command not allowed when used memory> ‘maxmemory’” 的问题

    Redis 是一款快速、高效的键值存储数据库,广泛应用于分布式系统、缓存、消息队列等场景中。然而,在使用 Redis 过程中,我们可能会遇到 “OOM command not allowed when...

    1 年前
  • 利用 CSS Grid 实现响应式博客布局的细节处理

    随着移动设备的普及,越来越多的网站需要具备响应式布局,以适应不同设备上的屏幕大小。在前端开发中,CSS Grid 可以极大地方便响应式网页设计的实现。本文将介绍如何利用 CSS Grid 完成博客网站...

    1 年前
  • 在 Fastify 应用中使用 GraphQL Apollo

    Fastify 是一种基于 Node.js 的快速、低开销的 Web 框架。GraphQL 是一种现代化的 API 查询语言。本文将介绍如何在 Fastify 应用中使用 GraphQL Apollo...

    1 年前
  • 如何从 MongoDB 中删除重复数据?

    本文将介绍如何从 MongoDB 中删除重复数据。在使用 MongoDB 时,重复数据是比较常见的问题。当然,也会影响查询速度和数据质量。解决这个问题,也就是删除 MongoDB 中的重复数据,是前端...

    1 年前

相关推荐

    暂无文章