位置: 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 转载请保留说明!

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

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

  • 如何才能做出成功的社会化广告(如何才能做出成品油)

    如何才能做出成功的社会化广告(如何才能做出成品油)

  • 华为nova5怎么设置屏幕常亮(华为nova5怎么设置门禁卡功能)

    华为nova5怎么设置屏幕常亮(华为nova5怎么设置门禁卡功能)

  • 微信屏幕黑色怎么回事(微信屏幕黑色怎么设置)

    微信屏幕黑色怎么回事(微信屏幕黑色怎么设置)

  • 摄像头能识别戴口罩人脸吗(摄像头能识别戴头盔人脸吗)

    摄像头能识别戴口罩人脸吗(摄像头能识别戴头盔人脸吗)

  • kindle用贴膜吗(kindle建议贴膜吗)

    kindle用贴膜吗(kindle建议贴膜吗)

  • qq免费头像挂件有哪些(qq免费头像挂件有哪些永久)

    qq免费头像挂件有哪些(qq免费头像挂件有哪些永久)

  • 苹果手机看抖音发烫(苹果手机看抖音模糊是什么原因)

    苹果手机看抖音发烫(苹果手机看抖音模糊是什么原因)

  • 正在准备windows请不要关机需要多久(正在准备windows请勿关闭计算机 卡住)

    正在准备windows请不要关机需要多久(正在准备windows请勿关闭计算机 卡住)

  • 咸鱼为什么别人付不了款(咸鱼为什么别人发的东西不会违规)

    咸鱼为什么别人付不了款(咸鱼为什么别人发的东西不会违规)

  • 小米手机微信视频没声音是怎么回事(小米手机微信视频美颜功能在哪里设置)

    小米手机微信视频没声音是怎么回事(小米手机微信视频美颜功能在哪里设置)

  • oppo无障碍是什么意思(oppo无障碍模式是什么意思)

    oppo无障碍是什么意思(oppo无障碍模式是什么意思)

  • 微信漫游数据是什么意思(微信漫游聊天)

    微信漫游数据是什么意思(微信漫游聊天)

  • ipad港版和国行的区别(ipad港版和国行的设置区别)

    ipad港版和国行的区别(ipad港版和国行的设置区别)

  • 苹果x带nfc功能吗(苹果xnfc功能在哪里打开)

    苹果x带nfc功能吗(苹果xnfc功能在哪里打开)

  • 主板flash模式是什么(主板进去flash模式)

    主板flash模式是什么(主板进去flash模式)

  • id设计是什么意思(id设计方案)

    id设计是什么意思(id设计方案)

  • word新建图片样式在那(word新建图片样式,应用于文档正文中的10张图片)

    word新建图片样式在那(word新建图片样式,应用于文档正文中的10张图片)

  • 手机银行锁定怎么办(手机银行锁死了)

    手机银行锁定怎么办(手机银行锁死了)

  • 2019微信退群有提示吗(2020微信退群别人能看到吗)

    2019微信退群有提示吗(2020微信退群别人能看到吗)

  • gtx1060配i5还是i7

    gtx1060配i5还是i7

  • 抖音如何查观看记录(抖音如何查观看直播历史)

    抖音如何查观看记录(抖音如何查观看直播历史)

  • 拨打电话已关机怎么回事(怎么设置拨打电话已关机)

    拨打电话已关机怎么回事(怎么设置拨打电话已关机)

  • Windows 10如何开启游戏图形高性能(windows10如何开启vt)

    Windows 10如何开启游戏图形高性能(windows10如何开启vt)

  • 帝国CMS自定义列表SQL调用方法(帝国cms栏目自定义字段)

    帝国CMS自定义列表SQL调用方法(帝国cms栏目自定义字段)

  • 税率变化递延所得税资产怎么计算
  • 环境保护税是什么科目
  • 公司垫付生育津贴凭证
  • 白酒消费税最低计税价格
  • 月收入不足10万免增值税的账务处理
  • 劳务费达到多少钱需要招标
  • 叉车维修费计什么费用
  • 行政单位的财务报告包括财务报表和财务情况说明书
  • 长期股权投资审计说明
  • 应付职工薪酬包括哪些内容
  • 存货不同入账基数怎么算
  • 个体工商户增值税怎么计算
  • 职工福利费计提比例一般是多少
  • 股利怎么算出来的
  • 个体户办营业执照需要什么证件和材料
  • 小规模纳税人开票额度
  • 合同签订的案例
  • 什么是税收编码,在哪里查
  • 债务重组过程
  • 出租房产如何交土地使用税
  • 委外开发费用可以加计扣除吗
  • 水电费发票可以开吗
  • 怎么计算房地产成本单价
  • 修缮房屋的防水工程的账务处理?
  • 经营费用包括哪些内容
  • 息税前利润和税后经营净利润
  • 预付账款为负数能转为应付账款吗
  • 在win7系统中将打开窗口拖到屏幕顶端
  • linux root没有权限
  • win7网络连接在哪里打开
  • 预防cpu被烧毁的办法
  • 委托出口的会计分录
  • 酒店装修的整个流程图
  • 进货开了发票也写了购销合同要交印花税吗
  • php扫二维码
  • 资本化的研发费用计入什么科目
  • 扩散分类
  • 盘点那些神级翻唱现场
  • 帝国cms wordpress
  • 工程发票可以开清单吗?
  • 开办费计入哪个会计科目
  • 织梦怎么采集文章
  • 主营业务税金及附加包括增值税吗
  • 土地使用发票
  • 自来水公司水表安装标准
  • SQL2005 自动备份的脚本
  • 什么叫做固定资本
  • 凭证必须用凭证盒
  • 残保金计算公式及例题
  • 公司 股东 变更
  • 进口关税,增值税是进口设备重置成本中的从属费用
  • 净资产收益率与什么指标有关
  • 销售边角废料属于什么
  • 公司给员工结婚红包
  • 生产成本与工程施工
  • 短期借款如何记账
  • 个人账号可以向对公账户转账吗
  • 房地产企业资产负债率行业平均值
  • MySQL数据库索引设计
  • sql连接两个表接查询sql语句
  • mysql数据库迁移方案
  • win8系统安装教程图解
  • win8.1技巧
  • windows7无法启动怎么修复
  • surface准备就绪
  • ssh远程登录设置
  • unity粒子制作ui特效
  • nodejs调试指南
  • Linux 下mysql通过存储过程实现批量生成记录
  • Android通过HttpURLConnection获取JSON并进行UI更新
  • viewstock
  • unity 子对象
  • 基于javascript的毕业设计选题
  • python编程内容
  • js获取div下指定元素的值
  • js点击代码
  • android判断应用是否在前台
  • 国家税务总局现任局长
  • 北京朝阳区国税局
  • 小规模纳税人开专票需要交税吗
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设