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

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

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

  • 怎么做微信营销来获取客户的信任,微信营销实战方法(如何做微信营销)

    怎么做微信营销来获取客户的信任,微信营销实战方法(如何做微信营销)

  • excel中行高怎么设置(excel中行高怎么设置成厘米)

    excel中行高怎么设置(excel中行高怎么设置成厘米)

  • 微信初始提示音叫什么(微信提示音需要怎么恢复回原来呢)

    微信初始提示音叫什么(微信提示音需要怎么恢复回原来呢)

  • 微软商店无法获取应用(微软商店获取没反应)

    微软商店无法获取应用(微软商店获取没反应)

  • 抖音剩余粉丝未授权无法查看(抖音剩余粉丝未授权怎么移除)

    抖音剩余粉丝未授权无法查看(抖音剩余粉丝未授权怎么移除)

  • 手机短信设置在哪里(短信在哪里设置)

    手机短信设置在哪里(短信在哪里设置)

  • plus表示什么(plus是什意思)

    plus表示什么(plus是什意思)

  • 手机号已暂停服务什么意思(手机号已暂停服务怎么办)

    手机号已暂停服务什么意思(手机号已暂停服务怎么办)

  • 集成运算放大器中间级的主要特点是(集成运算放大器的特点)

    集成运算放大器中间级的主要特点是(集成运算放大器的特点)

  • 一体机能换cpu和显卡吗(一体机可以换cpu)

    一体机能换cpu和显卡吗(一体机可以换cpu)

  • 正常笔记本是多大尺寸(正常笔记本是多大的纸)

    正常笔记本是多大尺寸(正常笔记本是多大的纸)

  • 将文件另存为怎么弄(文件另存为的步骤有哪些)

    将文件另存为怎么弄(文件另存为的步骤有哪些)

  • 畅连通话需要钱吗(畅连通话要钱吗)

    畅连通话需要钱吗(畅连通话要钱吗)

  • vivox21黑屏怎么办(vivox21黑屏怎么强制重启)

    vivox21黑屏怎么办(vivox21黑屏怎么强制重启)

  • ipv6常见地址是什么(ipv6地址包括)

    ipv6常见地址是什么(ipv6地址包括)

  • 手机蓝牙连接音响怎么放歌(手机蓝牙连接音响老是断开)

    手机蓝牙连接音响怎么放歌(手机蓝牙连接音响老是断开)

  • p20徕卡三摄是什么意思(徕卡三摄赛神仙)

    p20徕卡三摄是什么意思(徕卡三摄赛神仙)

  • 计算机中io设备是什么(计算机中io设备的作用)

    计算机中io设备是什么(计算机中io设备的作用)

  • 如何设置指定数据点显示数据标签(如何设置指定数量提醒公式)

    如何设置指定数据点显示数据标签(如何设置指定数量提醒公式)

  • 手机电池显示怎么变成彩色(手机电池显示怎么是黄色的)

    手机电池显示怎么变成彩色(手机电池显示怎么是黄色的)

  • 怎样不退群屏蔽群信息(有没有办法不退群,永远屏蔽不显示消息)

    怎样不退群屏蔽群信息(有没有办法不退群,永远屏蔽不显示消息)

  • qq四叶草会掉吗(qq四叶草断了能恢复吗)

    qq四叶草会掉吗(qq四叶草断了能恢复吗)

  • wps如何全屏显示(wps调成全屏显示怎么调回来)

    wps如何全屏显示(wps调成全屏显示怎么调回来)

  • 手机送话器为什么会坏(手机送话器为什么没声音)

    手机送话器为什么会坏(手机送话器为什么没声音)

  • 爱奇艺为什么无法下载1080P(爱奇艺为什么无法播放)

    爱奇艺为什么无法下载1080P(爱奇艺为什么无法播放)

  • 城建附加的计税依据
  • 新公司个税申报怎么操作
  • 山东省注册税务师协会官网
  • 调研费用怎么写
  • 本年利润需要毎月转入未分配利润吗
  • 购买私募基金有风险吗
  • 工程项目估算收入要缴税吗
  • 权益法下股权投资
  • 不动产抵扣进项税
  • 企业计提福利费时,贷记应付职工薪酬
  • 计提社保个人部分需要计提吗
  • 代收水电费做错了该如何调账?
  • 铲车费属于劳务费吗
  • 蜜枣税收分类编码
  • 资管产品增值税征收管理规定
  • 企业注册资金需要拿钱出来吗
  • 无偿获得固定资产的会计处理
  • 需要缴纳消费税的委托加工存货,由受托方
  • 白银及其制品出自哪里
  • 未知文件格式怎么打开
  • 高新企业研发费用占销售收入的比例
  • 非营利组织一般纳税人会计准则
  • mac如何改变照片图库
  • 多收不用退的货物怎么办
  • 差额征税的项目有哪些
  • PHP:realpath_cache_size()的用法_Filesystem函数
  • 支付给员工的工伤赔偿款账务
  • 新建vue项目
  • 临时存款账户怎么开户
  • ajax调用php接口
  • redis php实例
  • 以前年度损益科目代码
  • 想学web前端
  • yolov3实例
  • 微信支付扫码支付顺序
  • 红包生成算法
  • web逻辑漏洞
  • 未开票金额怎么填写
  • 小企业会计准则和一般企业会计准则的区别
  • 小规模纳税人公转私技巧
  • 建筑业营改增前后区别
  • 保险业务手续费
  • 装修增值税税率是多少2022
  • 综合评价怎么改
  • 购买财务软件报税流程
  • 开办费用的财务是如何处理的
  • 增值税发票怎么领取
  • 什么是住房补贴,住房补贴如何办理?
  • 股东分红要不要纳税?
  • 一般纳税人劳务税率是多少?
  • 出口不报关账务处理
  • 以前年度的银行流水可以补进来做账嘛
  • 企业年金个税怎么计算
  • 公司赞助学校
  • 未确认融资费用计算公式
  • 长期待摊费用是当月摊销还是次月摊销
  • 基金会对外捐赠,对方开什么发票
  • 公司向个人借款是否合法
  • 建账有几种方法
  • sqlserver 获取表字段
  • 收缩后对数据库有影响吗
  • mysql内网访问
  • 苹果电脑dock栏是什么意思
  • 通用pe工具箱安装win7
  • linux系统开机黑屏啥也没有
  • win8无法使用内置管理员账户打开ie
  • java grid
  • opengl中点画线算法
  • js中的filter方法和map方法
  • android:ellipsize="marquee"
  • Node.js中的核心模块包括哪些内容?
  • unity音乐thefatrat
  • 在linux的主要组成部分中最基础的是哪一项?
  • 传智播客在线课程
  • python编程完全入门教程
  • 车船税属于地方固定收入吗
  • 监察室主任岗位职责
  • 汽车契税和购置税一样吗
  • 河南税务局发票查询系统
  • 锦江区税务局发行窗口在哪
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设