亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

公眾號接入chatGPT的詳細教程 附Python源碼

 更新時間:2023年02月18日 14:53:43   作者:攻城獅杰森  
這篇文章主要介紹了公眾號接入chatGPT教程附Python源碼,這里需要大家準備一個域名,一臺服務器和一個公眾號,本文結合實例代碼給大家介紹的非常詳細,需要的朋友可以參考下

前置準備

  1. 一個域名
  2. 一臺服務器
  3. 一個公眾號

域名配置

在你的域名服務商新建二級域名并綁定服務器主機IP

服務器配置

上傳下面的python文件到你的服務器,并修改代碼段中相應位置代碼(token、api-key、port)

import time
from flask import Flask,make_response,request
import openai
from flask import Flask, request
from flask_caching import Cache
import xml.etree.cElementTree as ET
import hashlib
import requests
import re
import os

cnt = 0
my_wx_token = "" # 自定義字母和數(shù)字組合即可,后續(xù)需要填入公眾號后臺
my_gpt_key = "" # 這里填寫你在OpenAI后臺創(chuàng)建的API-KEY
my_switch_chatgpt = True

app = Flask(__name__)
env_dist = os.environ
cache = Cache(app, config={'CACHE_TYPE': 'simple', "CACHE_DEFAULT_TIMEOUT": 30})

@app.route('/',methods=['GET','POST'])
def wechat():
    if request.method == 'GET':
        signature = request.args.get("signature", "")

        timestamp= request.args.get("timestamp", "")

        nonce= request.args.get("nonce", "")

        echostr= request.args.get("echostr", "")
        print(signature, timestamp, nonce, echostr)

        token=my_wx_token

        data =[token, timestamp, nonce]

        data.sort()

        temp = ''.join(data)

        sha1 = hashlib.sha1(temp.encode('utf-8'))

        hashcode=sha1.hexdigest()
        print(hashcode)

        if hashcode == signature:
            print("wechat commit check OK")
            return echostr
        else:
            print("GET error input msg")
            return "error-return\r\n"
    else:
        xmlData = ET.fromstring(request.stream.read())
        msg_type = xmlData.find('MsgType').text
        if msg_type == 'text':
            ToUserName = xmlData.find('ToUserName').text
            FromUserName = xmlData.find('FromUserName').text
            CreateTime = xmlData.find('CreateTime').text
            
            print(ToUserName)
            print(FromUserName)
            print(CreateTime)
            
            global cnt
            cnt += 1
            print('-------> ' + str(cnt))
            
            return generate_response_xml(FromUserName, ToUserName, xmlData.find('Content').text)
                           
def text_reply(FromUserName, ToUserName, output_content):
    reply = '''
    <xml>
    <ToUserName><![CDATA[%s]]></ToUserName>
    <FromUserName><![CDATA[%s]]></FromUserName>
    <CreateTime>%s</CreateTime>
    <MsgType><![CDATA[text]]></MsgType>
    <Content><![CDATA[%s]]></Content>
    </xml>
    '''
    response = make_response(reply % (FromUserName, ToUserName, str(int(time.time())), output_content))
    response.content_type = 'application/xml'
    return response

def generate_response_xml(FromUserName, ToUserName, input_content):
    output_content = generate_response(input_content)
    return text_reply(FromUserName, ToUserName, output_content)

outofsevice_txt = "抱歉,<a href=\"https://mp.weixin.qq.com/s/0LN37YiERJgMyvIDpzRcAQ\">攻城獅杰森的ChatGPT服務助手</a>正在維護中,暫時無法預估維護持續(xù)時間,請明天再來嘗試吧。"

@cache.memoize(timeout=60)
def generate_response(prompt):
    
    if not my_switch_chatgpt:
        return outofsevice_txt
        
    openai.api_key = my_gpt_key
    
    response = openai.Completion.create(
        model="text-davinci-003",
        prompt=prompt,
        temperature=0,
        max_tokens=1024,
        top_p=1,
        frequency_penalty=0.0,
        presence_penalty=0.0,
    )
    
    message = response.choices[0].text
    print(message)
    
    ans = message.strip()
    return ans
               
