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

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

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

  • 荣耀magic3怎么拦截骚扰电话(荣耀magic3怎么拦截地区号码)

    荣耀magic3怎么拦截骚扰电话(荣耀magic3怎么拦截地区号码)

  • 抖音直播间可以设置密码吗(抖音直播间可以说微信吗)

    抖音直播间可以设置密码吗(抖音直播间可以说微信吗)

  • 微信手机绑定怎么解除(微信手机绑定怎么解除绑定)

    微信手机绑定怎么解除(微信手机绑定怎么解除绑定)

  • 华为荣耀20i是不是全面屏(华为荣耀20i不能自动旋转)

    华为荣耀20i是不是全面屏(华为荣耀20i不能自动旋转)

  • 快手没有播放量是怎么回事(快手没有播放量不上热门的原因)

    快手没有播放量是怎么回事(快手没有播放量不上热门的原因)

  • iphone11型号区别(iphone11各种型号区别)

    iphone11型号区别(iphone11各种型号区别)

  • 京东买空调免费安装吗(京东买空调免费打孔吗)

    京东买空调免费安装吗(京东买空调免费打孔吗)

  • 安卓手机如何打开.dwl2文件(安卓手机如何打开.vtt文件)

    安卓手机如何打开.dwl2文件(安卓手机如何打开.vtt文件)

  • 苹果手机密码输错多少次就会永久停用(苹果手机密码输错一次就锁屏一小时怎么解除)

    苹果手机密码输错多少次就会永久停用(苹果手机密码输错一次就锁屏一小时怎么解除)

  • qq手机通讯录能聊天吗(qq里面的手机通讯录)

    qq手机通讯录能聊天吗(qq里面的手机通讯录)

  • 抖音提示有正在编辑的视频(抖音提示正在直播)

    抖音提示有正在编辑的视频(抖音提示正在直播)

  • qq聊天记录可以保存多久(qq聊天记录可以备份吗)

    qq聊天记录可以保存多久(qq聊天记录可以备份吗)

  • 苹果手机看视频抖动是什么原因(苹果手机看视频总是卡顿怎么办)

    苹果手机看视频抖动是什么原因(苹果手机看视频总是卡顿怎么办)

  • 手机反向充电对手机有什么影响(手机反向充电对手机有何坏处)

    手机反向充电对手机有什么影响(手机反向充电对手机有何坏处)

  • 手机wps散点图怎么显示公式(手机wps散点图怎么自定义横纵坐标?)

    手机wps散点图怎么显示公式(手机wps散点图怎么自定义横纵坐标?)

  • 荣耀忘记了手机锁屏密码怎么办(荣耀忘记了手机密码怎么解开锁?)

    荣耀忘记了手机锁屏密码怎么办(荣耀忘记了手机密码怎么解开锁?)

  • 网络不可上网怎么回事(网络不可上网怎么修复)

    网络不可上网怎么回事(网络不可上网怎么修复)

  • 手机耗电快了怎么办(手机耗电快了怎么解决)

    手机耗电快了怎么办(手机耗电快了怎么解决)

  • vivov1831a是什么型号(vivoa1813a是什么手机)

    vivov1831a是什么型号(vivoa1813a是什么手机)

  • wifi热点被拉黑了怎么解除(wifi热点被拉黑名单)

    wifi热点被拉黑了怎么解除(wifi热点被拉黑名单)

  • 手机淘宝怎么删除差评(手机淘宝怎么删除自己评价图片)

    手机淘宝怎么删除差评(手机淘宝怎么删除自己评价图片)

  • 小米9pro怎么升级miui11(小米9pro怎么升级moui14)

    小米9pro怎么升级miui11(小米9pro怎么升级moui14)

  • 无u盘怎么进入pe系统(没有u盘怎么进入pe系统win10)

    无u盘怎么进入pe系统(没有u盘怎么进入pe系统win10)

  • 怎么特别关注淘宝店铺(淘特怎么关注别人)

    怎么特别关注淘宝店铺(淘特怎么关注别人)

  • qq音乐财富等级在哪里(qq音乐财富等级充值表)

    qq音乐财富等级在哪里(qq音乐财富等级充值表)

  • iphone静音键自动跳(iphone静音键自动跳怎么设置)

    iphone静音键自动跳(iphone静音键自动跳怎么设置)

  • linux块设备读写流程详解(linux块设备驱动详解)

    linux块设备读写流程详解(linux块设备驱动详解)

  • 动产租赁税率是多少2023
  • 结转应交增值税是什么意思
  • 个人劳务报酬所得税率表
  • 项目差旅费能计入项目费用吗
  • 用友t3凭证日期怎么自动排序
  • 员工回家探亲的文案
  • 加计抵扣进项税进营业外收入
  • 厂里搬厂赔偿员工标准
  • 附加税退税申请书怎么写
  • 怎么核算金融企业收入
  • 将产品转为本企业使用
  • 发出库存商品没发货
  • 增值税专用发票电子版
  • 劳务费发票是几个点的税率
  • 显示已申报税额
  • 一个公司可以有几个公章
  • 2016年的发票2020年可以认证吗
  • 所得税需要结转嘛
  • 发票联给错怎么办?
  • 企业将自产产品发放给职工作为福利
  • 住房公积金管理官网
  • 建筑企业所得税怎么算举例说明
  • 申请银行汇票手续费记账凭证
  • 固定资产改造更新是否需要计提折旧
  • 私户给公户转账多久到账
  • 收取违约金如何入账
  • 利得和损失计入哪里
  • 如何配置环境变量windows
  • php数组实现
  • php字符串操作函数
  • 代扣代缴手续费比例
  • 工会举办比赛,参赛人员差旅费可以在工会报销吗
  • 分批供货付款方式
  • fontpackages-filesystem
  • 长期债权投资收回的利息 现金流量表
  • 出口退税进项发票稽核
  • php虚拟主机
  • 以银行存款交纳欠缴税金
  • 税务法是否允许私人经营
  • 公司转让注册海外公司
  • 收到员工交来现金怎么入账
  • 去年的滞纳金没有入账怎么处理
  • 个人独资所得
  • 企业应交税金科目编码
  • 未确认融资费用账务处理
  • 低值易耗品摊销计入什么科目
  • 管理费用核算的是
  • 先给发票后付款做账
  • 对公账户 退款
  • 核销贷款收回账务怎么做
  • 季节性停工固定资产折旧计入什么科目
  • 净利润增长率的影响因素
  • 个税公司少申报一个月会对个人有什么影响
  • 出口退税登记的内容
  • 银行汇票哪个科目
  • 审计年审内容
  • 简易征收是什么意思和一般纳税人
  • 业务提成怎么做账内账
  • sql语句学习
  • Linux下安装MySQL5.7.19问题小结
  • Mac OS10.11下mysql5.7.12 安装配置方法图文教程
  • windows10预览
  • window10系统邮件设置在哪里
  • ubuntu系统应用
  • smon进程
  • win10系统如何设置不休眠
  • win10怎么看电池寿命
  • WIN10系统打开IE浏览器断网
  • linux tcptraceroute
  • 微信小程序支付的钱怎么退款
  • javascript数组操作方法
  • PHP+jquery+ajax实现分页
  • vue组件精讲
  • js实现页面跳转跳到主页
  • jquery(document).ready
  • jquery trigger实现联动的方法
  • ruby元编程第二版
  • 出租车票如何验真
  • 房产税季度缴纳还是月度
  • 国家税务局网上浙江电子税务局官网
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设