我写了一个随机发送本地图片的插件,但是发送的图片无法显示

这个是发送本地随机图片的一个插件,代码是:

import { Context, Schema, Session, h } from "koishi";
import { resolve } from "path";
import * as fs from "fs";

export const name = "tu";

export const usage = `
### 向世界分享你的图片

在imagePath处填入你的图片文件夹绝对路径即可

`;

export interface Config {
  imagePath: string;
}

export const Config: Schema<Config> = Schema.object({
  imagePath: Schema.string()
    .description("图片文件夹路径")
    .default("D:/a图片/xp"),
});

export const using = [];

// 导出一个异步函数,接收两个参数:Context 和 Config
export async function apply(ctx: Context, config: Config) {
  // 获取 logger 对象
  const logger = ctx.logger("open-pics");

  // 定义一个返回指定范围内随机整数的函数
  function mathRandomInt(a: number, b: number): number {
    // 如果 a 大于 b,则交换 a 和 b 的值
    if (a > b) {
      [a, b] = [b, a]; // 使用解构赋值交换 a 和 b 的值
    }
    // 返回 a 到 b 之间的随机整数
    return Math.floor(Math.random() * (b - a + 1) + a);
  }

  // 定义一个命令处理函数
  async function handleCommand(session: Session) {
    try {
      // 获取图片文件夹中的所有文件名
      const files = fs.readdirSync(config.imagePath);
      // 随机选择一个文件名
      const fileName = files[mathRandomInt(0, files.length - 1)];
      // 组装图片的本地路径
      const imagePath = resolve(config.imagePath, fileName);
      // 发送本地图片消息
      await session.send(h.image(imagePath));
    } catch (error) {
      logger.error(error.message);
      await session.send("获取图片失败,请稍后再试");
    }
  }

  // 定义一个命令
  ctx
    .command("xp", "获取一张随机的 xp 图片")
    .alias("美图")
    .action(({ session }, prompt) => handleCommand(session));
}

日志报错:

运行情况:

我想知道为什么发送的图片无法显示,怎么样修改才能正确发送图片

2 个赞

你好,沙盒就是会不显示 :rofl:。建议接入到真实的聊天平台测试。
我就是这种情况,在QQ上就可以正常显示了。

我在回答这个问题的时候请问如何随机发送本地的图片至QQ群中,就在沙盒里试了半天,被气死。

3 个赞