vue配合axios连接express搭建的node服务器接口_简单案例

简介: 文章介绍了如何使用Express框架搭建一个简单的Node服务器,并使用Vue结合Axios进行前端开发和接口调用,同时讨论了开发过程中遇到的跨域问题及其解决方案。

首先,我们先搭建node服务器

我们需要使用express这个node搭建服务的框架,当然也可以使用其他的
下载全局express和express-generator这两个模块依赖包

npm i -g  express  express-generator

在文件夹在我们创建自己的express文件夹,并打开cmd
执行命令

express --view=ejs mynodeExpress

mynodeExpress 是我们的node项目文件名
在这里插入图片描述
按照提示进入mynodeExpress文件夹下载依赖包 npm i
文件目录为
在这里插入图片描述
bin下面的www是我们的执行node服务入口文件
node|_modules是依赖包 比如fs板块 cookice-parser body-parser模块包
public是存放静态文件的 还可以存放我们前端打包好的文件 利用宝塔面板 pm2 直接就可以运行项目
routes是路由文件夹
views存放页面
app.js 入口文件
package.json 依赖目录
在这里插入图片描述
运行项目 npm start 会执行bin文件夹下的www文件 里面是服务的配置
在这里插入图片描述
我们可以看到创建了一个http服务,他的端口号默认是3000,如果process.env.PORT有值的话就是它的值,端口号就是它了。
运行服务,我们打开

localhost:3000

在这里插入图片描述
是一个初始页面,我们可以看一下app.js文件,因为这个文件里面我们找到我们的路由来自哪里
在这里插入图片描述
显而易见是routes下面的index文件,我们再查看一下它
在这里插入图片描述

在这里它引入了路由模块,添加了一个get方式的路由 ‘/’,我们刚刚匹配的页面就是来自这个路由

localhost:3000/

下面我们在自己写一个试试:

router.get('/zjq', (req, res) => {
   
  console.log(req.query, 'req')
  res.send({
   
    nameList: [
      {
    name: 'zjq', age: "23" },
      {
    name: 'zrb', age: "22" },
      {
    name: 'zry', age: "18" },
      {
    name: 'fyy', age: "24" }]
  });
})

让它返回一个数组,我们在页面看一下有没有返回:
在这里插入图片描述
nice,成功了,我们的node服务器搭建成功,喝一袋可口的酸酸乳奖励自己一下,开心。
还有一个我们再看app.js中我们发现了这样几行代码:

var indexRouter = require('./routes/index');
var usersRouter = require('./routes/users');
app.use('/', indexRouter);
app.use('/users', usersRouter);

显而易见,3000端口号后面第一个为 ‘/'的自动匹配 ‘./routes/index’ 这个文件,
如果我们写’/users‘呢,我们测试一下
在./routes/users文件中我们再写两个路由

var express = require('express');
var router = express.Router();
/* GET users listing. */
router.get('/', function (req, res, next) {
   
  res.send('respond with a resource');
});
//新加的get请求
router.get('/zjq', (req, res) => {
   
  let {
    zjq, zrh } = req.query
  if (zjq == 'zjq' || zrh == 'zrh') {
   
    res.send({
    status: true })
  } else {
   
    res.send({
    status: false })
  }
})
//新加的post请求
router.post('/postDome', (req, res) => {
   
  let {
    id } = req.body
  console.log(id, 'id')
  let arr = [{
    id: 1, name: "zjqAndId=1" }, {
    id: 2, name: "zjqAndId=2" }, {
    id: 3, name: "zjqAndId=3" },]
  if (id) {
   
    let brr = arr.filter((item) => {
   
      return item.id == id
    })
    res.send({
   
      res: brr
    })
  } else {
   
    res.send({
    res: false })
  }
})
module.exports = router;

当然我们在浏览器url上只能测试get请求
在这里插入图片描述
我们没有传递参数,给我们返回了 { status: false }这个对象

