明敏 詹士 發(fā)自 凹非寺
來(lái)源 | 量子位 QbitAI
前兩天還看到不少人討論,要是ChatGPT接入微信是啥感覺(jué)?
這不,想你所想,項(xiàng)目已經(jīng)來(lái)了~
來(lái)看效果,ChatGPT就出現(xiàn)在普通的微信對(duì)話框里,有問(wèn)必答:
圖源@我是小馬甲(公眾號(hào))
甚至還能拉入群聊,大家共用,誰(shuí)有問(wèn)題艾特就好:
圖源@我是小馬甲(公眾號(hào))
如果不想自己來(lái)操作,還能手動(dòng)添加演示Bot微信好友(wx:RuYoChatBot),來(lái)體驗(yàn)~
真的,永遠(yuǎn)不要低估程序員的手速。
截至目前,在GitHub及社交平臺(tái)上已經(jīng)發(fā)現(xiàn)了3個(gè)類似項(xiàng)目,都能實(shí)現(xiàn)把ChatGPT接入微信。
熱度最高的項(xiàng)目,GitHub星已經(jīng)超過(guò)1K了~
微博評(píng)論區(qū)也是一水的@我的印象筆記。
具體怎么實(shí)現(xiàn)的?一起來(lái)看~
可以手動(dòng)添加ChatGPT Bot好友
在此,我們選擇其中一種相對(duì)簡(jiǎn)單的方法進(jìn)行講解,方法來(lái)自@我是小馬甲(微信公眾號(hào))。
首先是部署環(huán)節(jié),可以有兩種方式。
其一,需要有Golang環(huán)境。
優(yōu)點(diǎn)是操作簡(jiǎn)潔,但是推薦有一定技術(shù)底子的童鞋。
git clone https://github.com/malaohu/wechat-chatGPT.git
cd wechat-chatGPT
go mod tidy
在修改配置文件后,啟動(dòng)運(yùn)行即可。
go run main.go
另一種部署方式不需要本地Golang環(huán)境,windows和linux都適用。
直接下載執(zhí)行文件和配置文件,可執(zhí)行文件和配置文件放到同一個(gè)目錄里。
Window系統(tǒng)雙擊就能運(yùn)行了。
但是這種方法仍舊是要有OpenAI注冊(cè)賬號(hào)的(方法大家可以自行搜索某寶等)。
在OpenAI官網(wǎng)上創(chuàng)建一個(gè)新的秘鑰,用于修改配置文件。
記得將API keys復(fù)制下來(lái)。
默認(rèn)配置文件config.dev.json里面僅有2項(xiàng)配置:
"api_key": "your api key",
"auto_pass": true
把剛剛復(fù)制好的API key,復(fù)制到y(tǒng)our api key的位置。
原作提示,auto_pass指的是是否自動(dòng)同意加好友,用的人少的情況可以選ture。
程序啟動(dòng)后,瀏覽器就會(huì)跳出一個(gè)二維碼網(wǎng)頁(yè),然后用微信掃碼登錄即可。
如果要切換微信賬號(hào),要將可執(zhí)行文件所在目錄中的storage.json文件刪除。
需要注意的是,這種方法在mac系統(tǒng)上運(yùn)行會(huì)有點(diǎn)麻煩,安裝包為.exe格式,所以自己來(lái)架一個(gè)Windows系統(tǒng)。
當(dāng)然還有懶人推薦路線——原作放出了一個(gè)演示bot的微信號(hào)(wx:RuYoChatBot),大家可以直接微信加好友。
p.s.好友需要手動(dòng)通過(guò),等待時(shí)間可能較長(zhǎng)~
GitHub上還有兩種方法
除了以上,還有兩種方法這兩天也比較火。
不過(guò)都需要用到Docker,而且也要有注冊(cè)好的OpenAI賬號(hào),下面簡(jiǎn)單介紹下。
其中之一基于NodeJS環(huán)境和聊天機(jī)器人開(kāi)源項(xiàng)目webchaty,AI可在群里回復(fù)消息。(鏈接已附在文末)
配置Docker文件:
// build
docker build --pull --rm -f "Dockerfile" -t wechatbot:latest "."
// run, and then you will see some logs
docker run --name wechatbot wechatbot:latest
從OpenAI處獲取session-token。
方法為登錄ChatGPT網(wǎng)頁(yè),點(diǎn)擊“開(kāi)發(fā)者工具”,進(jìn)入Application欄,在Cookie下拉菜單找到chat.openai.com,就能看到Secure-next-auth.session-token的值:
將Token值替換src/index.js內(nèi)的“ChatGPTSessionToken”,然后,在本地運(yùn)行下面的代碼:
// install dependencies
npm i
// start:
// dev
npm run dev
//or
// build
npm run build
// run lib
node lib/bundle.esm.js
這樣,就能看到其正在運(yùn)行,再通過(guò)掃描二維碼,登錄你的微信。
如此一來(lái),向你的微信發(fā)送信息,就能收到回復(fù)。
作者展示,其回復(fù)表現(xiàn)如下,目前已獲240Star。
另一種辦法同樣基于wechaty需與Docker一同“食用”,不過(guò)獲贊更多。
老樣子,配置Docker。
cp config.yaml.example config.yaml
# Change Config.yaml
docker run -d --name wechat-chatgpt -v $(pwd)/config.yaml:/app/config.yaml holegots/wechat-chatgpt:latest
# login with qrcode
docker logs -f wechat-chatgpt
從GitHub下載文件包(鏈接已附在文末)后進(jìn)行安裝:
npm install && poetry install
然后復(fù)制配置文件設(shè)置項(xiàng)目。
cp config.yaml.example config.yaml
配置OpenAI賬密:
chatGPTAccountPool:
- email:
password:
# if you hope only some keywords can trigger chatgpt on private chat, you can set it like this:
chatPrivateTiggerKeyword: ""
然后啟動(dòng)項(xiàng)目即可,如第一次登錄,需掃描二維碼:
npm run dev
目前,該方式在GitHub上獲星已超1k。
最后,聊聊上述實(shí)現(xiàn)方法的注意事項(xiàng):
1、還是需要有OpenAI的賬號(hào),要先完成注冊(cè)
2、將用到docker、GO等,且需要獲取token,完全小白嘗試起來(lái)可能有點(diǎn)難度
3、文中,基于NodeJS和webchaty的方式如若無(wú)法登錄微信,請(qǐng)檢查項(xiàng)目根目錄是否有文件——wechaty-puppet-wechat.memory-card.json,如果有,請(qǐng)刪除后重試。
4、最后一種方法,如無(wú)法通過(guò)上述配置登錄OpenAI,也可手動(dòng)登錄獲取session token,保存至config.yaml的方式。(獲取方式前文已呈現(xiàn))
5、目前ChatGPT使用者過(guò)多,一時(shí)難以登錄,不妨過(guò)幾個(gè)小時(shí)再試試;
傳送門
方法一(@我是小馬甲):
方法二(@AutumnWhj):
https://github.com/AutumnWhj/ChatGPT-wechat-bot
方法三(@fuergaosi233):
https://github.com/fuergaosi233/wechat-chatgpt
—完—