位置: IT常识 - 正文

Chat GPT实用案例——VUE+Chat GPT实现聊天功能教程

编辑:rootadmin
Chat GPT实用案例——VUE+Chat GPT实现聊天功能教程

推荐整理分享Chat GPT实用案例——VUE+Chat GPT实现聊天功能教程,希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:,内容如对您有帮助,希望把文章链接给更多的朋友!

首先,我们需要确定所需功能和技术栈:

前端框架:Vue.js聊天机器人:Chat GPT APICSS框架:Bootstrap or 自主设计

在开始编写代码之前,请确认 Chat GPT API 服务已经配置好, 并且您已获得了API密钥或者token。

Chat GPT实用案例——VUE+Chat GPT实现聊天功能教程

接下来是 Vue.js项目初始化:

# 安装vue-clinpm install -g vue-cli # 创建一个基于webpack模板新项目(chatbot)vue init webpack chatbot# 进入到目录cd chatbot && npm install# 添加chat-gpt依赖库yarn add @huggingface/chatapi-basic

然后打开package.json文件,在scripts中添加一些scripts命令:

"build": "node build/build.js","lint": "eslint --ext .js,.vue src","start": "node server/index.js", // 开始服务器监听请求

server/index.js 文件为聊天机器人Node代理类(实现跨域+GPT-API调用),具体请参考源码。(下方直接复制源码代码)

编辑聊天界面,在chatbot/src/components目录下新建Chat.vue文件,并编写以下代码:

<template> <div class="container"> <h3>简单CSS样式</h3> <div class="row pt-4"> <div class="col-md"> <!-- 用户输入 --> <label for="">User Input</label> <input type="text" placeholder="" v-model='userInput' @keyup.enter='sendMsg()'class='form-control'> </div> <!-- 工作区域 --> <div class="col-md border-left py-2 px-5 h-100 overflow-y-auto text-center"> <!-- 聊天内容列表--> <ul ref='dialogue' style='list-style-type: none;width:auto;margin-top:auto; margin-bottom:auto;' > <!--<li><strong>会话开始</strong></li>--> </ul> </div> </div> </div></template><script lang=js>export default { name: "BaseChat", data(){ return{ chatData:[], userInput:'', sessionId:'' }},mounted () { this.init() // 初始化sessionId}, methods:{ init : async function (){ const ans = await this.$axios.get('/api/session') this.sessionId =(ans.data).id; }, // 发送消息到后端API(接受GPT回复) sendMsg:async function(){ //添加用户发送信息到对话框列表中 if(this.userInput!=""){ await this.updateDialogue('Me',this.userInput); } //获取ai的回答并将其添加到对话框列表中let response = await this.getResponse(); await this.updateDialogue('AI',response); }, async getResponse(){ let without_space_input = this.userInput.trim(); //调用前端Chat GPT API const ans = await axios.post( '/api/chat/text',{ message :without_space_input,sessionId:this.sessionId} ); return ans.data.message; }, updateDialogue: function(user,message) { const ulTags= this.$refs.dialogue ; var newli = document.createElement("li"); var newText=document.createTextNode(message); if (user=='Me'){ newli.style="text-align:right; color:green"; } else{ newli.style="color:blue"; } ulTags.appendChild(newli).appendChild(newText); }, }}</script><style>.container{ width:100%; height:50vh;}</style>

接下来是 Chat 接口代理代码, 在server/index.js文件添加以下内容:

const express=require('express')const bodyParser=require('body-parser');const app=express();var config={key:"API-KEY",//API key token or Secret-API-keyengine : "davinci"};var sessionID=null;app.use(express.static('../chatbot/dist/'))app.use(bodyParser.json());app.get('/hello',(req,res)=>{ res.send("<h1>Hello World!</h1>");});/** 开始对话创建一个sesssion.**/async function create_session() {const api_url='https://api.openai.com/v1/engine/'+config.engine+'/completions';var headers={ 'Content-Type': 'application/json', auth:`Bearer ${config.key}` }; const prompt = "Hello openai"; // Initial seed const data= { prompt: plug(prompt), max_tokens: 300,temperature:0.8,n :1 ,presence_penalty :0,delay :false }let res = await fetch(api_url,{method:'POST',headers,body: JSON.stringify(data)}) .then(response => response.json()) if(!('id' in res)){ console.error("Error calling GPT API",res); throw new Error("Create Session Token request failed"); } console.log("------------->>>",res.choices[0].text.replace(/[\r\n]+/gm, "")); sessionID=res.id; return { success:true,id:(sessionID)};}app.get('/api/session',(req,res)=>{ (async ()=>{const ans ={success:false};try{ ans.success=true; ans["id"]=await create_session();// 返回目前在线最新对话的Api-Key和Session-Token. }catch(e){ console.log(e);}res.status(200).json(ans);})()});/** Chat基础API,使用GPT模型实现聊天机器人功能。**/const chat_message="Chat basic API functionality!";function plug(text){//判断是否是列表let mcs=text.charAt(text.length-1)===';'if(mcs==true){ c='\n'} else{c=''}return text+c+chat_message;}app.post('/api/chat/text',(req,res)=>{(async ()=>{try{ const message=req.body.message;//请求消息体的文本消息内容const api_url='https://api.openai.com/v1/engine/'+config.engine+'/completions';var headers={ 'Content-Type': 'application/json', auth:`Bearer ${config.key}`};console.log(req.body) const prompt=[message] +" "; // Initial seedconst data= { prompt: plug(prompt), max_tokens: 300, temperature:0.8,n :1 ,presence_penalty :0,delay :false } let res = await fetch(api_url,{method:'POST',headers,body: JSON.stringify(data)}) .then(response => response.json()) if(!('choices' in res)){console.error("Error calling GPT API",res); throw new Error("Create Session Token request failed"); } res.status(200).json({ message:(res.choices[0].text)}); }catch(e){ console.log(e); }})()});app.listen(9002,()=>{console.log('listening port....9002')})

最后,运行命令node server/index.js启动服务器。 在浏览器中打开http://localhost:{port}/即可使用简单的Vue.ChatBot聊天界面。

祝您编码愉快!如果有任何问题,请随时联系我。

本文链接地址:https://www.jiuchutong.com/zhishi/287200.html 转载请保留说明!

上一篇:尖椒炒肉的做法(图文)(湘菜尖椒炒肉的做法)

下一篇:【详讲】微信小程序分包流程步骤(微信怎么开小)

  • 不想被嫉妒的唾沫喷到,那就站的再高些(我不想嫉妒别人可为什么总是嫉妒别人)

    不想被嫉妒的唾沫喷到,那就站的再高些(我不想嫉妒别人可为什么总是嫉妒别人)

  • word文档怎么复制整页内容(word文档怎么复制粘贴)

    word文档怎么复制整页内容(word文档怎么复制粘贴)

  • 朋友圈图片怎么配自己喜欢的音乐(朋友圈图片怎么转发)

    朋友圈图片怎么配自己喜欢的音乐(朋友圈图片怎么转发)

  • 苹果6s plus怎么分屏(苹果6s plus怎么开机)

    苹果6s plus怎么分屏(苹果6s plus怎么开机)

  • 淘宝分享店怎么找不到(淘宝分享店怎么开)

    淘宝分享店怎么找不到(淘宝分享店怎么开)

  • 大小写切换是哪个键(大小写切换是哪个键 word)

    大小写切换是哪个键(大小写切换是哪个键 word)

  • qq龙王标识如何关闭(qq龙王表情包)

    qq龙王标识如何关闭(qq龙王表情包)

  • 华为p40nfc怎么用(华为p40nfc在哪里打开)

    华为p40nfc怎么用(华为p40nfc在哪里打开)

  • 指令计数器的作用(指令计数器和指令寄存器的区别)

    指令计数器的作用(指令计数器和指令寄存器的区别)

  • 一加六手机长度几厘米(一加六手机长度是多少)

    一加六手机长度几厘米(一加六手机长度是多少)

  • iphonexsmax支持什么运营商(iphonexsmax支持什么wifi)

    iphonexsmax支持什么运营商(iphonexsmax支持什么wifi)

  • p30屏幕录制在哪里(华为p30屏幕录制在设置里面那个地方)

    p30屏幕录制在哪里(华为p30屏幕录制在设置里面那个地方)

  • 数据库阶段的特点是什么(数据库有哪几个阶段)

    数据库阶段的特点是什么(数据库有哪几个阶段)

  • 平板耗电特别快怎么办(平板耗电特别快是漏电)

    平板耗电特别快怎么办(平板耗电特别快是漏电)

  • 苹果11有锁和无锁的区别(苹果11有锁无卡贴有什么影响)

    苹果11有锁和无锁的区别(苹果11有锁无卡贴有什么影响)

  • 手机怎么拍夕阳(手机怎么拍夕阳参数)

    手机怎么拍夕阳(手机怎么拍夕阳参数)

  • 苹果11港版和国行区别(苹果11港版和国行哪个质量好)

    苹果11港版和国行区别(苹果11港版和国行哪个质量好)

  • 微信文件为什么会损坏(微信文件为什么会过期或清理)

    微信文件为什么会损坏(微信文件为什么会过期或清理)

  • 怎么把ppt调成兼容模式(ppt怎么设置为兼容)

    怎么把ppt调成兼容模式(ppt怎么设置为兼容)

  • 9900k核显性能(9900k的核显)

    9900k核显性能(9900k的核显)

  • ios开qq语音游戏没声音(为什么开着qq语音游戏里边的语音不能用)

    ios开qq语音游戏没声音(为什么开着qq语音游戏里边的语音不能用)

  • 苹果xr后面是玻璃的吗(iphone xr后面是玻璃的吗)

    苹果xr后面是玻璃的吗(iphone xr后面是玻璃的吗)

  • p30是曲面屏吗(华为p30是曲面屏手机吗)

    p30是曲面屏吗(华为p30是曲面屏手机吗)

  • vivoy7s处理器是什么(vivoy7s处理器是啥)

    vivoy7s处理器是什么(vivoy7s处理器是啥)

  • 红米k20后盖是什么材质(红米k20后盖拆卸)

    红米k20后盖是什么材质(红米k20后盖拆卸)

  • iphone怎么导出b站缓存(iPhone怎么导出备忘录为图片)

    iphone怎么导出b站缓存(iPhone怎么导出备忘录为图片)

  • ipad如何取消底部横条(ipad如何取消底部横条ios12)

    ipad如何取消底部横条(ipad如何取消底部横条ios12)

  • 一般纳税人财务要求
  • 清税证明是什么要钱吗
  • 增值税价外费用开票内容
  • 工伤在门诊的收据能报销吗
  • 预提工资计入哪个科目
  • 银行贷款减值准备转回处理
  • 工程项目的存货含哪些科目
  • 非利息净收入包括营业外收入吗
  • 企业返利如何处理
  • 道路施工企业的财务核算包括
  • 小规模纳税人月收入超过10万,要交多少税
  • 预缴企业所得税是含税数还是不含税
  • 递延收益的所得税影响
  • 公园门票可以开发票吗
  • 委托研发受托方怎么做账
  • 物资包括材料吗
  • 资产处置收益的含义
  • 销售电梯并安装如何缴纳增值税
  • excel合并的单元格怎么填充序列
  • 手动滑屏怎么操作
  • 母子公司吸收合并优劣势
  • 身份证信息提取python
  • 应收账款转让分录
  • 网络不通怎么办苹果手机
  • 车辆交通罚款怎样避免重复报销
  • 会计分录编制的步骤
  • win7旗舰版系统激活工具
  • 长期应付款的摊余成本怎么计算
  • 马耳他共和国瓦莱塔福利
  • PHP:imagecreatetruecolor()的用法_GD库图像处理函数
  • 应收款余额在借方什么意思
  • 详解 HttpServletResponse
  • 博客界面模板
  • 单元测试的测试工具
  • 分公司在外地,企业怎么交税
  • 会计怎么计算
  • 企业所得税报表怎么更正
  • 其他应付款用什么冲掉
  • 土地出让金的范围是什么
  • phpcms文档
  • mysql性能提升
  • 股东转股怎么办理
  • 房地产开发企业成本核算方法
  • 一般纳税人也会被税吗
  • 营业成本指的什么
  • 珠宝行业会计核算流程
  • 公司销售一批物品怎么做
  • 融资租赁业务如何开展
  • 单位保险柜里都放些什么
  • 企业年底亏损怎么结转
  • 商场联营扣点的合作方式
  • 备用金被盗刷了怎么办
  • 小规模纳税人销售自己使用过固定资产
  • 老板在自己的公司做事
  • 收购分公司有什么要求
  • 小规模企业与一般纳税人企业最新划分标准及税率
  • 固定资产领用原因
  • 企业对疫情
  • 应收账款坏账的说明
  • 附条件的行政行为有哪些
  • 注册会计师转所规定
  • sql数据采集
  • mysql如何修改默认值
  • Windows Server 2016技术第三预览版10537英文版ISO镜像下载泄露
  • xp系统自带浏览器打不开网页
  • VirtualBox虚拟机中文免费
  • u盘安装winpe
  • win8系统版本
  • hyper-v以后安装操作系统
  • Win7 64位旗舰版设置字体显示比例让字体变大
  • windows8 应用商店
  • adobe骨骼动画
  • 下列有关javascript中call和apply
  • 同步数据和异步数据的区别
  • 粒子form
  • ssh登录后自动执行命令
  • 党建引领结对共建生态
  • 成都高新区办理社保在哪里?
  • 税务登记证书怎么办
  • 国税地税征管体制改革方案
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设