在get请求中我们在node端接收参数使用req.query接受,在post中使用req.body接受 ,可以使用ES6的解构赋值来接受,书写也是很方便,太nice了。

下一步我们简单搭建一个vue项目,测试post请求。
当然肯定是可以的,不一定非要用搭建vue这种方式测试 我们可以用vscode xxx.http后缀为http的文件测试也是很方便的。我的目的是为了给大家展示一个坑。
npm create 我的项目名称

npm create my_project

流程很简单 我们选择自动安装路由的(选不选都可以,我这里习惯性的选上了),我这里忘了截图。

再下载一个我们vue全家桶中的axios

在这里插入图片描述

运行运行命令我们可以在package.json中的scripts自己配置

npm run serve


运行在了8080端口,这个时候会产生跨域的问题,因为同源策略的限制,我们必须在同协议域名端口号下才不算跨域。我们的解决方法是proxy代理
新建vue.config.js文件

module.exports = {
   
    lintOnSave: false,//取消严格模式
    devServer: {
   
        // 设置主机地址
        host: 'localhost',
        // 设置默认端口
        port: 8080,
        // 设置代理
        proxy: {
   
            '/api': {
   
                // 目标 API 地址
                target: 'http://127.0.0.1:3000/',
                // 如果要代理 websockets
                ws: false,
                // 将主机标头的原点更改为目标URL
                changeOrigin: true,
                pathRewrite: {
   
                    // 路径重写
                    "/api": "" // 这个意思就是以api开头的,定向到哪里, 如果你的后边还有路径的话, 会自动拼接上
                }
            }
        }
    }
}

我们就在这个路由下,首先看我们的src下的router文件
在这里插入图片描述

匹配的是我们src下views/Home.vue文件
我们让它在挂载的时候请求,挂载的时候页面已经渲染完成。el、ref、data我们都可以获取到了
在这里插入图片描述
看到了打印
在这里插入图片描述
成功的将我们对应的node接口信息返回~

我说一个我遇到的坑,我在代理的时候我使用了

target:process.env.VUE_APP_URL

我在.env.development中配置的是:这是一个很低级的错误

NODE_ENV = development  
VUE_APP_URL='http://127.0.0.1:3000/'
NODE_ENV = development  
VUE_APP_URL=127.0.0.1:3000/

这里面的url不能加引号否则会按字符串处理,也不能不写协议
下面的才是对的

NODE_ENV = development  
VUE_APP_URL=http://127.0.0.1:3000/

好了,今天就分享到这了,加油。