if __name__ == '__main__':
    app.run(host='0.0.0.0', port=xxxx, debug=True)#開放xxxx端口

使用寶塔是比較快捷的配置方式,安裝寶塔面板后,進入軟件商店,安裝下面兩個插件

打開 python 項目管理器 ,簡單配置下我們要啟動的項目

啟動后映射項目域名,頂級域和二級域都可以,比如我這里填入的是 chatgpt.coder-jason.cn 

公眾號配置

進入公眾號后臺,找到設置與開發(fā),進入基本配置,由于我這里已經配置好了,這里僅演示下怎么添加啟用

點擊添加配置

token 值就是在上述代碼段中填入的值,自定義字母和數(shù)字組合即可

點擊提交后,如果服務器中的項目啟動無誤,則會提示 token校驗成功

接下來就可以回到公眾號和 chatGPT 愉快的交流啦~

到此這篇關于公眾號接入 chatGPT教程 附Python源碼的文章就介紹到這了,更多相關公眾號接入 chatGPT內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • Pytorch數(shù)據(jù)類型Tensor張量操作的實現(xiàn)

    Pytorch數(shù)據(jù)類型Tensor張量操作的實現(xiàn)

    本文主要介紹了Pytorch數(shù)據(jù)類型Tensor張量操作的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-07-07
  • python筆記(1) 關于我們應不應該繼續(xù)學習python

    python筆記(1) 關于我們應不應該繼續(xù)學習python

    關于Python,如果你要學習,建議大家查看一下網站:因為本人也是剛剛決定收集點零碎時間來學習下它,推薦可能并不是最好的
    2012-10-10
  • pymysql模塊的操作實例

    pymysql模塊的操作實例

    在本篇文章里小編給大家分享的是關于pymysql模塊的簡單操作,有需要的朋友們可以參考下。
    2019-12-12
  • python腳本實現(xiàn)mp4中的音頻提取并保存在原目錄

    python腳本實現(xiàn)mp4中的音頻提取并保存在原目錄

    這篇文章主要介紹了python腳本實現(xiàn)mp4中的音頻提取并保存在原目錄,本文給大家通過實例代碼介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-02-02
  • 淺析python實現(xiàn)scrapy定時執(zhí)行爬蟲

    淺析python實現(xiàn)scrapy定時執(zhí)行爬蟲

    這篇文章主要介紹了淺析python實現(xiàn)scrapy定時執(zhí)行爬蟲的相關資料,需要的朋友可以參考下
    2018-03-03
  • Python繪制散點密度圖的三種方式詳解

    Python繪制散點密度圖的三種方式詳解

    散點密度圖是在散點圖的基礎上,計算了每個散點周圍分布了多少其他的點,并通過顏色表現(xiàn)出來。本文主要介紹了Python繪制散點密度圖的三種方式,需要的可以參考下
    2022-06-06
  • python 實現(xiàn)IP子網計算

    python 實現(xiàn)IP子網計算

    這篇文章主要介紹了python 實現(xiàn)IP子網計算的方法,幫助大家更好的理解和使用python,感興趣的朋友可以了解下
    2021-02-02
  • Python-apply(lambda x: )的使用及說明

    Python-apply(lambda x: )的使用及說明

    這篇文章主要介紹了Python-apply(lambda x: )的使用及說明,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-02-02
  • python依賴安裝兩種常用方式

    python依賴安裝兩種常用方式

    這篇文章主要給大家介紹了關于python依賴安裝兩種常用方式的相關資料,python本身做為一門解釋性語言,說它功能強大,是因為它有著豐富的模塊或稱之為依賴(包),需要的朋友可以參考下
    2023-10-10
  • 使用BeeWare實現(xiàn)iOS調用Python方式

    使用BeeWare實現(xiàn)iOS調用Python方式

    這篇文章主要介紹了使用BeeWare實現(xiàn)iOS調用Python方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-12-12

最新評論