IT评测·应用市场-qidao123.com

标题: 微信公众号集成文心一言API [打印本页]

作者: 数据人与超自然意识    时间: 2024-7-20 12:58
标题: 微信公众号集成文心一言API
要将微信公众号集成文心一言API,并使用Python语言和Flask技术实现,可以按照以下步骤举行操纵:
  1. from flask import Flask, request,jsonify,make_response
  2. import erniebot
  3. from gevent import pywsgi
  4. import xml.etree.cElementTree as ET
  5. import hashlib
  6. import time
  7. app = Flask(__name__)
  8. @app.route('/wx',methods=['GET','POST'])
  9. def wechat():
  10.     if request.method == 'GET':
  11.         signature = request.args.get("signature", "")
  12.         timestamp= request.args.get("timestamp", "")
  13.         nonce= request.args.get("nonce", "")
  14.         echostr= request.args.get("echostr", "")
  15.         print(signature, timestamp, nonce, echostr)
  16.         token="微信公众平台设置的token与此处token一致"
  17.         data =[token, timestamp, nonce]
  18.         data.sort()
  19.         temp = ''.join(data)
  20.         sha1= hashlib.sha1(temp.encode('utf-8'))
  21.         hashcode=sha1.hexdigest()
  22.         if hashcode == signature:
  23.             return echostr
  24.         else:
  25.             return "error"
  26.     else:
  27.         xmlData = ET.fromstring(request.stream.read())
  28.         msg_type = xmlData.find('MsgType').text
  29.         print(msg_type)
  30.         if msg_type == 'text':
  31.             ToUserName = xmlData.find('ToUserName').text
  32.             FromUserName = xmlData.find('FromUserName').text
  33.             Content = ''
  34.             erniebot.api_type = 'aistudio'
  35.             #获取令牌 https://aistudio.baidu.com/index/accessToken
  36.             erniebot.access_token = 'access_token'  
  37.             try:
  38.                 response = erniebot.ChatCompletion.create(model='ernie-bot-turbo',messages=[ {'role': 'user','content': xmlData.find('Content').text}])
  39.                 Content= response.get_result()
  40.             except e:
  41.                 print(e)
  42.             reply = '''
  43.             <xml>
  44.             <ToUserName><![CDATA[%s]]></ToUserName>
  45.             <FromUserName><![CDATA[%s]]></FromUserName>
  46.             <CreateTime>%s</CreateTime>
  47.             <MsgType><![CDATA[text]]></MsgType>
  48.             <Content><![CDATA[%s]]></Content>
  49.             </xml>
  50.             '''
  51.             response = make_response(reply % (FromUserName, ToUserName, str(int(time.time())), Content))
  52.             response.content_type = 'application/xml'
  53.             return response
  54.         elif msg_type == 'event':
  55.             event_type = xmlData.find('Event').text
  56.             if event_type== "subscribe":
  57.                 ToUserName = xmlData.find('ToUserName').text
  58.                 FromUserName = xmlData.find('FromUserName').text
  59.                 reply = '''
  60.                 <xml>
  61.                 <ToUserName><![CDATA[%s]]></ToUserName>
  62.                 <FromUserName><![CDATA[%s]]></FromUserName>
  63.                 <CreateTime>%s</CreateTime>
  64.                 <MsgType><![CDATA[text]]></MsgType>
  65.                 <Content><![CDATA[%s]]></Content>
  66.                 </xml>
  67.                 '''
  68.                 response = make_response(reply % (FromUserName, ToUserName, str(int(time.time())), "欢迎来到XXX微信公众号!"))
  69.                 response.content_type = 'application/xml'
  70.                 return response
  71.         else:
  72.             ToUserName = xmlData.find('ToUserName').text
  73.             FromUserName = xmlData.find('FromUserName').text
  74.             reply = '''
  75.             <xml>
  76.             <ToUserName><![CDATA[%s]]></ToUserName>
  77.             <FromUserName><![CDATA[%s]]></FromUserName>
  78.             <CreateTime>%s</CreateTime>
  79.             <MsgType><![CDATA[text]]></MsgType>
  80.             <Content><![CDATA[%s]]></Content>
  81.             </xml>
  82.             '''
  83.             response = make_response(reply % (FromUserName, ToUserName, str(int(time.time())), "我看不太懂!"))
  84.             response.content_type = 'application/xml'
  85.             return response
  86. if __name__=="__main__":
  87.     #app.run()
  88.     server = pywsgi.WSGIServer(('0.0.0.0',80),app)
  89.     server.serve_forever()
复制代码
这段代码是一个使用Python和Flask框架编写的微信公众号后台服务。它的主要目的是处置惩罚来自微名誉户的消息,然后使用ErnieBot模型生成聊天回复。以下是代码的详细描述:
导入模块:

代码开始时导入了须要的模块和库,包罗Flask、ErnieBot(假定是一个聊天呆板人API)、Gevent、用于XML解析的xml.etree.cElementTree,hashlib用于哈希操纵,以及time模块。
Flask应用步伐设置:

代码初始化了一个Flask应用步伐。
路由’/wx’:
这个路由处置惩罚来自微信的GET和POST请求。
对于GET请求,它用于验证微信服务器的真实性,比较接收到的signature(署名)与盘算出的哈希值是否匹配。假如匹配,将返回echostr值以完成验证。假如不匹配,将返回错误消息。
对于POST请求,它处置惩罚来自微信的XML数据。它提取消息类型(MsgType)并检查是否为文本消息或变乱。
处置惩罚文本消息:

假如是文本消息,它提取发送者和接收者的用户名以及文本内容。
然后,它为响应设置ErnieBot API,并将用户的消息传递给它。
末了,它构建一个XML响应,包含聊天呆板人的回复,然后将响应发送回用户。
处置惩罚变乱消息:
假如是订阅变乱,它会回复欢迎消息。

对于其他变乱类型或未处置惩罚的情况,它会回复一个通用的"我无法理解"消息。
主要实行部门:
代码通过Gevent服务器运行Flask应用步伐,监听在0.0.0.0地址的80端口上。

需要留意的几点:

代码似乎缺少文本消息处置惩罚部门的错误处置惩罚。
需要将’access_token’替换为实际的访问令牌,这是与ErnieBot API交互所需的。
请根据微信公众号的设置将token替换为与微信服务器配置的token一致,以确保验证的安全性。
python环境 ≥ 3.8
  1. pip install erniebot flask gevent
复制代码
看起来你需要在Python 3.8及以上环境中安装一些库,这些库包罗: erniebot flask gevent 对于erniebot和flask这两个库,它们是Python Web开发常用的库,主要用于构建Web应用。你可以使用pip来安装它们。pip是Python的包管理器,可以用于安装Python包。 在Python环境 ≥ 3.8的情况下,你可以使用以下命令来安装这些库:
pip install erniebot flask gevent
假如你在安装过程中遇到任何题目,或者需要更详细的资助,欢迎随时向我扣问。


免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。




欢迎光临 IT评测·应用市场-qidao123.com (https://dis.qidao123.com/) Powered by Discuz! X3.4