Questo è un programma basato su Next.js che collega l'account pubblico WeChat al programma ChatGPT. Puoi fare domande direttamente a ChatGPT e ricevere risposte attraverso l'account pubblico WeChat.
-
Clona il repository e accedi alla directory del progetto.
git clone https://github.com/CyrusZhou-CN/MP_WeiXin_ChatGPT.git cd MP_WeiXin_ChatGPT
-
Crea un file
.env
nella directory principale del progetto. -
Aggiungi i seguenti parametri di configurazione nel file
.env
e sostituiscili con i valori effettivi.APP_ID=your_app_id APP_SECRET=your_app_secret TOKEN=your_token ENCODING_AES_KEY=(necessario quando il modo sicuro è abilitato) SUBSCRIBE_REPLY=Benvenuti, potete fare domande direttamente a ChatGPT CONTENT_TOO_LONG=La risposta è troppo lunga e il tempo è scaduto. Per favore, riprova a fare la domanda OPENAI_API_KEY=your_openai_api_key OPENAI_MODEL=gpt-3.5-turbo OPENAI_TIMEOUT=60000 IS_AUTHENTICATED=false SECRET_COOKIE_PASSWORD=(Puoi usare il comando openssl rand -hex 16 per generare un segreto) MYSQL_HOST=localhost MYSQL_PORT=6306 MYSQL_USER=weixin MYSQL_PASSWORD=weixin MYSQL_DATABASE=weixin VERCEL=false
-
Sostituisci
your_app_id
,your_app_secret
,your_token
,your_encoding_aes_key
eyour_openai_api_key
con i valori effettivi che hai ottenuto dalla piattaforma per sviluppatori WeChat e dalla chiave API di OpenAI.
Nota: nell'interfaccia di gestione dell'account pubblico WeChat, l'URL è l'indirizzo completo che inizia con l'indirizzo del tuo server, ad esempio http://yourdomain.com/api/wechat
docker compose up -d
-
Nella directory principale del progetto, esegui il comando seguente per installare le dipendenze.
npm install
-
Verifica il database mediante il comando
npm test
-
Avvia il server di sviluppo mediante il comando seguente.
npm run dev
-
Configura l'indirizzo del server nell'account pubblico WeChat, e inserisci il Token del file di configurazione come valore del parametro
TOKEN
. -
Sottometti le impostazioni e attiva il servizio.
-
Accedi all'account pubblico WeChat e inizia a testare il programma.
Sono state create due tabelle nel database: system_log
e reply_cache
.
- `id`: ID univoco generato automaticamente dal sistema.
- `level`: il livello del log, che può essere 'error', 'warn', 'info', 'debug'.
- `message`: il messaggio del log.
- `createdAt`: il momento in cui il log è stato creato.
- `updatedAt`: il momento in cui il log è stato aggiornato.
- `id`: ID univoco generato automaticamente dal sistema.
- `msgId`: l'ID del messaggio univoco che identifica il messaggio nell'account pubblico WeChat.
- `responseId`: l'ID della risposta associata.
- `input`: il contenuto della domanda dell'utente.
- `reply`: la risposta di ChatGPT.
- `ask` int(11) NOT NULL il numero di richieste di connessione all'account pubblico WeChat.
- `createdAt`: il momento in cui la risposta è stata creata.
- `updatedAt`: il momento in cui la risposta è stata aggiornata.
- `expireAt`: il tempo di scadenza della cache, che è utilizzato per controllare la validità della cache.
Nell'applicazione, utilizziamo il modulo sequelize
per gestire la cache e salvarla nella tabella reply_cache
.
-
Nella directory principale del progetto, esegui il seguente comando per compilare l'applicazione.
npm run build
-
Carica la directory
.next
generata, il filepackage.json
e il file.env
sul server. -
Sul server, esegui il seguente comando per installare le dipendenze.
npm install
-
Sul server, esegui il seguente comando per avviare l'applicazione.
npm start
-
Configura l'indirizzo del server nell'account pubblico WeChat, e inserisci il Token del file di configurazione come valore del parametro
TOKEN
. -
Sottometti le impostazioni e attiva il servizio.
-
Accedi all'account pubblico WeChat e inizia a utilizzare il programma.
-
Se riscontri problemi, utilizza lo strumento di debug dell'account pubblico WeChat.
Se il tuo server non supporta l'accesso esterno all'account pubblico WeChat, puoi utilizzare un programma proxy di richiesta PHP per inviare le richieste ricevute all'applicazione Next.js che supporta l'API.
Ecco come si usa:
-
Copia il contenuto del file
./php/proxy.php
, crea un nuovo file chiamatoproxy.php
e incolla il contenuto. -
Sostituisci
'https://*.vercel.app/api/wechat'
con l'URL dell'applicazione Next.js che hai effettivamente distribuito come descritto sopra. -
Carica il file
proxy.php
su un server che supporta il servizio PHP e annota l'URL in cui il file è stato caricato. -
Nell'account pubblico WeChat, configura l'URL del servizio come URL di
proxy.php
.
Se usi Vercel, devi tenere a mente che il tempo di timeout predefinito per le funzioni di Vercel è di 10 secondi e, quando ChatGPT elabora un grande volume di testo, potrebbe richiedere più tempo e generare un errore, quindi è preferibile distribuire l'applicazione sul proprio server.
Poiché Vercel non supporta SQLite, offre un servizio di database PostgreSQL basato su cloud come soluzione alternativa.
Crea un database PostgreSQL cliccando sulla scheda "Storage" dopo aver effettuato il login nel dashboard di Vercel.
Imposta le variabili d'ambiente.
La configurazione di connessione di PostgreSQL di Vercel può essere visualizzata nella scheda ".env.local" del database.
Impostazioni corrispondenti per questo progetto:
DB_TYPE=postgres
DB_HOST=POSTGRES_HOST
DB_PORT=5432
DB_USER=POSTGRES_USER
DB_PASS=POSTGRES_PASSWORD
DB_NAME=POSTGRES_DATABASE
Indirizzo di backend: http://localhost:3000/admin
Nome utente/password: admin/admin
Traduzione di Chat GPT.