在本指南中,我们将使用 node.JS 和 discord.js 库为 discord 创建一个简单的审核机器人。该机器人将包括禁止、静音和监控聊天活动等功能。
创建一个用于 discord 的审核机器人
在本指南中,我们将使用 node.js 和 discord.js 库为 discord 创建一个简单的审核机器人。该机器人将包括禁止、静音和监控聊天活动等功能。
先决条件
- 已安装 node.js: 从 nodejs.org 下载并安装 node.js。
- discord 帐户: 确保您拥有 discord 帐户以及对要测试机器人的服务器的管理访问权限。
- 基本 JavaScript 知识: 建议熟悉 javascript 基础知识。
第 1 步:创建一个新的 discord 机器人
- 前往 discord 开发者门户。
- 点击新建应用程序并为您的机器人命名。
- 在左侧边栏中,转到机器人,然后单击添加机器人。
- 复制机器人的令牌以供以后使用(保密)。
- 在“特权网关意图”下,启用消息内容意图以允许机器人读取消息。
第 2 步:设置您的项目
- 打开终端并为您的机器人创建一个新文件夹:
mkdir discord-moderation-bot cd discord-moderation-bot
- 初始化一个新的 node.js 项目:
npm init -y
- 安装discord.js:
npm install discord.js
- 在文件夹中创建一个 index.js 文件来保存机器人的代码:
touch index.js
第 3 步:编写机器人代码
在代码编辑器中打开index.js并添加以下代码:
1.导入并配置discord.js
const { client, gatewayintentbits } = require('discord.js'); const client = new client({ intents: [ gatewayintentbits.guilds, gatewayintentbits.guildmessages, gatewayintentbits.messagecontent, gatewayintentbits.guildmembers ] }); const token = 'your_bot_token'; // replace with your bot token
2. 设置机器人登录和就绪事件
client.once('ready', () => { console.log(`logged in as ${client.user.tag}!`); }); client.login(token);
3.添加审核命令
禁止命令
client.on('messagecreate', (message) => { if (message.content.startswith('!ban')) { if (!message.member.permissions.has('banmembers')) { return message.reply('you do not have permission to ban members.'); } const member = message.mentions.members.first(); if (!member) { return message.reply('please mention a user to ban.'); } member.ban() .then(() => message.reply(`${member.user.tag} has been banned.`)) .catch((err) => message.reply('i was unable to ban the member.')); } });
静音命令
client.on('messagecreate', (message) => { if (message.content.startswith('!mute')) { if (!message.member.permissions.has('manageroles')) { return message.reply('you do not have permission to mute members.'); } const member = message.mentions.members.first(); if (!member) { return message.reply('please mention a user to mute.'); } let muterole = message.guild.roles.cache.find(role => role.name === 'muted'); if (!muterole) { return message.reply('no "muted" role found. please create one first.'); } member.roles.add(muterole) .then(() => message.reply(`${member.user.tag} has been muted.`)) .catch((err) => message.reply('i was unable to mute the member.')); } });
清除消息命令
client.on('messagecreate', (message) => { if (message.content.startswith('!clear')) { if (!message.member.permissions.has('managemessages')) { return message.reply('you do not have permission to manage messages.'); } const args = message.content.split(' '); const amount = parseint(args[1]); if (isnan(amount) || amount <= 0) { return message.reply('please specify a valid number of messages to delete.'); } message.channel.bulkdelete(amount, true) .then((deletedmessages) => message.reply(`deleted ${deletedmessages.size} messages.`)) .catch((err) => message.reply('i was unable to delete messages.')); } });
第 4 步:邀请机器人到您的服务器
- 返回 discord 开发者门户。
- 在左侧边栏中,单击oauth2 > url 生成器。
- 在范围下,选择机器人。在机器人权限下,选择:
- 禁止会员
- 管理角色
- 管理消息
- 复制生成的 url 并将其粘贴到您的浏览器中,以邀请机器人访问您的服务器。
第 5 步:测试您的机器人
- 运行机器人:
node index.js
- 在您的 discord 服务器中,尝试使用以下命令:
- !ban @user 禁止用户。
- !mute @user 将用户静音(确保存在“静音”角色)。
- !clear
删除指定数量的消息。
额外提示
- 改进错误处理:添加更好的错误日志记录和用户反馈。
- 添加帮助命令:为用户提供命令列表及其描述。
- 保护您的机器人令牌:使用环境变量或配置文件来保证您的令牌安全。
- 扩展功能:添加警告、取消静音,甚至使用消息跟踪器进行自动垃圾邮件检测。
通过本指南,您将拥有一个功能齐全的审核机器人,您可以对其进行自定义以满足服务器的需求!