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

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

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

  • 2017年最新互联网十大免费推广方式,现在知道不算晚!(17互联网)

    2017年最新互联网十大免费推广方式,现在知道不算晚!(17互联网)

  • 苹果手机怎么自定义微信步数(苹果手机怎么自动锁屏)

    苹果手机怎么自定义微信步数(苹果手机怎么自动锁屏)

  • 微信可以更改实名认证吗(微信可以更改实名认证后好友还在吗)

    微信可以更改实名认证吗(微信可以更改实名认证后好友还在吗)

  • xsmax发热怎么回事(苹果手机xsmax发热)

    xsmax发热怎么回事(苹果手机xsmax发热)

  • 淘宝商家电话在哪找(淘宝的商家电话)

    淘宝商家电话在哪找(淘宝的商家电话)

  • 纳米技术用在什么地方(纳米技术用在什么上面)

    纳米技术用在什么地方(纳米技术用在什么上面)

  • 苹果官换机在哪里购买(苹果官换机在哪买)

    苹果官换机在哪里购买(苹果官换机在哪买)

  • 剪映的镜像在哪(剪映中的镜像在哪里)

    剪映的镜像在哪(剪映中的镜像在哪里)

  • 小米10怎么升级MIUI12(小米10怎么升级13系统)

    小米10怎么升级MIUI12(小米10怎么升级13系统)

  • 抖音极速版怎么提现到微信(抖音极速版怎么填写别人的邀请码)

    抖音极速版怎么提现到微信(抖音极速版怎么填写别人的邀请码)

  • 视频可以设置成win10桌面吗(视频可以设置成电脑壁纸吗)

    视频可以设置成win10桌面吗(视频可以设置成电脑壁纸吗)

  • iphonese2有nfc功能吗(苹果se2有nfc)

    iphonese2有nfc功能吗(苹果se2有nfc)

  • 企业微信会监控个人微信吗(企业微信会监控微信聊天内容吗)

    企业微信会监控个人微信吗(企业微信会监控微信聊天内容吗)

  • 华为荣耀手机辅助功能在哪里(华为荣耀手机辅助按键在哪里设置)

    华为荣耀手机辅助功能在哪里(华为荣耀手机辅助按键在哪里设置)

  • 华为蓝牙耳机声音突然变小声了(华为蓝牙耳机声音小怎么调大声)

    华为蓝牙耳机声音突然变小声了(华为蓝牙耳机声音小怎么调大声)

  • 联想电脑没声音怎么弄(联想电脑没声音怎么回事)

    联想电脑没声音怎么弄(联想电脑没声音怎么回事)

  • 来电语音提示是什么(手机电话语音来电提示)

    来电语音提示是什么(手机电话语音来电提示)

  • 抖音上私信可以撤销吗(抖音上私信可以说微信号码)

    抖音上私信可以撤销吗(抖音上私信可以说微信号码)

  • a1778是无锁的吗(a1779有锁是什么版本)

    a1778是无锁的吗(a1779有锁是什么版本)

  • 手机京东怎么取消订单(手机京东怎么取消无货订购订单)

    手机京东怎么取消订单(手机京东怎么取消无货订购订单)

  • 苹果8plus充电慢原因(苹果8plus充电太慢)

    苹果8plus充电慢原因(苹果8plus充电太慢)

  • 48v锂电池亏电怎么激活(48v锂电池坏了怎么修)

    48v锂电池亏电怎么激活(48v锂电池坏了怎么修)

  • pdf编辑器怎么修改文字(pdf编辑器怎么修改图片)

    pdf编辑器怎么修改文字(pdf编辑器怎么修改图片)

  • oled屏能用5年吗

    oled屏能用5年吗

  • 电脑微信登录不上怎么办(电脑微信登录不用手机确认)

    电脑微信登录不上怎么办(电脑微信登录不用手机确认)

  • 蚂蚁能量有什么用(蚂蚁能量什么时候偷最多)

    蚂蚁能量有什么用(蚂蚁能量什么时候偷最多)

  • 小影小程序在哪(小影app收费吗)

    小影小程序在哪(小影app收费吗)

  • 关于服务连接器(Servlet)你了解多少?(服务器连接方式包括直接相连,间接连接)

    关于服务连接器(Servlet)你了解多少?(服务器连接方式包括直接相连,间接连接)

  • 未确认融资费用和长期应付款
  • 增值税附加税的会计处理
  • 甲方应项目具备开工条件
  • 电子发票有使用期限吗
  • 专用发票压线了可以拒收吗
  • 公司承担社保能放到生产成本里吗
  • 个人公积金计入什么会计科目
  • 发放遗属补助还要拍照片吗山东
  • 税费滞纳金计入增值税吗
  • 存放中央银行款项名词解释
  • 小规模变一般纳税人需要哪些资料
  • 出纳如何做好保密工作
  • 冲减本年利润
  • 公司注销时发现很多年前多发了员工的工资
  • 季度交的企业所得税怎么做账
  • 利润为负会计分录
  • 企业所得税税前扣除异常
  • 实收资本印花税最新规定
  • 非盈利组织纳税筹划
  • 加计抵减10%会计分录用营业外收入还是其他业务收入
  • 国际收款产生的手续费账务处理
  • 零申报个税怎么补申报可以不罚款吗
  • 小规模企业增值税账务处理
  • 单位探望病人如何报销费用?
  • 以前年度损益调整属于哪类科目
  • 小企业的场地租金怎么算
  • 民非组织可以接受捐赠吗
  • 研发废料收入
  • 建筑企业收到预收账款要交增值税吗
  • 华为手机隐藏应用
  • 桌面图标间距特别大
  • 特许经营企业广告语
  • 工程投标保证金一般是多少
  • nginx静态文件服务器
  • 运输发票税金怎么算
  • codeigniter 教程
  • 职工福利费会计科目怎么写
  • 清洁费用是属于什么科目
  • php数组拼接成字符串
  • 猿创设计科技有限公司
  • 如何利用数据有效性制作单元格菜单
  • 怎么样写合同书
  • 资产负债表中应交税费为负数是什么意思
  • 营改增之后增值税怎么算
  • python中如何删除文件
  • 个人所得税有哪些项目
  • sql server数据库中的null(空值)
  • 购货方收到红字发票计入进项税转出还是进项税额负数?
  • 股东借款的利息收入
  • 独资合伙公司
  • 小规模纳税人购买原材料会计分录
  • 公司购买的家电怎么入账
  • 分期收款提供劳务 是什么
  • 交存超库存现金
  • 付款凭证怎么写样本
  • 汇算期间取得以下收入
  • 本年利润到年末还有余额吗
  • 农业技术人员是什么意思
  • 收到个人退回的社保费,怎样做分录
  • 公司开业之前产假怎么算
  • 其他资本公积是利得吗
  • 税收会计记账方法
  • mysql必知必会读后感2000字
  • ubuntu系统怎么用
  • unix含义
  • 富士通FUJITSU笔记本电脑开机进入BIOS的方法(F2)
  • 回收站清空文件怎么恢复?试试这三个方法找回!
  • windows10如何取消密码开机
  • win8安装应用商店
  • Eclipse和AndroidStudio常用快捷键对比
  • ftp上传网站的步骤
  • jquery validation plugin
  • 简述android应用的常用开发模式及其优缺点
  • nginx服务器日志
  • unity获取ui
  • android 标签页
  • 如何安装python环境安装包
  • 国税局国家公务员工资待遇
  • 财政部国家税务总局
  • 企业职工病退后一般能领多少钱
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设