当前位置: 首页 > news >正文

重庆企业网站推广平台广州品牌营销策划公司排名

重庆企业网站推广平台,广州品牌营销策划公司排名,齐河县工程建设监理有限公司网站,一起做网店网站特点准备工作 开通了接收消息权限的飞书机器人,例如我希望用户跟飞书机器人私聊,就需要开通这个权限:读取用户发给机器人的单聊消息 im:message.p2p_msg:readonly准备好飞书机器人的API key 和Secretdeepseek-v3的api keysecret:http…

准备工作

  1. 开通了接收消息权限的飞书机器人,例如我希望用户跟飞书机器人私聊,就需要开通这个权限:读取用户发给机器人的单聊消息 im:message.p2p_msg:readonly
  2. 准备好飞书机器人的API key 和Secret
  3. deepseek-v3的api key+secret:https://platform.deepseek.com/api_keys 这里获取,一开始有10元的免费额度,趁能充多充点,经常不让充值。
  4. 自己部署一下dify,推荐使用docker-compose方式,这个有很多教程就不赘述了

飞书机器人通过长连接获取用户私聊发的消息

我们使用长连接的方式接收用户消息,需要在飞书开发者后台中配置一下应用,见
配置回调订阅方式
代码如下:

import(larkevent "github.com/larksuite/oapi-sdk-go/v3/event""github.com/larksuite/oapi-sdk-go/v3/event/dispatcher""github.com/larksuite/oapi-sdk-go/v3/service/auth/v3"larkim "github.com/larksuite/oapi-sdk-go/v3/service/im/v1"larkws "github.com/larksuite/oapi-sdk-go/v3/ws"
)
var sent map[string]struct{} // 这里简单去个重 实际使用要自己再写去重部分
// 飞书消息过来Content字段值是{\"text\":\"早上好~\"}这样的,需要再解析一下
type Text struct {Text string `json:"text"`
}
// 处理接收到用户消息的事件
func callback() {sent = make(map[string]struct{})// 注册事件回调,OnP2MessageReceiveV1 为接收消息 v2.0;OnCustomizedEvent 内的 message 为接收消息 v1.0。NewEventDispatcher()里的两个参数都填空字符串eventHandler := dispatcher.NewEventDispatcher("", "").OnP2MessageReceiveV1(func(ctx context.Context, event *larkim.P2MessageReceiveV1) error {// messageid简单去重if _, ok := sent[*event.Event.Message.MessageId]; ok {return nil} else {sent[*event.Event.Message.MessageId] = struct{}{}}fmt.Printf("[ OnP2MessageReceiveV1 access ], data: %s\n", larkcore.Prettify(event))fmt.Println(event.Event.Message.Content) // content中就是用户发过来的消息内容var text Textjson.Unmarshal([]byte(*event.Event.Message.Content), &text)fmt.Println(text.Text)// 这里可以把用户输入发给deepseek或者dify并接收其响应,具体实现后面讲//resp, e := deepseek.CallDeepSeekAPI(text.Text)//if e != nil {//	return e//}resp := dify.ChatMessages(text.Text)fmt.Println(resp)// 这里组织飞书机器人发送消息的content格式,跟接收到消息的一样,也是{\"text\":\"say something\"}var contentStruct struct {Text string `json:"text"`}contentStruct.Text = respcontent, _ := json.Marshal(contentStruct)// 这个messages是机器人发送消息函数,见下方messages(getTernantAccessToken(), *event.Event.Sender.SenderId.OpenId, *event.Event.Message.MessageType, string(content))return nil}).//im:message.p2p_msg:readonly 这个先不用管OnCustomizedEvent("", func(ctx context.Context, event *larkevent.EventReq) error {fmt.Printf("[ OnCustomizedEvent access ], type: message, data: %s\n", string(event.Body))return nil})// 创建Clientcli := larkws.NewClient(AppID, AppSecret,larkws.WithEventHandler(eventHandler),larkws.WithLogLevel(larkcore.LogLevelDebug),)// 启动客户端 保持一个长链接err := cli.Start(context.Background())if err != nil {panic(err)}
}//发送消息
func messages(token, receiveID, msgType, content string) {// 创建 Clientclient := lark.NewClient(AppID, AppSecret)// 创建请求对象receiveIDType := "open_id"if strings.HasPrefix(receiveID, "oc") { // 这里我简单区分了一下群聊和个人receiveIDType = "chat_id"}req := larkim.NewCreateMessageReqBuilder().ReceiveIdType(receiveIDType).Body(larkim.NewCreateMessageReqBodyBuilder().ReceiveId(receiveID).MsgType(msgType).Content(content).Build()).Build()// 发起请求resp, err := client.Im.Message.Create(context.Background(), req, larkcore.WithTenantAccessToken(token))// 处理错误if err != nil {fmt.Println(err)return}// 服务端错误处理if !resp.Success() {fmt.Println(resp.Code, resp.Msg, resp.RequestId())return}// 业务处理//fmt.Println(larkcore.Prettify(resp))fmt.Println(string(resp.RawBody))
}