目录
相关文章
|
3天前
|
存储 数据挖掘 数据库
服务器数据恢复—OceanStor存储数据恢复案例
华为OceanStor T系列某型号存储中有一组由24块机械硬盘组建的一组RAID5阵列。 运行过程中该存储设备RAID5阵列上多块硬盘出现故障离线,阵列失效,存储中数据无法访问。
|
1天前
|
存储 数据挖掘
服务器数据恢复—zfs文件系统服务器数据恢复案例
一台配有32块硬盘的服务器在运行过程中突然崩溃不可用。经过初步检测,基本上确定服务器硬件不存在物理故障。管理员重启服务器后问题依旧。需要恢复该服务器中的数据。
|
9天前
|
运维 数据挖掘 索引
服务器数据恢复—Lustre分布式文件系统服务器数据恢复案例
5台节点服务器,每台节点服务器上有一组RAID5阵列。每组RAID5阵列上有6块硬盘(其中1块硬盘设置为热备盘,其他5块硬盘为数据盘)。上层系统环境为Lustre分布式文件系统。 机房天花板漏水导致这5台节点服务器进水,每台服务器都有至少2块硬盘出现故障。每台服务器中的RAID5阵列短时间内同时掉线2块或以上数量的硬盘,导致RAID崩溃,服务器中数据无法正常读取。
|
14天前
|
存储 数据挖掘
服务器数据恢复—V7000存储上多块Mdisk成员盘出现故障的数据恢复案例
服务器存储数据恢复环境: 一台V7000存储上共12块SAS机械硬盘(其中1块是热备盘),组建了2组Mdisk,创建了一个pool。挂载在小型机上作为逻辑盘使用,小型机上安装的AIX+Sybase。 服务器存储故障: V7000存储中磁盘出现故障,管理员发现问题后立即更换磁盘。新更换的硬盘在上线同步数据的时候,存储上另一块磁盘也出现问题,导致逻辑盘无法挂接在小型机上,业务暂时中断。V7000存储的管理界面上显示两块硬盘故障脱机。 pool无法加载,其中三个通用卷均无法挂载。
|
23天前
|
安全 数据挖掘
服务器数据恢复—RAID5阵列中两块硬盘离线导致阵列崩溃的数据恢复案例
服务器数据恢复环境: 两组分别由4块SAS接口硬盘组建的raid5阵列,两组raid5阵列划分LUN并由LVM管理,格式化为EXT3文件系统。 服务器故障: RAID5阵列中一块硬盘未知原因离线,热备盘自动激活上线替换离线硬盘。在热备盘上线过程中,raid5阵列中又有一块硬盘离线。热备盘同步失败,该raid阵列崩溃,LVM结构变得不完整,文件系统无法正常使用。
|
28天前
|
存储 监控 调度
云服务器成本优化深度解析与实战案例
本文深入探讨了云服务器成本优化的策略与实践,涵盖基本原则、具体策略及案例分析。基本原则包括以实际需求为导向、动态调整资源、成本控制为核心。具体策略涉及选择合适计费模式、优化资源配置、存储与网络配置、实施资源监控与审计、应用性能优化、利用优惠政策及考虑多云策略。文章还通过电商、制造企业和初创团队的实际案例,展示了云服务器成本优化的有效性,最后展望了未来的发展趋势,包括智能化优化、多云管理和绿色节能。
|
1月前
|
存储 运维 数据挖掘
服务器数据恢复—EVA存储中多块硬盘离线导致存储崩溃的数据恢复案例
一台HP EVA存储中有23块硬盘,挂接到一台windows server操作系统的服务器。 EVA存储上有三个硬盘指示灯亮黄灯,此刻存储还能正常使用。管理员在更换硬盘的过程中,又出现一块硬盘对应的指示灯亮黄灯,存储崩溃,无法使用了。
|
1月前
|
数据挖掘 Linux Windows
服务器数据恢复—服务器raid0数据恢复及数据迁移的案例
某品牌服务器上有一组由两块SAS硬盘组建的raid0阵列,上层是windows server操作系统+ntfs文件系统。服务器上一个硬盘指示灯显示黄颜色,该指示灯对应的硬盘离线,raid不可用。
|
15天前
|
存储 数据挖掘
服务器数据恢复—ZFS文件系统下数据恢复案例
服务器存储数据恢复环境: ZFS Storage 7320存储阵列中有32块硬盘。32块硬盘分为4组,每组8块硬盘,共组建了3组RAIDZ,每组raid都配置了热备盘。 服务器存储故障: 服务器存储运行过程中突然崩溃,排除人为误操作、断电、进水和其他机房不稳定因素。管理员重启服务器存储,系统无法进入,需要恢复服务器存储中的数据。
|
30天前
|
存储 Oracle 关系型数据库
服务器数据恢复—华为S5300存储Oracle数据库恢复案例
服务器存储数据恢复环境: 华为S5300存储中有12块FC硬盘,其中11块硬盘作为数据盘组建了一组RAID5阵列,剩下的1块硬盘作为热备盘使用。基于RAID的LUN分配给linux操作系统使用,存放的数据主要是Oracle数据库。 服务器存储故障: RAID5阵列中1块硬盘出现故障离线,热备盘自动激活开始同步数据,在同步数据的过程中又一块硬盘离线,RAID5阵列瘫痪,上层LUN无法使用。