文件助手(files
)
这个插件允许你轻松地从 Telegram 服务器下载文件,并且获取一个URL,以便你自己下载文件。
别忘了 文件是如何工作的,以及如何上传文件。
下载文件
你需要传递你的 bot token 给这个插件,因为它必须在下载文件时以你的 bot 身份进行认证。 然后这个插件在 get
调用结果上安装了 download
方法。 例子:
ts
import { Bot, Context } from "grammy";
import { FileFlavor, hydrateFiles } from "@grammyjs/files";
// 添加上下文调味剂
type MyContext = FileFlavor<Context>;
// 创建一个 bot。
const bot = new Bot<MyContext>("BOT_TOKEN");
// 使用插件。
bot.api.config.use(hydrateFiles(bot.token));
// 下载视频和 GIF 到临时位置。
bot.on([":video", ":animation"], async (ctx) => {
// 准备文件供下载。
const file = await ctx.getFile();
// 下载文件到一个临时位置。
const path = await file.download();
// 打印文件路径
console.log("File saved at ", path);
});
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
js
import { Bot } from "grammy";
import { hydrateFiles } from "@grammyjs/files";
// 创建一个 bot。
const bot = new Bot("");
// 使用插件。
bot.api.config.use(hydrateFiles(bot.token));
// 下载视频和 GIF 到临时位置。
bot.on([":video", ":animation"], async (ctx) => {
// 准备文件供下载。
const file = await ctx.getFile();
// 下载文件到一个临时位置。
const path = await file.download();
// 打印文件路径。
console.log("File saved at ", path);
});
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
ts
import { Bot, Context } from "https://deno.land/x/grammy@v1.30.0/mod.ts";
import {
FileFlavor,
hydrateFiles,
} from "https://deno.land/x/grammy_files@v1.1.1/mod.ts";
// 添加上下文调味剂
type MyContext = FileFlavor<Context>;
// 创建一个 bot。
const bot = new Bot<MyContext>("BOT_TOKEN");
// 使用插件。
bot.api.config.use(hydrateFiles(bot.token));
// 下载视频和 GIF 到临时位置。
bot.on([":video", ":animation"], async (ctx) => {
// 准备文件供下载。
const file = await ctx.getFile();
// 下载文件到一个临时位置。
const path = await file.download();
// 打印文件路径。
console.log("File saved at ", path);
});
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
如果你不想创建临时文件,你可以传递一个文件路径到 download
。 像这样:await file
。
如果你只想获取文件的 URL,以便你自己下载文件,请使用 file
。 这将返回一个你的文件对 HTTPS 链接,这个链接有效的时间至少是一个小时。
本地 Bot API 服务器
如果你使用 本地 Bot API 服务器,那么 get
调用有效地下载文件到你的磁盘。
反过来,你可以调用 file
以访问这个文件路径。 请注意,await file
现在将会将这个本地存在的文件复制到临时位置(或者指定的路径)。
支持 bot.api
调用
默认情况下,await bot
的结果将会被配备上 download
和 get
方法。 但是,这并不会在类型中反映出来。 如果你需要这些调用,你应该也安装一个叫作 File
的 API 调味剂 在 bot 对象上。
ts
import { Api, Bot, Context } from "grammy";
import { FileApiFlavor, FileFlavor, hydrateFiles } from "@grammyjs/files";
type MyContext = FileFlavor<Context>;
type MyApi = FileApiFlavor<Api>;
const bot = new Bot<MyContext, MyApi>("");
// ...
1
2
3
4
5
6
7
8
2
3
4
5
6
7
8
ts
import { Api, Bot, Context } from "https://deno.land/x/grammy@v1.30.0/mod.ts";
import {
FileApiFlavor,
FileFlavor,
hydrateFiles,
} from "https://deno.land/x/grammy_files@v1.1.1/mod.ts";
type MyContext = FileFlavor<Context>;
type MyApi = FileApiFlavor<Api>;
const bot = new Bot<MyContext, MyApi>("");
// ...
1
2
3
4
5
6
7
8
9
10
11
12
2
3
4
5
6
7
8
9
10
11
12