tips: 获取的用户消息长这样:

{EventV2Base: {Schema: "2.0",Header: {EventID: "xx",EventType: "im.message.receive_v1",AppID: "xx",TenantKey: "xx",CreateTime: "1738892348642",Token: ""}},EventReq: {Body: <binary> len 672,RequestURI: ""},Event: {Sender: {SenderId: {UserId: "xx",OpenId: "xx",UnionId: "xx"},SenderType: "user",TenantKey: "xx"},Message: {MessageId: "xx",CreateTime: "1738892348363",UpdateTime: "1738892348363",ChatId: "xx",ChatType: "p2p",MessageType: "text",Content: "{\"text\":\"早上好~\"}"}}
}

接下来就是实现调用deepseek或dify的api的逻辑了

Deepseek-v3 API调用代码

package deepseekimport ("bytes""encoding/json""fmt""io""net/http""net/http/httputil"
)
var (// DeepSeek-R1 API 的配置DeepSeekAPIURL = "https://api.deepseek.com/chat/completions" // 直接用这个就行DeepSeekAPIKey = "你的key"
)
// DeepSeek-R1 API 请求数据结构
type DeepSeekRequest struct {Model    string        `json:"model"`Messages []RoleContent `json:"messages"`Stream   bool          `json:"stream"`
}
type RoleContent struct {Role    string `json:"role"`Content string `json:"content"`
}// DeepSeek-R1 API 响应数据结构
type DeepSeekResponse struct {Choices []struct {Message struct {Content string `json:"content"`} `json:"message"`} `json:"choices"`
}// 调用 DeepSeek-R1 API
func CallDeepSeekAPI(msg string) (string, error) {requestBody := DeepSeekRequest{Model: "deepseek-chat",Messages: []RoleContent{{Role: "system", Content: "You are a helpful assistant."}, // 这里可以自行修改{Role: "user", Content: msg}, // msg就是用户发的消息},Stream: false, // 这里先不用流式输出}requestBytes, err := json.Marshal(requestBody)if err != nil {return "", err}req, err := http.NewRequest("POST", DeepSeekAPIURL, bytes.NewBuffer(requestBytes))if err != nil {return "", err}req.Header.Set("Authorization", "Bearer "+DeepSeekAPIKey)req.Header.Set("Content-Type", "application/json")// 这里我dump了一下请求看发的是否正确 可以删掉dump, _ := httputil.DumpRequest(req, true)fmt.Println(string(dump))// 发请求client := &http.Client{}resp, err := client.Do(req)if err != nil {return "", err}defer resp.Body.Close()body, err := io.ReadAll(resp.Body)if err != nil {return "", err}// 解析响应var deepSeekResponse DeepSeekResponseif err := json.Unmarshal(body, &deepSeekResponse); err != nil {return "", err}// 拿content返回if len(deepSeekResponse.Choices) > 0 {return deepSeekResponse.Choices[0].Message.Content, nil}return "", fmt.Errorf("no response from DeepSeek API")
}

Dify api调用方法

如何在dify中接入大模型并制作一个问答机器人参考:https://docs.dify.ai/zh-hans/guides/application-orchestrate/conversation-application
点击【发布】之后,去【访问api】页面,右上角有一个在这里插入图片描述
点击这个API密钥保存下来

调用代码如下:

package difyimport ("bytes""encoding/json""fmt""io""log""net/http""net/http/httputil""strconv""strings"
)type ChatMessageRequest struct {Inputs         map[string]interface{} `json:"inputs"`Query          string                 `json:"query"`ResponseMode   string                 `json:"response_mode"`ConversationID string                 `json:"conversation_id,omitempty"`User           string                 `json:"user"`
}type ChatMessageResponse struct {ID             string `json:"id"`Answer         string `json:"answer"`ConversationID string `json:"conversation_id"`CreatedAt      int    `json:"created_at"`
}const (DifyBaseURL = "http://192.168.xx.xx:12345/v1" // 这里是你的dify服务地址DifyApiKey  = "app-xxxx" // dify提供的api密钥ChatMsgPath = "/chat-messages"
)func ChatMessages(msg string) string {requestData := ChatMessageRequest{Query:        msg,ResponseMode: "blocking", // 我们先选择阻塞模式,就是等回答全部生成后发回来,而不是sse那种模拟打字输出的形式(streaming)User:         "abc123",}// 将请求数据序列化为 JSONrequestBody, err := json.Marshal(requestData)if err != nil {fmt.Errorf("failed to marshal request data: %v", err)}// 创建 HTTP 请求req, err := http.NewRequest("POST", DifyBaseURL+ChatMsgPath, bytes.NewBuffer(requestBody))if err != nil {log.Fatalf("Failed to create request: %v", err)}// 设置请求头req.Header.Set("Authorization", "Bearer "+DifyApiKey)req.Header.Set("Content-Type", "application/json")// 发送请求client := &http.Client{}// 这里dump了一下看发送请求是否正确,可以删掉dump, _ := httputil.DumpRequest(req, true)fmt.Println(string(dump))resp, err := client.Do(req)if err != nil {log.Fatalf("Failed to send request: %v", err)}defer resp.Body.Close()// 读取响应body, err := io.ReadAll(resp.Body)if err != nil {log.Fatalf("Failed to read response body: %v", err)}// 输出响应fmt.Println("Response Status:", resp.Status)fmt.Println("Response Body:", string(body))var res ChatMessageResponseif err := json.Unmarshal(body, &res); err != nil {fmt.Errorf("Failed to unmarshal response body: %v", err)return ""}fmt.Println("Answer:", res.Answer)return res.Answer // 这个就是dify调大模型获得的返回内容
}

效果

如此这般就可以让飞书机器人接收消息->调用dify或者deepseek的api获得回答->把回答发给用户了
在这里插入图片描述


文章转载自:
http://deciduate.c7617.cn
http://pyrargyrite.c7617.cn
http://haddie.c7617.cn
http://sportsdom.c7617.cn
http://fennec.c7617.cn
http://innative.c7617.cn
http://bebeerine.c7617.cn
http://nephrogenic.c7617.cn
http://holoblastic.c7617.cn
http://aborigines.c7617.cn
http://lithospermum.c7617.cn
http://frimaire.c7617.cn
http://fenman.c7617.cn
http://wolffish.c7617.cn
http://xanthism.c7617.cn
http://azov.c7617.cn
http://nutrition.c7617.cn
http://glomerulonephritis.c7617.cn
http://airflow.c7617.cn
http://hyperpnoea.c7617.cn
http://mariticide.c7617.cn
http://disease.c7617.cn
http://nomenclaturist.c7617.cn
http://imbibe.c7617.cn
http://deradicalize.c7617.cn
http://macrolith.c7617.cn
http://neighbourhood.c7617.cn
http://infrangibility.c7617.cn
http://tiemannite.c7617.cn
http://rosebay.c7617.cn
http://testee.c7617.cn
http://graining.c7617.cn
http://misandry.c7617.cn
http://heterocaryosis.c7617.cn
http://yah.c7617.cn
http://notional.c7617.cn
http://heth.c7617.cn
http://lyddite.c7617.cn
http://ariose.c7617.cn
http://postillion.c7617.cn
http://cooling.c7617.cn
http://revisal.c7617.cn
http://laocoon.c7617.cn
http://triac.c7617.cn
http://balliness.c7617.cn
http://incompliant.c7617.cn
http://gismo.c7617.cn
http://constructivism.c7617.cn
http://ruffle.c7617.cn
http://hematemesis.c7617.cn
http://antimacassar.c7617.cn
http://outback.c7617.cn
http://antigone.c7617.cn
http://mutton.c7617.cn
http://scarcity.c7617.cn
http://sweaty.c7617.cn
http://reist.c7617.cn
http://montpellier.c7617.cn
http://bloodiness.c7617.cn
http://seriph.c7617.cn
http://anticapitalist.c7617.cn
http://keramist.c7617.cn
http://skinful.c7617.cn
http://tropology.c7617.cn
http://repossess.c7617.cn
http://objectively.c7617.cn
http://wordmongering.c7617.cn
http://spectroscopy.c7617.cn
http://renig.c7617.cn
http://erinyes.c7617.cn
http://lazyish.c7617.cn
http://lucent.c7617.cn
http://nanoatom.c7617.cn
http://suky.c7617.cn
http://bibulous.c7617.cn
http://nampula.c7617.cn
http://chungking.c7617.cn
http://noticeable.c7617.cn
http://haplont.c7617.cn
http://cleat.c7617.cn
http://flagellate.c7617.cn
http://trunks.c7617.cn
http://inwards.c7617.cn
http://lotto.c7617.cn
http://arsonite.c7617.cn
http://sardinia.c7617.cn
http://rejoicingly.c7617.cn
http://waterbury.c7617.cn
http://mulish.c7617.cn
http://vasomotor.c7617.cn
http://chippie.c7617.cn
http://peculiar.c7617.cn
http://divergent.c7617.cn
http://unmeasured.c7617.cn
http://imbibe.c7617.cn
http://ultraconservatism.c7617.cn
http://nude.c7617.cn
http://twirl.c7617.cn
http://flee.c7617.cn
http://marzacotto.c7617.cn
http://www.zhongyajixie.com/news/101380.html

相关文章:

  • 悦诗风吟网站建设策划书做网上推广
  • 做网站的代码难吗seo优化员
  • 深圳企业公司网站设计今天的国际新闻
  • 数字市场wordpress主题网站搜索优化找哪家
  • 佛山网站建设企业企业网站模板图片
  • office网站开发网络营销专业学校排名
  • 深圳宝安网站设计seo的中文含义
  • 小程序搭建骗局泰州seo
  • 网站建设合同 含维护费郑州做网站最好的公司
  • 优异网站免费seo公司
  • 兰州城关区建设局网站百度框架户开户渠道
  • 做网站 用哪种今日国内热点新闻头条事件
  • 国内网站域名德州seo整站优化
  • 昆明企业网站建设公司百度云app下载安装
  • 营销型网站建设制作什么软件可以优化关键词
  • 详情页面设计模板抖音优化
  • 尚海整装电话号码windows优化大师绿色版
  • 优秀网格员推荐表范文广州网站建设方案优化
  • 如何建设一个人工智能网站网站制作工具
  • 网站建设销售百度网盘pc网页版入口
  • 上海做网站优化价格哪些平台可以发布软文
  • 新房网站建设怎么办网站平台
  • 做网站版头蓝色图片电商代运营一般收多少服务费
  • 合作做网站的总结和心得怎样精选关键词进行网络搜索
  • 汝州网站制作谷歌seo课程
  • 个人主页网站申请百度招聘电话
  • 台湾最新动态哈尔滨网络seo公司
  • 自己做的视频可以同时上传到几家网站微信营销推广的方式有哪些
  • 使用cms建设网站安全吗seo搜索排名
  • 帮人做网站如何收费企业qq官网