代码拉取完成,页面将自动刷新
非官方的 MidJourney api 的 Node.js 客户端。
English / 中文文档
运行本项目需要安装 Node.js,然后在本项目的根目录运行以下命令:
下载项目代码
git clone https://github.com/erictik/midjourney-api.git
cd midjourney-api
安装依赖
yarn
# or npm
npm install
设置环境变量
获取 Discord TOKEN 登录 Discor F12 或者 [Ctrl + Shift + I] 或者 [Command + Option + I] 打开开发者工具,然后在 Console 中输入以下代码:
window.webpackChunkdiscord_app.push([
[Math.random()],
{},
(req) => {
for (const m of Object.keys(req.c)
.map((x) => req.c[x].exports)
.filter((x) => x)) {
if (m.default && m.default.getToken !== undefined) {
return copy(m.default.getToken());
}
if (m.getToken !== undefined) {
return copy(m.getToken());
}
}
},
]);
console.log("%cWorked!", "font-size: 50px");
console.log(`%您的Token在剪贴板了!`, "font-size: 16px");
也可以通过 查看 network 获取 discord token
export SERVER_ID="1082500871478329374"
export CHANNEL_ID="1094892992281718894"
或者 创建一个 Discord 服务器 并邀请 Midjourney Bot
# 在浏览器中复制你的服务器网址
# `https://discord.com/channels/$SERVER_ID/$CHANNEL_ID`
export SERVER_ID="your-server-id"
export CHANNEL_ID="your-channel-id"
将环境变量写入.env
文件或者 在控制台中设置
#example variables, please set up yours
export SERVER_ID="1082500871478329374"
export CHANNEL_ID="1094892992281718894"
export SALAI_TOKEN="your-discord-token"
现在可以运行示例了
npx tsx example/imagine-ws.ts
或者
yarn example:imagine
# or npm
npm run example:imagine
更多使用案例
安装
npm i midjourney
# or
yarn add midjourney
使用 Imagine 、Variation 和 Upscale
import { Midjourney } from "midjourney";
const client = new Midjourney({
ServerId: <string>process.env.SERVER_ID,
ChannelId: <string>process.env.CHANNEL_ID,
SalaiToken: <string>process.env.SALAI_TOKEN,
Debug: true,
Ws: true, //enable ws is required for remix mode (and custom zoom)
});
await client.init();
const prompt =
"Christmas dinner with spaghetti with family in a cozy house, we see interior details , simple blue&white illustration";
//imagine
const Imagine = await client.Imagine(
prompt,
(uri: string, progress: string) => {
console.log("loading", uri, "progress", progress);
}
);
console.log(Imagine);
if (!Imagine) {
console.log("no message");
return;
}
// U1 U2 U3 U4 V1 V2 V3 V4 "Vary (Strong)" ...
const V1CustomID = Imagine.options?.find((o) => o.label === "V1")?.custom;
if (!V1CustomID) {
console.log("no V1");
return;
}
// Varition V1
const Varition = await client.Custom({
msgId: <string>Imagine.id,
flags: Imagine.flags,
customId: V1CustomID,
content: prompt, //remix mode require content
loading: (uri: string, progress: string) => {
console.log("loading", uri, "progress", progress);
},
});
console.log(Varition);
const U1CustomID = Imagine.options?.find((o) => o.label === "U1")?.custom;
if (!U1CustomID) {
console.log("no U1");
return;
}
// Upscale U1
const Upscale = await client.Custom({
msgId: <string>Imagine.id,
flags: Imagine.flags,
customId: U1CustomID,
loading: (uri: string, progress: string) => {
console.log("loading", uri, "progress", progress);
},
});
if (!Upscale) {
console.log("no Upscale");
return;
}
console.log(Upscale);
const zoomout = Upscale?.options?.find((o) => o.label === "Custom Zoom");
if (!zoomout) {
console.log("no zoomout");
return;
}
// Custom Zoom
const CustomZoomout = await client.Custom({
msgId: <string>Upscale.id,
flags: Upscale.flags,
content: `${prompt} --zoom 2`, // Custom Zoom require content
customId: zoomout.custom,
loading: (uri: string, progress: string) => {
console.log("loading", uri, "progress", progress);
},
});
console.log(CustomZoomout);
/imagine
variation
upscale
reroll
blend
zoomout
vary
/info
/fast
and /relax
/prefer remix
variation (remix mode)
/describe
/shorten
/settings
reset
如果您觉得它很有价值,可以通过以下方式支持作者
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。