赞
踩
https://platform.openai.com/account/api-keys 在这个地址进行注册,但是需要翻墙,可自己查找国内的试用地址。就不多赘述…
思路:前端通过一个图标入口,点击后 发送请求,创建一个会话(也就是聊天室),并且把创建的这个会话 入库。并且后端返回一个入库生成的uuid,和默认的消息会话返回给前端,前端暂时存放在 input 隐藏域中,以备后续使用。此时完成一个会话的连接和创建。
ps:前端发送请求前,需要做一些校验,$this->verifySend(); 验证是否登录,和发送请求的频率
直接上代码如下:
<?php namespace LdWxappPlugin\Api\Resource\Chatapi; use ApiBundle\Api\ApiRequest; use ApiBundle\Api\Resource\AbstractResource; use ApiBundle\Api\Annotation\ApiConf; use Ramsey\Uuid\Uuid; use Symfony\Component\HttpKernel\Exception\BadRequestHttpException; class Chatapi extends AbstractResource { public function add(ApiRequest $request): array { $uuid = $request->request->get('conversationId'); // 没有 uuid 就要新建会话,入库,有uuid 就直接打开 // 这里在页面上做了一个 显示隐藏效果 不刷新页面的情况下,关闭侧边窗口,元素移除屏幕 // 再次打开,有uuid ,直接让元素 移回原来的尺寸 'right','-1000px' 'right','0px' if(empty($uuid)){ // 这里用它来区分是 右侧侧边栏 还是 独立网页版 $display = $request->request->get('display',0); // 入库的会话名字 从侧边栏进来的是 默认对话,从网页进来的是 新建对话 $conversationName = $request->request->get('conversationName','默认对话'); // 课程 ID 和 课程类型 这里可根据自己的需求传递不同参数,这个课程ID 是为了跟踪 根据哪一个课程,点击聊天窗口的 $sourceId = $request->request->get('sourceId'); $sourceType = $request->request->get('sourceType'); if (empty($sourceId) || empty($sourceType)){ throw new BadRequestHttpException('sourceId或sourceType不能为空'); } $currentUser = $this->getCurrentUser(); // 生成 uuid ,uuid 是后端生成好,返回给前端,前端卸载 隐藏域里面,每次请求,用隐藏域里面的去做判断。 $random = 'lingdai'.microtime(true).rand(1000,9999); $conversationId = Uuid::uuid5(Uuid::NAMESPACE_OID,$random)->toString(); $goods = $this->findGoodsByTargetIdAndType($sourceId,$sourceType); $conversationData = [ 'conversationId' => $conversationId, 'conversationName' => $conversationName, 'userId' => $currentUser->getId(), 'display' => $display, 'goodsId' => $goods['id'], 'createdTime' => time() ]; $insertResult = $this->getChatApiService()->createConversation($conversationData); if ($insertResult){ // role : 返回给前端的默认对话 可根据情况自行设置 return [ 'status'=> 'success', 'message'=> '创建成功', 'code'=> 1, 'data'=> [ 'conversationId'=> $conversationId, 'conversationName'=> $conversationName, 'aiDocId'=>$goods['aiDocId'], 'id'=>$insertResult['id'], 'display'=>$insertResult['display'], 'goodsId'=>$insertResult['goodsId'], 'role' => [ [ 'role' => 'AI', 'content' => "Hi:你好,哈哈哈哈哈".'</br>'.'123123123' ] ], ] ]; } else { return ['status'=> 'fail','message'=> '创建失败','code'=> 0,'data'=> []]; } }else{ return []; } } // 根据 传过来的 课程ID 和 课程type 查询数据库,查到对应的商品ID 数据 public function findGoodsByTargetIdAndType($sourceId,$sourceType) { if ($sourceType == "goods"){ $goods = $this->getGoodsService()->getGoods($sourceId); return $goods; } $product = $this->getProductService()->getProductByTargetIdAndType($sourceId, $sourceType); $goods = $this->getGoodsService()->getGoodsByProductId($product['id']); return $goods; } // 新建对话的 入库完成! //http://www.lingdaipc.win/lddev.php/chat/pcAI/index?chatId=684&uuid=3b9aad06-356e-5534-a8bf-4a98a95a7497&goodsId=3021 // 独立的 PC 网页版 查询方法 根据上面 url中 传递的参数 ,查询对应的 chatId的 的对话 public function search(ApiRequest $request) { // 判断 ID 是否存在,不存在 是独立出来的窗口 存在是跳转过来的 $params = $request->query->all(); $conditions = $this->filterParams($params); $conditions['display'] = 1; $currentUser = $this->getCurrentUser(); $conditions['userIds'] = $currentUser['id']; list($offset, $limit) = $this->getOffsetAndLimit($request); $conversationTotal = $this->getChatApiService()->count($conditions); $searchResult = $this->getChatApiService()
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。