智念AIGC平台
这是 智念AIGC平台 的 Web 极简 MVP。当前产品只保留核心闭环:统一创作图片/视频、查看结果、局部重绘、智能超清和必要设置。
运维部署与 API 对接:
- 部署说明
- 开放 API 对接说明
- OpenAPI:
GET /api/v1/openapi.json
启动
服务器一键部署:
bash scripts/deploy.sh
开发环境:
cd /Users/inmanx/Documents/zhinian-creation-assistant
npm install
npm run dev -- --hostname 127.0.0.1 --port 3000
默认访问:
http://127.0.0.1:3000
常用命令:
npm start
npm run start:server
npm run worker
npm run build
npm test
npm run health
npm run info
npm start 会自动先执行一次生产构建,再启动 http://127.0.0.1:3000;开发调试建议继续使用 npm run dev。
Docker 部署默认使用 docker-compose.yml 同时启动 Web 服务和 zhinian-worker 任务 Worker,访问 http://服务器IP:3000。如需修改端口,调整 .env.local 中的 APP_PORT 和 NEXT_PUBLIC_APP_URL 后重新执行 bash scripts/deploy.sh。
Web MVP 信息架构
/自动跳转到/create/create创作,合并图片、视频、局部重绘、智能超清/assets结果,保留历史资产和历史生成任务/image-edit兼容旧入口,自动跳转到创作页的局部重绘/settings设置
主导航只保留创作、结果、设置,不包含工作台、项目、模板中心、Billing 或桌面端入口。
账户登录 / SSO
发布环境默认要求账户登录。Web 登录支持两种方式:一是 OAuth2 Authorization Code,用户跳转到认证中心登录,本服务在 /api/auth/callback 后端换 token;二是在本项目登录页直接输入账号、密码和图形验证码,由本服务后端调用 ${AUTH_BASE}/oauth2/token 的 password grant。两种方式都会通过 ${AUTH_BASE}/oauth2/jwks 本地验签 JWT,再写入 HttpOnly 会话 cookie。
需要在认证中心客户端配置中加入回调地址:
https://你的域名/api/auth/callback
关键环境变量:
ZHINIAN_AUTH_REQUIRED=auto:生产默认启用;本地可信开发可设为0ZHINIAN_AUTH_BASE_URL=https://<gateway-domain>/authZHINIAN_AUTH_CLIENT_ID=customPCZHINIAN_AUTH_CLIENT_SECRETZHINIAN_AUTH_SCOPE=serverZHINIAN_AUTH_ISSUER=https://pig4cloud.comZHINIAN_AUTH_SESSION_SECRET:长随机字符串,用于签名本地登录态
/create、/assets、/settings、第一方生成/资产 API、以及本地上传和生成结果文件都会受登录态保护。/api/v1/* 继续使用 ZHINIAN_API_KEYS,不走浏览器 SSO。
如果认证中心客户端未加入 security.ignore-clients,登录页的账号密码方式会要求图形验证码;验证码图片由 /api/auth/captcha 代理 ${AUTH_BASE}/code/image 获取。
图片创作引擎
图片生成和局部重绘支持在设置页「状态」里按功能切换创作引擎:
jimeng:默认引擎,走火山 Visual 即梦能力。evolink:走 EvoLink GPT Image 2 中转站,提交任务后轮询 EvoLink task 结果。
智能超清仍走即梦超清能力。
即梦图片能力
V1 接入三类能力:
image.generate:即梦图片生成 4.6,默认req_key=jimeng_seedream46_cvtobimage.inpaint:交互编辑 inpainting,默认req_key=jimeng_image2image_dream_inpaintimage.upscale:智能超清,默认req_key=jimeng_i2i_seed3_tilesr_cvtob
后端统一走火山 Visual 异步任务:
- 提交:
CVSync2AsyncSubmitTask - 查询:
CVSync2AsyncGetResult
未配置火山密钥时,JIMENG_VISUAL_MOCK=auto 会自动使用 mock 图,方便先跑通产品流。
EvoLink 图片能力
设置 IMAGE_GENERATE_ENGINE=evolink 或 IMAGE_INPAINT_ENGINE=evolink 后,对应功能会使用 EvoLink:
- 提交:
POST /v1/images/generations - 查询:
GET /v1/tasks/{task_id} - 默认模型:
gpt-image-2
未配置 EVOLINK_API_KEY 且 EVOLINK_MOCK=auto 时,会自动使用 mock 图。
AI 生成台与提示词编排
/create 是新的统一生成入口,按即梦“图片/视频能力在同一个创作产品内切换”的方式组织:
- 一个提示词框:图片和视频都在同一创作面板内编辑最终提示词。
- 模式切换:图片模式走即梦图片生成 4.6;视频模式走 Seedance 视频生成。
- 素材统一上传:一个入口上传图片、视频或音频,不再拆分参考图、主体、分镜等栏目。
@素材引用:上传后自动绑定为@图片1、@视频1、@音频1,chip 和 @ 候选项都显示缩略图。- 提示词校验:通过
/api/prompt/assemble检查提示词中引用的素材是否已绑定。 - 工作台只负责生成输入和提交,不展示任务列表或最近结果。
- 结果保存:图片和视频生成结果会写入资产记录,并在
/assets保留历史任务与历史资产。
未配置 SEEDANCE_API_KEY 时,SEEDANCE_MOCK=auto 会自动使用旧模板样片作为 mock 成品,方便先验收工作流。
环境变量
复制配置样例:
cp .env.example .env.local
核心配置:
ZHINIAN_AUTH_REQUIRED=autoZHINIAN_AUTH_BASE_URLZHINIAN_AUTH_CLIENT_ID=customPCZHINIAN_AUTH_CLIENT_SECRETZHINIAN_AUTH_SCOPE=serverZHINIAN_AUTH_ISSUER=https://pig4cloud.comZHINIAN_AUTH_SESSION_SECRETIMAGE_GENERATE_ENGINE=jimeng或evolinkIMAGE_INPAINT_ENGINE=jimeng或evolinkVOLCENGINE_ACCESS_KEY_IDVOLCENGINE_SECRET_ACCESS_KEYVOLCENGINE_REGION=cn-north-1VOLCENGINE_SERVICE=cvVOLCENGINE_VISUAL_ENDPOINT=https://visual.volcengineapi.comEVOLINK_API_KEYEVOLINK_BASE_URL=https://api.evolink.aiEVOLINK_IMAGE_MODEL=gpt-image-2EVOLINK_IMAGE_QUALITY=mediumEVOLINK_IMAGE_RESOLUTION=2KEVOLINK_MOCK=autoSEEDANCE_API_KEYSEEDANCE_BASE_URLSEEDANCE_MODELSEEDANCE_RATIO:支持16:9、4:3、1:1、3:4、9:16、21:9、adaptiveSEEDANCE_DURATION:Seedance 2.0 支持4到15的整数秒,或-1让模型自动选择SEEDANCE_RESOLUTION:支持480p、720p、1080p;Seedance 2.0 fast 不支持1080pSEEDANCE_MOCKALI_OSS_*:用于上传素材和生成结果转存NEXT_PUBLIC_SUPABASE_URLNEXT_PUBLIC_SUPABASE_ANON_KEYSUPABASE_SERVICE_ROLE_KEY
如果 Supabase 未配置,应用会使用 .runtime/data/web-app-state.json 做本地开发数据层。如果 OSS 未配置,上传和 mock 结果会保存到 .runtime/uploads 和 .runtime/generated-results,并通过 Web 路由提供访问。
数据库
Supabase/Postgres 表结构在:
supabase/schema.sql
当前仍保留必要数据表,供上传、生成任务和用量记录使用:
assetsgeneration_jobsusage_events
任务管理与开放 API
平台支持服务端任务管理:页面和 /api/v1 创建任务后只入队,Worker 统一提交供应商、轮询、转存结果、失败重试和 Webhook 回调。生产部署建议配置 Supabase/Postgres;本地开发可继续使用 .runtime/data/web-app-state.json。
开放 API 使用 API Key:
ZHINIAN_API_KEYS=demo-agent:change-me-public-api-key
ZHINIAN_INTERNAL_WORKER_TOKEN=change-me-worker-token
主要接口:
GET /api/v1/capabilitiesPOST /api/v1/assetsGET /api/v1/assetsPOST /api/v1/jobsGET /api/v1/jobsGET /api/v1/jobs/[id]POST /api/v1/jobs/[id]/cancelGET /api/v1/openapi.json
任务创建支持 Idempotency-Key 幂等键和 webhookUrl 完成回调。Worker 可用 npm run worker 常驻运行,或 npm run worker:once 单次处理。
API
核心图片 API:
POST /api/generations/imageGET /api/generations/imageGET /api/generations/image/[id]POST /api/generations/image/[id]/retryPOST /api/assets/[id]/inpaintPOST /api/assets/[id]/upscalePOST /api/generations/videoGET /api/generations/videoGET /api/generations/video/[id]POST /api/prompt/assembleGET /api/assetsPOST /api/assetsPOST /api/assets/upload
健康检查:
GET /api/health
验证
当前已覆盖:
- 即梦能力矩阵:4.6/inpainting/upscale 启用
- 即梦请求参数构造
- 分镜提示词与
@素材引用编排 - 火山 Visual 签名 canonical request
- Next.js 生产构建
npm test
npm run build
npm run health