支援高速串流輸出、支援多輪對話、支援語音合成、語音辨識、支援聯網搜尋、支援長文檔解讀、支援影像解析,零配置部署,多路token支持,自動清理會話痕跡。
與ChatGPT介面完全相容。
還有以下八個free-api歡迎關注:
Moonshot AI(Kimi.ai)介面轉API kimi-free-api
ZhipuAI (智譜清言) 介面轉API glm-free-api
階躍星辰(躍問StepChat) 介面轉API step-free-api
阿里通義(Qwen) 介面轉API qwen-free-api
秘塔AI (Metaso) 介面轉API metaso-free-api
訊飛星火(Spark)介面轉API spark-free-api
深度求索(DeepSeek)介面轉API deepseek-free-api
聆心智能(Emohaa) 介面轉API emohaa-free-api
逆向API是不穩定的,建議前往MiniMax官方https://www.minimaxi.com/platform 付費使用API,避免封鎖的風險。
本組織和個人不接受任何資金捐贈和交易,此計畫是純粹研究交流學習性質!
僅限自用,禁止對外提供服務或商用,避免對官方造成服務壓力,否則風險自擔!
僅限自用,禁止對外提供服務或商用,避免對官方造成服務壓力,否則風險自擔!
僅限自用,禁止對外提供服務或商用,避免對官方造成服務壓力,否則風險自擔!
此連結僅臨時測試功能,只有一路並發,如果遇到異常請稍後重試,建議自行部署使用。
https://udify.app/chat/uqBly3aW1LTwzzb3
語音合成就是創造語音
語音辨識就是創建轉錄
從海螺AI 取得token
進入海螺AI隨便發起一個對話,然後F12打開開發者工具,從Application > LocalStorage中找到_token
的值,這將作為Authorization的Bearer Token值: Authorization: Bearer TOKEN
目前似乎限制同個帳號同時只能有一路輸出,你可以透過提供多個帳號的_token並使用,
拼接提供:
Authorization: Bearer TOKEN1,TOKEN2,TOKEN3
每次請求服務會從中挑選一個。
請準備一台具有公網IP的伺服器並將8000連接埠開放。
拉取鏡像並啟動服務
docker run -it -d --init --name hailuo-free-api -p 8000:8000 -e TZ=Asia/Shanghai vinlic/hailuo-free-api:latest
查看服務即時日誌
docker logs -f hailuo-free-api
重啟服務
docker restart hailuo-free-api
停止服務
docker stop hailuo-free-api
version : ' 3 '
services :
hailuo-free-api :
container_name : hailuo-free-api
image : vinlic/hailuo-free-api:latest
restart : always
ports :
- " 8000:8000 "
environment :
- TZ=Asia/Shanghai
注意:部分部署區域可能無法連接hailuo,如容器日誌出現請求逾時或無法連接,請切換其他區域部署!注意:免費帳戶的容器實例將在一段時間不活動時自動停止運行,這會導致下次請求時遇到50秒或更長的延遲,建議查看Render容器保活
fork本專案到你的github帳號下。
造訪Render 並登入你的github帳號。
建立你的Web Service(New+ -> Build and deploy from a Git repository -> Connect你fork的專案-> 選擇部署區域-> 選擇實例類型為Free -> Create Web Service)。
等待建置完成後,複製已指派的網域名稱並拼接URL存取即可。
注意:Vercel免費帳戶的請求回應逾時時間為10秒,但介面回應通常較長,可能會遇到Vercel回傳的504逾時錯誤!
請先確保安裝了Node.js環境。
npm i -g vercel --registry http://registry.npmmirror.com
vercel login
git clone https://github.com/LLM-Red-Team/hailuo-free-api
cd hailuo-free-api
vercel --prod
請準備一台具有公網IP的伺服器並將8000連接埠開放。
請先安裝好Node.js環境且配置好環境變量,確認node指令可用。
安裝依賴
npm i
安裝PM2進行進程守護
npm i -g pm2
編譯構建,看到dist目錄就是構建完成
npm run build
啟動服務
pm2 start dist/index.js --name " hailuo-free-api "
查看服務即時日誌
pm2 logs hailuo-free-api
重啟服務
pm2 reload hailuo-free-api
停止服務
pm2 stop hailuo-free-api
使用以下二次開發客戶端接入free-api系列專案更快更簡單,支援文件/圖像上傳!
由Clivia 二次開發的LobeChat https://github.com/Yanyutin753/lobe-chat
由時間@ 二次開發的ChatGPT Web https://github.com/SuYxh/chatgpt-web-sea
目前支援與openai相容的/v1/chat/completions
接口,可自行使用與openai或其他相容的用戶端接入接口,或使用dify 等線上服務接入使用。
對話補全接口,與openai的chat-completions-api 相容。
POST /v1/chat/completions
header 需要設定Authorization 頭部:
Authorization: Bearer [_token]
請求資料:
{
// model模型名称可以乱填
"model" : " hailuo " ,
"messages" : [
{
"role" : " user " ,
"content" : "你是谁? "
}
],
// 如果使用SSE流请设置为true,默认false
"stream" : false
}
響應數據:
{
"id" : " 242830597915504644 " ,
"model" : " hailuo " ,
"object" : " chat.completion " ,
"choices" : [
{
"index" : 0 ,
"message" : {
"role" : " assistant " ,
"content" : "我是海螺AI,由上海稀宇科技有限公司(MiniMax)自主研发的AI助理。我可以帮助你回答各种问题,提供信息查询、生活建议、学习辅导等服务。如果你有任何问题,随时可以向我提问。 "
},
"finish_reason" : " stop "
}
],
"usage" : {
"prompt_tokens" : 1 ,
"completion_tokens" : 1 ,
"total_tokens" : 2
},
"created" : 1714751470
}
建立語音接口,與openai的audio-create-speech-api 相容,只支援mp3格式輸出。
male-botong 思远 [兼容 tts-1 alloy]
Podcast_girl 心悦 [兼容 tts-1 echo]
boyan_new_hailuo 子轩 [兼容 tts-1 fable]
female-shaonv 灵儿 [兼容 tts-1 onyx]
YaeMiko_hailuo 语嫣 [兼容 tts-1 nova]
xiaoyi_mix_hailuo 少泽 [兼容 tts-1 shimmer]
xiaomo_sft 芷溪 [兼容 tts-1-hd alloy]
cove_test2_hailuo 浩翔(英文)
scarlett_hailuo 雅涵(英文)
Leishen2_hailuo 模仿雷电将军 [兼容 tts-1-hd echo]
Zhongli_hailuo 模仿钟离 [兼容 tts-1-hd fable]
Paimeng_hailuo 模仿派蒙 [兼容 tts-1-hd onyx]
keli_hailuo 模仿可莉 [兼容 tts-1-hd nova]
Hutao_hailuo 模仿胡桃 [兼容 tts-1-hd shimmer]
Xionger_hailuo 模仿熊二
Haimian_hailuo 模仿海绵宝宝
Robot_hunter_hailuo 模仿变形金刚
Linzhiling_hailuo 小玲玲
huafei_hailuo 拽妃
lingfeng_hailuo 东北er
male_dongbei_hailuo 老铁
Beijing_hailuo 北京er
JayChou_hailuo JayJay
Daniel_hailuo 潇然
Bingjiao_zongcai_hailuo 沉韵
female-yaoyao-hd 瑶瑶
murong_sft 晨曦
shangshen_sft 沐珊
kongchen_sft 祁辰
shenteng2_hailuo 夏洛特
Guodegang_hailuo 郭嘚嘚
yueyue_hailuo 小月月
從F12 Network中尋找robot_custom_config請求回應data.formInfo.userVoiceList自己的克隆音色ID,格式為puv_******************
。
請在docker啟動或系統中配置REPLACE_AUDIO_MODEL
環境變數用於映射自訂發音者到openai的發音人模型,每個發音人使用,
逗號隔開。
映射的順序為:alloy,echo,fable,onyx,nova,shimmer,目前可以定義6個映射。
映射範例:
Podcast_girl -> alloy
yueyue_hailuo -> echo
keli_hailuo -> fable
以上映射關係的環境配置如下所示:
REPLACE_AUDIO_MODEL="Podcast_girl,yueyue_hailuo,keli_hailuo";
POST /v1/audio/speech
header 需要設定Authorization 頭部:
Authorization: Bearer [_token]
請求資料:
{
// model模型名称可以乱填
"model" : " hailuo " ,
// 语音内容,尽量不要包含指令(否则可能导致模型回答你的问题)
"input" : "你在做什么? " ,
// 发音人ID,可以使用官方或者自己克隆的音色
"voice" : " Podcast_girl "
}
響應數據:
audio/mpeg 二進位資料流(mp3檔)
建立轉錄接口,與openai的audio-create-transcription-api 相容。
POST /v1/audio/transcriptions
header 需要設定Authorization 頭部:
Authorization: Bearer [_token]
請求資料(multipart/form-data):
file 要转录的音频文件对象(不是文件名),格式为:wav、mp3、mpeg、mpga、m4a、ogg、flac。
model 模型名称,可以乱填
response_format 仅支持json或text
響應數據:
{
"text": "嗯,多年前呢我是个穷小子,我有一个喜欢的女孩,他有一双会说话的眼睛,他偏爱雏菊般的淡黄色。我我每天都骑自行车送他上下学专挑那个坑坑洼洼的路走。然后编的时候,我就能感觉到他用双手在后边用力的拽我的衣服,我好开心哪。然后回家以后,我才发现我唯一的一件衬衣变成了燕尾服。我每天中午会把我妈妈给我带的荷包蛋,我给她吃,他只吃蛋白,他把蛋蛋黄留给我,我我真的我好感动啊。呃,到后来我我知道呃,吃蛋黄反腹唇口,呃,我们同窗三年,我给他写了一百多封信,跟你联系我我我我我我每一封信我都换一个笔记,我怕他认出来,我那我很不好意思。所以说长此以往的练习,我在书法大赛获得了一等奖。直到有一天,他准备坐火车去省城上学的时候,我也没有把我自己的话跟他说出来。哎,我去那天也是像今天一样下着雨,他也带着那条漂亮的黄丝巾,我递给他一篮子鸡蛋,他没接,他反问我说有多少个鸡蛋,我说有一百个,他说他一天吃一个,一百天就吃完了再想吃,还有吗?这个其实我知道他懂我那句话,可是我当时就像被雷击中了一样无果果主人我什么话我都说不出来。当我缓过神儿来的时候,他已经上车了,车已经开了,车已经开出一段距离了。那个时候我只要大声的喊,他一定能够听到我张嘴了,没声儿。从那一刻起,我就生了病,预言是癌症,没当下雨或者是重要场合,我者无法说话。其实这么多年我一直想找一个机会,我希望他能够重新出现在我眼前。今天这个机会来了,此时此刻他就坐在离我三米半远的地方。我要把我二十年前要跟你说的话,大声的告诉你,哇,李丽,你你只要愿意跟我在一起鸡蛋,我给你带一辈子,有的是。"
}
提供一個可存取的檔案URL或BASE64_URL進行解析。
POST /v1/chat/completions
header 需要設定Authorization 頭部:
Authorization: Bearer [_token]
請求資料:
{
// model模型名称可以乱填
"model" : " hailuo " ,
"messages" : [
{
"role" : " user " ,
"content" : [
{
"type" : " file " ,
"file_url" : {
"url" : " https://mj101-1317487292.cos.ap-shanghai.myqcloud.com/ai/test.pdf "
}
},
{
"type" : " text " ,
"text" : "文档里说了什么? "
}
]
}
],
// 如果使用SSE流请设置为true,默认false
"stream" : false
}
響應數據:
{
"id" : " 242835041910616068 " ,
"model" : " hailuo " ,
"object" : " chat.completion " ,
"choices" : [
{
"index" : 0 ,
"message" : {
"role" : " assistant " ,
"content": "文档中包含了一系列的古代魔法仪式和咒语,这些内容似乎源自古希腊罗马时期的魔法文献,如《希腊魔法纸莎草纸》(PGM,全称为Papyri Graecae Magicae)。以下是每个文档内容的简要概述:nn1. 文档1中描述了一个仪式,其中包括将面包分成七小块,然后在那些被暴力杀害的地方留下这些面包块,并念诵一段咒语。这个仪式的目的是为了吸引一个特定女性的注意,让她对施法者产生强烈的感情和欲望。nn2. 文档2中包含了一个咒语,要求一个名为Didymos的施法者召唤一个名为Tereous的女性,通过念诵一系列的魔法名字和咒语,使她感到痛苦和渴望,直到她来到施法者身边。nn3. 文档3中提供了一个简单的仪式,施法者需要保持三天的纯洁,并献上乳香作为祭品,念诵一个特定的名字(NEPHERIRI),以此来吸引一个美丽的女性。nn4. 文档4中描述了一个使用没药的仪式,施法者在献上没药的同时念诵一段咒语,目的是让一个特定的女性对施法者产生强烈的爱慕之情,即使她正在做其他事情,也会被这种强烈的感情所占据。nn这些文档内容反映了古代人们对于魔法和咒语的信仰,以及他们试图通过这些仪式来影响他人情感和行为的愿望。需要注意的是,这些内容仅供学术研究和了解历史之用,现代社会中不应使用这些仪式或咒语来干预他人的自由意志。"
},
"finish_reason" : " stop "
}
],
"usage" : {
"prompt_tokens" : 1 ,
"completion_tokens" : 1 ,
"total_tokens" : 2
},
"created" : 1714752530
}
提供一個可存取的圖像URL或BASE64_URL進行解析。
此格式相容於gpt-4-vision-preview API格式,您也可以用這個格式傳送文件進行解析。
POST /v1/chat/completions
header 需要設定Authorization 頭部:
Authorization: Bearer [_token]
請求資料:
{
"model" : " hailuo " ,
"messages" : [
{
"role" : " user " ,
"content" : [
{
"type" : " image_url " ,
"image_url" : {
"url" : " https://ecmb.bdimg.com/tam-ogel/-1384175475_-1668929744_259_194.jpg "
}
},
{
"type" : " text " ,
"text" : "图里是什么? "
}
]
}
],
// 如果使用SSE流请设置为true,默认false
"stream" : false
}
響應數據:
{
"id" : " 242835404705341445 " ,
"model" : " hailuo " ,
"object" : " chat.completion " ,
"choices" : [
{
"index" : 0 ,
"message" : {
"role" : " assistant " ,
"content" : "图里是“海螺AI”的标识。 "
},
"finish_reason" : " stop "
}
],
"usage" : {
"prompt_tokens" : 1 ,
"completion_tokens" : 1 ,
"total_tokens" : 2
},
"created" : 1714752616
}
偵測_token是否存活,如果存活live未true,否則為false,請不要頻繁(小於10分鐘)呼叫此介面。
POST /token/check
請求資料:
{
"token" : " eyJhbGciOiJIUzUxMiIsInR5cCI6IkpXVCJ9... "
}
響應數據:
{
"live" : true
}
如果您正在使用Nginx反向代理hailuo-free-api,請新增以下設定項優化流的輸出效果,優化體驗感。
# 关闭代理缓冲。当设置为off时,Nginx会立即将客户端请求发送到后端服务器,并立即将从后端服务器接收到的响应发送回客户端。
proxy_buffering off ;
# 启用分块传输编码。分块传输编码允许服务器为动态生成的内容分块发送数据,而不需要预先知道内容的大小。
chunked_transfer_encoding on ;
# 开启TCP_NOPUSH,这告诉Nginx在数据包发送到客户端之前,尽可能地发送数据。这通常在sendfile使用时配合使用,可以提高网络效率。
tcp_nopush on ;
# 开启TCP_NODELAY,这告诉Nginx不延迟发送数据,立即发送小数据包。在某些情况下,这可以减少网络的延迟。
tcp_nodelay on ;
# 设置保持连接的超时时间,这里设置为120秒。如果在这段时间内,客户端和服务器之间没有进一步的通信,连接将被关闭。
keepalive_timeout 120 ;
由於推理側不在hailuo-free-api,因此token不可統計,將以固定數字返回。