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

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

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

  • 微信的nfc功能有什么用(微信的nfc功能有什么作用)

    微信的nfc功能有什么用(微信的nfc功能有什么作用)

  • 怎么用qq邮箱发文件(怎么用qq邮箱发邮件给别人)

    怎么用qq邮箱发文件(怎么用qq邮箱发邮件给别人)

  • p40是曲屏手机吗(p40是曲屏的么)

    p40是曲屏手机吗(p40是曲屏的么)

  • 苹果8p别人打电话无法接通(苹果8p别人打电话过来没有声音怎么设置)

    苹果8p别人打电话无法接通(苹果8p别人打电话过来没有声音怎么设置)

  • 小猿搜题可以同时几个人登录吗(小猿搜题可以两个人用一个账号吗?)

    小猿搜题可以同时几个人登录吗(小猿搜题可以两个人用一个账号吗?)

  • 苹果耳机充电盒后面那个按钮是什么(苹果耳机充电盒电量)

    苹果耳机充电盒后面那个按钮是什么(苹果耳机充电盒电量)

  • 剪映素材丢失怎么办(剪映素材丢失怎么重新添加)

    剪映素材丢失怎么办(剪映素材丢失怎么重新添加)

  • 爱奇艺会员怎么不能下载(爱奇艺会员怎么让第二个人登录)

    爱奇艺会员怎么不能下载(爱奇艺会员怎么让第二个人登录)

  • 华为手机自带浏览器在哪里(华为手机自带浏览器打开有广告)

    华为手机自带浏览器在哪里(华为手机自带浏览器打开有广告)

  • 中国电信hd收费吗(中国电信hd收费多少)

    中国电信hd收费吗(中国电信hd收费多少)

  • 华为5x能不能插电信卡(华为5x有nfc功能吗)

    华为5x能不能插电信卡(华为5x有nfc功能吗)

  • realmex2是什么牌子(realme x2真实口碑)

    realmex2是什么牌子(realme x2真实口碑)

  • 微电影片尾字幕怎么做(微电影片尾字幕有哪些人员)

    微电影片尾字幕怎么做(微电影片尾字幕有哪些人员)

  • 淘宝二维码怎么生成(淘宝二维码怎么保存)

    淘宝二维码怎么生成(淘宝二维码怎么保存)

  • 苹果11会发热吗(苹果11容不容易发热)

    苹果11会发热吗(苹果11容不容易发热)

  • 小米cc9支持内存扩展吗(小米cc9内存扩展在什么地方)

    小米cc9支持内存扩展吗(小米cc9内存扩展在什么地方)

  • 抖音点赞有数量限制吗(抖音点赞有数量,但点开显示无点赞怎么回事)

    抖音点赞有数量限制吗(抖音点赞有数量,但点开显示无点赞怎么回事)

  • 苹果商店为什么中国不能用(苹果商店为什么是英文)

    苹果商店为什么中国不能用(苹果商店为什么是英文)

  • 抖音申诉要多久(抖音申诉要多久通过)

    抖音申诉要多久(抖音申诉要多久通过)

  • 拼多多AA收款能退款吗(拼多多收款码使用规则)

    拼多多AA收款能退款吗(拼多多收款码使用规则)

  • 小米手机相册在哪个文件夹(小米手机相册在线播放未完成)

    小米手机相册在哪个文件夹(小米手机相册在线播放未完成)

  • x27微信有没有美颜(vivox27手机微信怎么开美颜效果)

    x27微信有没有美颜(vivox27手机微信怎么开美颜效果)

  • 小度在家的二维码在哪里(小度在家的二维码怎么调出来)

    小度在家的二维码在哪里(小度在家的二维码怎么调出来)

  • 广告费业务宣传费扣除标准
  • 税控盘开票系统怎么升级
  • 所得税是什么意思
  • 物流企业怎么做大做强?
  • 小规模纳税人税费会计分录
  • 不确认销售收入结转销售成本
  • 出售固定资产简易计税账务处理
  • 出口赠送客户怎么处理
  • 来料加工生产成本账务处理
  • 甲公司自2018年3月1日开始自行研发一款新兴产品
  • 外资企业对应的企业是什么
  • 农产品收购发票可以跨区域开吗
  • 个人到税务局开增值税专用发票
  • 基础设施特许权包括
  • 以固定资产换入固定资产
  • 供应商质量问题告知函
  • 销售回扣分录
  • 事业单位购入存货分录
  • 去年销售怎么算
  • 股息红利个人所得税扣税失败
  • 哪些情况下工资不低于最低工资标准的80
  • 未摊销金额怎么算
  • 一般纳税人进货收到普票怎么做账
  • 4s店 监管
  • 电脑bios设置最佳性能和默认
  • 电脑管家免费wifi
  • 已经提完折旧的设备改造
  • 红蘑菇是什么松树伞吗
  • 文本模式是什么意思?
  • PHP:session_destroy()的用法_Session函数
  • 家庭承包发包方的权利和义务
  • 蓝桥杯等级
  • 鼓励证券投资基金的政策
  • 科托儿古城
  • 研发支出属于哪个表
  • 交易性金融资产属于流动资产
  • 深度学习之concatenate和elementwise操作(二)
  • php对接第三方支付
  • 小规模纳税人年收入超过500万必须转为一般纳税人吗
  • 公司注销退还股票流程
  • 货物运输业增值税
  • 简述sql server
  • 如何利用sql进行数据传输
  • sql语句修改某个字段
  • 利润表利息费用怎么填
  • 物业公司的会计好干吗
  • 企业会计本年利润
  • 房地产开发成本测算套表(全过程)
  • 企业技术服务费有税前列支限额吗
  • 记账凭证的编制依据是审核无误的原始凭证
  • 材料折扣会计分录
  • 汇算清缴怎么申报
  • 哪些情况应收账款不能扣
  • 管理费用处理的是
  • 如何理解会计中的借贷? 知乎
  • 允许税前扣除的税金及附加包括哪些
  • 银行利息增值税发票申请单怎么填
  • 企业取得土地使用权会计处理
  • 什么是资产减值准备计提
  • 个体工商户建行贷款条件
  • sqlserver全文索引ndf文件丢失
  • win10下面任务栏
  • 台式电脑NUM LOCK键还能亮,算不算死机了
  • windows10的改进
  • macbook怎么关闭设置上的1
  • dllhost应用程序异常
  • win10系统无法更改
  • windows7system登录
  • win7开机黑屏只有一个鼠标箭头
  • 获取windows的最新信息
  • ssh客户端软件
  • win10电脑开机蓝屏怎么进入安全模式
  • win10非正常关机系统修复
  • 简单阐述javascript的主要作用
  • jquerycuishifeng
  • 批处理常用命令总结
  • javascript entries
  • 如何使用jquery实现点击按钮弹出一个对话框
  • 环保税新政策
  • 公司租房的房产税应计入哪个科目
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设