質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
Discord

Discordは、ゲーマー向けのボイスチャットアプリです。チャット・通話がブラウザ上で利用可能で、個人専用サーバーも開設できます。通話中でも音楽を流したり、PC画面を共有できるなど多機能な点が特徴です。

Node.js

Node.jsとはGoogleのV8 JavaScriptエンジンを使用しているサーバーサイドのイベント駆動型プログラムです。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

Q&A

解決済

2回答

2236閲覧

discord.jsでevalが作りたい(consoleへの出力も含め)

yuina8686

総合スコア12

Discord

Discordは、ゲーマー向けのボイスチャットアプリです。チャット・通話がブラウザ上で利用可能で、個人専用サーバーも開設できます。通話中でも音楽を流したり、PC画面を共有できるなど多機能な点が特徴です。

Node.js

Node.jsとはGoogleのV8 JavaScriptエンジンを使用しているサーバーサイドのイベント駆動型プログラムです。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

0グッド

0クリップ

投稿2021/10/15 03:12

編集2021/10/15 08:51

前提・実現したいこと

node.jsのdiscord.jsで作ったBOTにevalのコマンドを作成しようとしたのですが思うような結果が得られませんでした。
~編集 2021/10/15 17:48ごろ~
DiscordのAPIがempty messageのエラーを出していたのは、eval関数がconsole.logの返り値、undefinedを送信しようとしたためだとわかりました。
そこで、console.logなどの関数によるconsoleへの出力もDiscordのほうに出力したいのですが、どのようにしたらいいでしょうか。

発生している問題・エラーメッセージ

(node:311) UnhandledPromiseRejectionWarning: DiscordAPIError: Cannot send an empty message at RequestHandler.execute (/home/runner/newyinabot/node_modules/discord.js/src/rest/RequestHandler.js:170:25) at processTicksAndRejections (internal/process/task_queues.js:97:5) (node:311) UnhandledPromiseRejectionWarning: Unhandled promise rejection. This error originated either by throwing inside of an async function without a catch block, or by rejecting a promise which was not handled with .catch(). To terminate the node process on unhandled promise rejection, use the CLI flag `--unhandled-rejections=strict` (see https://nodejs.org/api/cli.html#cli_unhandled_rejections_mode). (rejection id: 1) (node:311) [DEP0018] DeprecationWarning: Unhandled promise rejections are deprecated. In the future, promise rejections that are not handled will terminate the Node.js process with a non-zero exit code.

該当のソースコード

javascript

1} else if (msg.content === '--eval' || msg.author.id === 802152878855684106) { 2 const collector = new Discord.MessageCollector(msg.channel, m => m.author.id === msg.author.id, { time: 10000 }); 3 msg.channel.send("実行するコードを発言してください。"); 4 collector.on('collect', message => { 5 message.channel.send(eval(message.content)); 6 }) 7}

試したこと

console.log('aaa');
などと入力してもdiscordの方には結果が出力されずconsoleの方に出力されました。

補足情報(FW/ツールのバージョンなど)

Node.js v16

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

ベストアンサー

理由はconsole.logで出力されるのはundefinedで、文字列でないからです。
util.inspectで文字列にしてやる必要があります。
それとtry-catchもつけたほうがいいです。

js

1} else if (msg.content === '--eval' || msg.author.id === 802152878855684106) { 2 const collector = new Discord.MessageCollector(msg.channel, m => m.author.id === msg.author.id, { time: 10000 }); 3 msg.channel.send("実行するコードを発言してください。"); 4 collector.on('collect', message => { 5 try { 6 message.channel.send(require("util").inspect(eval(message.content))); 7 } catch (err) { 8 message.channel.send(require("util").inspect(err)); 9 }) 10}

投稿2021/10/16 00:35

Waki285

総合スコア2014

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

yuina8686

2021/10/16 02:43

やってみたのですが SyntaxError: Unexpected identifier at MessageCollector.<anonymous> (C:\Users\machi\Desktop\yuinabot\test\index.js:199:67) at MessageCollector.emit (node:events:390:28) at MessageCollector.handleCollect (C:\Users\machi\Desktop\yuinabot\test\node_modules\discord.js\src\structures\interfaces\Collector.js:108:12) at processTicksAndRejections (node:internal/process/task_queues:96:5) というエラーが大量に出力されました どういうことでしょうか?
yuina8686

2021/10/16 02:48

consoleのほうにもエラー出てました (node:21400) DeprecationWarning: The message event is deprecated. Use messageCreate instead (Use `node --trace-deprecation ...` to show where the warning was created)
Waki285

2021/10/16 05:00

} else if (msg.content === '--eval' || msg.author.id === 802152878855684106) { const collector = msg.channel.createMessageCollector({ filter: m => m.author.id === msg.author.id, time: 10000 }); msg.channel.send("実行するコードを発言してください。"); collector.on('collect', message => { try { message.channel.send(require("util").inspect(eval(message.content))); } catch (err) { message.channel.send(require("util").inspect(err)); } }) } こちらでどうでしょう
yuina8686

2021/10/16 05:45

ちゃんと動きました! しかしDiscord側にはundefinedと出ているのですが、consoleの出力結果をDiscordに送信することはできますか?
Waki285

2021/10/16 12:45

console.log は関数です。関数の結果としてundefinedが出力されているので、理想的な動きです。 動作を出力したい場合は、 例えばdataという変数をDiscord側に出したい場合は console.log(data) ではなく data と直に書いてください。 たとえば: --eval のあとに const keisan = 1 + 1 keisan のように。
yuina8686

2021/10/17 05:34

やっぱり関数の結果をそのまま出力するのはできないんですね、、、 甘ったれてましたw ここまで回答ありがとうございました!
guest

0

おそらくは...これで動くと思います。
わかりませんが。

js

1} else if (msg.content === '--eval' || msg.author.id === 802152878855684106) { 2 const collector = new Discord.MessageCollector(msg.channel, m => m.author.id === msg.author.id, { time: 10000 }); 3 msg.channel.send("実行するコードを発言してください。"); 4 collector.on('collect', message => { 5 if(!message.author.id == "749092490556080158") return; 6 var eval_content = message.content.split(" ").slice(1).join(" ") 7 var result = eval(eval_content); 8 message.channel.send(result); 9 }) 10}

投稿2021/10/15 03:23

PyPyPyPy

総合スコア17

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

yuina8686

2021/10/15 07:19

同じエラーが出ますね…
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問