node.js+兰空图床实现随机图

之前博客一直用的公共的随机图API,虽然图片的质量都挺不错的,但是稳定性都比较一般,遂打算使用之前部署的兰空图床,自己弄一个随机图

本文章服务器操作基于雨云------新一代云服务提供商的云服务器进行操作,有兴趣的话可以去官网看看

兰空图床

兰空图床的部署过程可参考我之前的文章:搭建兰空图床并配合 PicGo 实现批量上传 | 火柴人儿的小站

获取Token

获取token的接口地址在兰空图床的接口文档中有写

使用api工具(ApiFox或者Postman都行)请求一次接口,Headers和Body按照我这个填就行,邮箱和密码要改成自己的

创建项目

  1. 创建项目

    • 初始化一个新的Node.js项目

      shell 复制代码
      npm init -y
    • 安装Express和Axios

      shell 复制代码
      npm install express axios
  2. 编写后端代码

    • 创建一个名为app.js的文件,并编写以下代码:

    javascript 复制代码
    const express = require('express');
    const axios = require('axios');
    const app = express();
    const port = 3000;   //自定义一个未使用的端口
    
    app.get('/', async (req, res) => {
      try {
        const response = await axios.get('http://xxxxxx/api/v1/images?album_id=xx',{ //兰空图床接口,用于获取指定相册下的所有图片
    	    headers: {
            'Authorization': 'Bearer xxxxx',  // 兰空图床的Token
            'Accept': 'application/json',           // 兰开图床公共请求参数
          }
        });
        const images = response.data.data.data;
        const randomIndex = Math.floor(Math.random() * images.length);
        const randomImage = images[randomIndex];
        res.redirect(randomImage.links.url); //重定向到图片地址
      } catch (error) {
        res.status(500).send('Internal Server Error');
      }
    });
    
    app.listen(port, () => {
      console.log(`Server is running at http://localhost:${port}/`);
    });
    • 运行

      shell 复制代码
      node app.js
  3. 测试

    浏览器访问地址localhost:3000就可以访问随机图片了,本地测试无误之后就需要放到服务器上运行了

部署

可能因为我是用docker部署的宝塔,所以有些问题,没法用宝塔部署node项目,所以改为手动部署

  1. 新建并进入目录randomImgs

    shell 复制代码
    mkdir /home/randomImgs
    cd /home/randomImgs
  2. 将项目文件导入到randomImgs中(使用SSH工具导入,我这里用的是WindTerm)

  3. 若已经安装过node,则直接执行以下命令即可,未安装node的话安装此教程------如何在服务器上安装node、npm_服务器安装npm-CSDN博客即可安装,记得把里面的版本号改为16.17.0或者>=你本地的版本号

    shell 复制代码
    nohup node app.js &

    会提示nohup: ignoring input and appending output to 'nohup.out',这个是正常的,意思就是项目日志会追加到nohup.out文件中,直接回车就行

  4. 配置nginx

    1. 去DNS添加一条A记录来创建一个子域名

    2. 创建php项目,使用刚刚创建的子域名

    3. 添加反向代理,目标URL为http://服务器IP:3000

      这里的3000为node项目中app.js设定的端口

  5. 此时就可以通过子域名获取随机图了

优化

因为涉及到token,所以可以使用javascript混淆进行简单的防护

  1. 使用在线Javascript混淆加密,用混淆后的内容替换app.js中的内容

相关推荐
WangHappy6 小时前
出海不愁!用Vue3 + Node.js + Stripe实现全球支付
前端·node.js
该用户已不存在6 小时前
Node.js后端开发必不可少的7个核心库
javascript·后端·node.js
小邋遢2.012 小时前
vscod 执行npm build报错:Error: Cannot find module ‘vite‘
前端·npm·node.js
孟陬14 小时前
2025-12-11 之后前端 npm 如何发包 How to Publish NPM Package in Year 2025
npm·node.js·bun
五月君_14 小时前
Node.js 历史性一刻!原生 TS 支持正式 Stable,告别 ts-node
node.js
五月君_15 小时前
Node.js 企业级框架 Egg 4.0 发布:原生支持 AI 开发,架构全面革新
人工智能·架构·node.js
未知原色15 小时前
react实现虚拟键盘支持Ant design Input和普通input Dom元素-升级篇
前端·javascript·react.js·node.js·计算机外设
未知原色15 小时前
React实现队列解决多个请求频繁并发到达server时序乱序问题
前端·javascript·react.js·node.js·ecmascript
天天扭码1 天前
前端如何实现RAG?一文带你速通,使用RAG实现长期记忆
前端·node.js·ai编程
hxmmm1 天前
自定义封装 vue多页项目新增项目脚手架
前端·javascript·node.js