代理 MidJourney 的discord频道,实现api形式调用AI绘图
- 支持 Imagine、U、V 指令,绘图完成后回调
- 支持 Describe 指令,根据图片生成 prompt
- 支持中文 prompt 翻译,需配置百度翻译或 gpt
- prompt 敏感词判断,支持覆盖调整
- 任务队列,默认队列10,并发3。可参考 MidJourney订阅级别 调整mj.queue
- 支持mysql存储,优化任务的查询方式
- 支持配置账号池,分发绘图任务
- Imagine 时支持上传图片,作为垫图
- 科学上网
- docker环境
- 注册 MidJourney,创建自己的频道,参考 https://docs.midjourney.com/docs/quick-start
- 添加自己的机器人: 流程说明
- 下载镜像
docker pull novicezk/midjourney-proxy:1.6.1
- 启动容器,并设置参数
# /xxx/xxx/config目录下创建 application.yml(mj配置项)、banned-words.txt(可选,覆盖默认的敏感词文件)
# 参考src/main/resources下的文件
docker run -d --name midjourney-proxy \
-p 8080:8080 \
-v /xxx/xxx/config:/home/spring/config \
--restart=always \
novicezk/midjourney-proxy:1.6.1
# 或者直接在启动命令中设置参数
docker run -d --name midjourney-proxy \
-p 8080:8080 \
-e mj.discord.guild-id=xxx \
-e mj.discord.channel-id=xxx \
-e mj.discord.user-token=xxx \
-e mj.discord.bot-token=xxx \
--restart=always \
novicezk/midjourney-proxy:1.6.1
- 访问 http://localhost:8080/mj 提示 "项目启动成功"
- 检查discord频道中新创建的机器人是否在线
- 调用api接口的根路径为
http://ip:port/mj
,接口测试地址:http://ip:port/mj/doc.html
- 常见问题及解决办法见 Wiki / 常见问题
- 在 Issues 中提出其他问题或建议
- 感兴趣的朋友也欢迎加入交流群讨论一下,扫码进群名额已满,加管理员微信邀请进群
变量名 | 非空 | 描述 |
---|---|---|
mj.discord.guild-id | 是 | discord服务器ID |
mj.discord.channel-id | 是 | discord频道ID |
mj.discord.user-token | 是 | discord用户Token |
mj.discord.bot-token | 是 | 自定义机器人Token |
mj.discord.mj-bot-name | 否 | mj机器人名称,默认 "Midjourney Bot" |
mj.notify-hook | 否 | 任务状态变更回调地址 |
mj.task-store.type | 否 | 任务存储方式,默认in_memory(内存\重启后丢失),可选redis |
mj.task-store.timeout | 否 | 任务过期时间,过期后删除,默认30天 |
mj.proxy.host | 否 | 代理host,全局代理不生效时设置 |
mj.proxy.port | 否 | 代理port,全局代理不生效时设置 |
mj.queue.core-size | 否 | 并发数,默认为3 |
mj.queue.queue-size | 否 | 等待队列,默认长度10 |
mj.queue.timeout-minutes | 否 | 任务超时时间,默认为5分钟 |
mj.translate-way | 否 | 中文prompt翻译方式,可选null(默认)、baidu、gpt |
mj.baidu-translate.appid | 否 | 百度翻译的appid |
mj.baidu-translate.app-secret | 否 | 百度翻译的app-secret |
mj.openai.gpt-api-key | 否 | gpt的api-key |
mj.openai.timeout | 否 | openai调用的超时时间,默认30秒 |
mj.openai.model | 否 | openai的模型,默认gpt-3.5-turbo |
mj.openai.max-tokens | 否 | 返回结果的最大分词数,默认2048 |
mj.openai.temperature | 否 | 相似度(0-2.0),默认0 |
spring.redis | 否 | 任务存储方式设置为redis,需配置redis相关属性 |
spring.redis配置参考
spring:
redis:
host: 10.107.xxx.xxx
port: 6379
password: xxx
POST application/json
{
// 动作: 必传,IMAGINE(绘图)、UPSCALE(选中放大)、VARIATION(选中变换)
"action":"IMAGINE",
// 绘图参数: IMAGINE时必传
"prompt": "猫猫",
// 任务ID: UPSCALE、VARIATION时必传
"taskId": "1320098173412546",
// 图序号: 1~4,UPSCALE、VARIATION时必传,表示第几张图
"index": 3,
// 自定义字符串: 非必传,供回调到业务系统里使用
"state": "test:22",
// 支持每个任务配置不同回调地址,非必传
"notifyHook": "http://localhost:8113/notify"
}
返回 Message
描述
- code=1: 提交成功,result为任务ID
{ "code": 1, "description": "成功", "result": "8498455807619990" }
- code=2: 提交成功,进入队列等待
{ "code": 2, "description": "排队中,前面还有1个任务", "result": "0741798445574458" }
- other: 提交错误,description为错误描述
POST application/json
{
// 自定义参数,非必传
"state": "test:22",
// 任务描述: 选中ID为1320098173412546的第2张图片放大
// 放大 U1~U4 ,变换 V1~V4
"content": "1320098173412546 U2",
// 支持每个任务配置不同回调地址,非必传
"notifyHook": "http://localhost:8113/notify"
}
返回结果同 /trigger/submit
POST application/json
{
// 自定义参数,非必传
"state": "test:22",
// 图片的base64字符串
"base64": "",
// 支持每个任务配置不同回调地址,非必传
"notifyHook": "http://localhost:8113/notify"
}
返回结果同 /mj/trigger/submit
后续任务完成后,task中prompt即为图片生成的prompt
{
"action":"DESCRIBE",
"id":"3856553004865376",
"prompt":"1️⃣ xxx1 --ar 5:4\n\n2️⃣ xxx2 --ar 5:4\n\n3️⃣ xxx3 --ar 5:4\n\n4️⃣ xxx4 --ar 5:4",
"promptEn":"1️⃣ xxx1 --ar 5:4\n\n2️⃣ xxx2 --ar 5:4\n\n3️⃣ xxx3 --ar 5:4\n\n4️⃣ xxx4 --ar 5:4",
"description":"/describe 3856553004865376.png",
"state":"test:22",
"submitTime":1683779732983,
"startTime":1683779737321,
"finishTime":1683779741711,
"imageUrl":"https://cdn.discordapp.com/ephemeral-attachments/xxxx/xxxx/3856553004865376.png",
"status":"SUCCESS"
}
{
// 动作: IMAGINE(绘图)、UPSCALE(选中放大)、VARIATION(选中变换)
"action":"IMAGINE",
// 任务ID
"id":"8498455807628990",
// 绘图参数
"prompt":"猫猫",
// 翻译后的绘图参数
"promptEn": "Cat",
// 执行的命令
"description":"/imagine 猫猫",
// 自定义参数
"state":"test:22",
// 提交时间
"submitTime":1682473784826,
// 开始处理时间
"startTime":1682473785130,
// 结束时间
"finishTime":null,
// 生成图片的url, 成功时有值
"imageUrl":"https://cdn.discordapp.com/attachments/xxx/xxx/xxxx_xxxx.png",
// 任务状态: NOT_START(未启动)、SUBMITTED(已提交处理)、IN_PROGRESS(执行中)、FAILURE(失败)、SUCCESS(成功)
"status":"IN_PROGRESS",
// 失败原因, 失败时有值
"failReason":""
}
[
{
"action":"IMAGINE",
"id":"8498455807628990",
"prompt":"猫猫",
"promptEn": "Cat",
"description":"/imagine 猫猫",
"state":"test:22",
"submitTime":1682473784826,
"startTime":1682473785130,
"finishTime":null,
"imageUrl":null,
"status":"IN_PROGRESS",
"failReason":""
}
]
POST application/json
{
"action":"IMAGINE",
"id":"8498455807628990",
"prompt":"猫猫",
"promptEn": "Cat",
"description":"/imagine 猫猫",
"state":"test:22",
"submitTime":1682473784826,
"startTime":1682473785130,
"finishTime":null,
"imageUrl":null,
"status":"IN_PROGRESS",
"failReason":""
}
- wechat-midjourney : 代理微信客户端,接入MidJourney,仅示例应用场景,不再维护