【初学者】Vue使用axios向Node.js发起请求以及跨域问题的解决

news/2024/5/10 23:07:30/文章来源:https://blog.csdn.net/weixin_46019681/article/details/127277933

目录

项目创建

代码

解决跨域问题

几个注意点

运行结果展示


axios官方文档:起步 | Axios 中文文档 | Axios 中文网

项目创建

本文实例用到的两个项目,分别命名为server和vue-axios。

server是node.js项目,创建方式:

# 创建server并打开位于该文件夹下的终端
# 初始化项目
npm init
# 然后输入包名 server,然后无脑回车即可# 安装模块包
npm install express --save# 创建文件 index.js# 开启服务器,注意每次修改index.js都要重新开启才生效!!
node index.js

vue-axios是vue3项目,我使用vite创建,当然你也可以用vue-cli:

# 进入根目录终端 使用vite创建项目 名称为vue-axios
npm create vite@latest vue-axioscd vue-axios
npm install# 使用npm安装axios插件
# 也可以使用yarn等等,详见开头的官方文档
npm install axios# 运行npm run dev

 以上步骤都完成后,接下来以三个例子说明axios请求数据,分别是get、post请求本地服务器,还有向外部服务器(以斗鱼为例)发起请求。

代码

1. vue-axios/src/App.vue

<template><button @click="getReq">发送一个 get 请求</button><button @click="postReq">发送一个 post 请求</button><button @click="douClick">请求斗鱼服务器</button><!-- 以下是从斗鱼服务器请求数据的展示 --><ul><li v-for="item in state.dy" :key="item.room_id"><img :src="item.room_src" alt=""><h4>{{ item.room_name }}</h4></li></ul>
</template>
<script setup>
// 导入
import axios from 'axios';
import { reactive } from "vue";let state = reactive({});// 发送 get 请求
let getReq = () =>{axios.get("http://localhost:3030/getUser?name=张三").then(function (response){// 处理成功的情况console.log(response.data)}).catch(function (error){// 请求失败console.log(error);}).then(function() {// 总是会执行})
}
// 发送 post 请求
let postReq =() =>{let data ={name:"李四"};axios.post('http://localhost:3030/postUser', data).then(function (response) {console.log(response);}).catch(function (error) {console.log(error);});
}
let douClick = ()=>{// http://open.douyucdn.cn/api/RoomApi/liveaxios.get('/api/RoomApi/live').then((res)=>{console.log(res.data.data);state.dy = res.data.data;}).catch((error)=>{console.log(error);}).then(()=>{})
}
</script><style scoped></style>

2. server/index.js

// 服务器入口文件// nodejs里用require来进行导入一个模块的函数
const express = require('express')// 通过 express 创建一个应用对象app
const app = express()// 解决post请求获取请求体的问题
app.use(express.json());
app.use(express.urlencoded({extended: true
}))app.get('/getUser',(req,res)=>{// 在这里是处理接口的方法,可以在数据库中查询内容console.log(req.query);// 解决跨域问题res.set("Access-Control-Allow-Origin","*");// res.send 将数据发送给前端res.send({name: req.query.name,age: 18,sex:true})
})
app.post('/postUser',(req,res)=>{console.log(req.body);// 解决跨域问题res.set("Access-Control-Allow-Origin","*");res.send({name:'李四',age: 11})
})app.listen('3030',()=>{// localhost 本机地址// 127.0.0.1 本机ipconsole.log('服务器开启成功,地址');
})

解决跨域问题


在前端解决:

 修改vue文件根目录里的vue-axios/vite.config.js(如果是用vue-cli创建的就是vue.config.js

其中'/api'是你要访问的服务器api,在此处定义后,你axios里对这个api发起的请求就不会出现跨域问题。

 

import { defineConfig } from 'vite'
import vue from '@vitejs/plugin-vue'// https://vitejs.dev/config/
export default defineConfig({plugins: [vue()],server:{proxy:{'/api':'http://open.douyucdn.cn/'}}
})

如果是vue.config.js是这样写的的

devServer: {
        proxy: {
            '/api': {
                target: 'http://localhost:8081/api',    // 你自己的api接口地址
                changeOrigin: true,
                ws: true,
                pathRewrite: {
                    '^/api': '',  
                }
            }
        }
    }

原文链接:https://blog.csdn.net/qq_26780317/article/details/119647250


在服务器解决:

就是在每个请求方法里都加上这一句:

res.set("Access-Control-Allow-Origin","*");

这些方法发起的请求就不会出现跨域问题。

 

 

几个注意点

(1)vue文件要记得在使用axios的代码之前导入axios。

(2)发送post请求前需要URLSearchParams对数据进行处理,否则就算解决了跨域问题也无法得到响应。

 

报错如下:

Access to XMLHttpRequest at。。。has been blocked by CORS policy: Response to preflight request doesn't pass access control check: No 'Access-Control-Allow-Origin' header is present on the requested resource.

 

 (3)向本地服务器发起请求,前端和服务器项目都要保持运行状态,修改了服务器项目记得要重新运行,而修改了前端文件只需要刷新页面即可,向外部服务器发起请求要保持你电脑联网,否则报500错误。

运行结果展示

 

 

 

 

 

 


over~~~你学到了吗?🐻

今天也是元(shen)气(xin)满(ju)满(pi)的一天 ☁️

😜

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.luyixian.cn/news_show_22259.aspx

如若内容造成侵权/违法违规/事实不符,请联系dt猫网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Codeforces Round #825 (Div. 2)

A. Make A Equal to B Sample input 5 3 1 0 1 0 0 1 4 1 1 0 0 0 1 1 1 2 1 1 1 1 4 1 0 0 1 0 1 1 0 1 0 1 Sample output 1 2 0 1 1 题意&#xff1a; 你有两个长度为n的数组a和b&#xff0c;你可以进行一次操作&#xff0c;将a数组的某个位置的数取反&#xff0c;或者…

LVM与磁盘配额

分区的缺点: 1、一旦建立无法修改 想修改得重新格式化 数据丢失 2、不够灵活 空间只能来自一块硬盘,且必须是连续的空间 3、没有备份冗余功能 需要工程师手动备份如果没有lvm可以下载:yum install lvm2 -y LVM的管理命令 主要命令:LVM为我们提供了逻辑概念上的磁盘,使得文…

usb sop and eop

USB包(packet)由SOP,SYNC,Packet内容和EOP组成. SOP信号-------------瞬态信号 协议中的描述&#xff1a;7.1.7.4.1 The start of a packet (SOP) is signaled by the originating port by driving the D and D- lines from the Idle state to the opposite logic level (K …

实验六:倾斜开关实验

OK,周一周二一共10节课,比较辛苦,昨天下午还有咨询师模拟演练,很累,就早早休息了 今天早上就想写一个实验指导书 也就是现在的实验六 一会十点有《C语言程序设计》的课,不过,今天好在就只有两节课(课时,一次大课2个课时,习惯说2节课) 感觉又是我最喜欢和擅长的C…

JSON——简介

JSON——简介 JSON——基础语法 JSON——json数据与java对象的转换// 将java对象转为json字符串User user = new User(1,"zahngsan","123");// 转换String jsonString = JSON.toJSONString(user);System.out.println(jsonString);// 将json字符串转为jav…

java基于vue+springboot 的体育用品销售购物网站 多商家 nodejs

用户在打开网站之后首先打开的是首页部分&#xff0c;在首页部分可以看到一些推荐的信息 环境需要 1.运行环境&#xff1a;最好是java jdk 1.8&#xff0c;这是目前最稳定的JDK也是被使用最多的JDK版本。 2.IDE环境&#xff1a;IDEA&#xff0c;Eclipse都可以。推荐IDEA; 3.to…

移动端IM产品RainbowChat[专业版] iOS端 v6.0版已发布!

关于MobileIMSDK MobileIMSDK 是一套专门为移动端开发的开源IM即时通讯框架&#xff0c;超轻量级、高度提炼&#xff0c;一套API优雅支持UDP 、TCP 、WebSocket 三种协议&#xff0c;支持iOS、Android、H5、标准Java平台&#xff0c;服务端基于Netty编写。 工程开源地址是&…

分治法实现二分查找(python)

问题描述&#xff1a; 改写二分查找算法&#xff1a;设a[1…n]是一个已经排好序的数组&#xff0c;改写二分查找算法: 当搜索元素x不在数组中时&#xff0c;返回小于x的最大元素位置i&#xff0c;和大于x的最小元素位置j&#xff1b; (即返回x的左、右2个元素) 当搜索元素x在…

系动词使役动词

系动词 系动词的作用就是赋值 I am a rabbit 把 a rabbit赋值给i我 我是一只兔子 The rabbit is smart 这兔子是聪明的 smart赋值给兔子 系动词连系的方式,就是简简单单把它前后的概念含义连起来而已 所以系动词又叫连系动词 (Linking Verb) 就是把前后两端连起来(link)就好…

基于侧影轮廓的三维模型构建

建模过程 图像的获取 由于待建模物体具有较多细节,因此选择在同一个方向拍摄两个角度的照片(手机倾斜角大约为60度和45度,如下图所示),以及顶部细节照片,最终拍摄的有效照片为35张。模型构建 新建项目,并导入所有拍摄的照片照片掩饰 可以先采用自动掩饰工具将物体轮廓从…

kotlin koin

介绍 Koin是一个面向Android developer的依赖注入框架使用场景 为什么要用依赖注入框架? 比如我们有一个下载器对象Downloader,需要下面三个对象才能完成构造。但是这个下载器对象在各个活动中使用频繁val executor = Executor() val client = HttpClient() val request = Re…

使用 Zpan 搭建低成本个人私有网盘,还不限速

摘要&#xff1a;本文就介绍一个不限速的低成本个人网盘——ZPan&#xff0c;相较于老牌的私有网盘 OwnCloud 等&#xff0c;Zpan 有一个独有的优势&#xff1a;不限速。本文分享自华为云社区《使用 Zpan 搭建低成本个人私有网盘》&#xff0c;作者&#xff1a; 云存储开发者支…

甘特图:制定项目计划的三个要点

任何事情都要有计划&#xff0c;这样才能保证自己的事情按照既定的目标和轨迹推进 制定计划首先要明确以下三点&#xff1a; 1、目标明确&#xff1a;做这个项目是做什么的要达成什么目标。 2、任务明确&#xff1a;达成这个目标要做哪些事&#xff0c;有具体的实施推进步骤。…

MP-SPDZ详细介绍

基础知识概述 隐私计算底层协议包括两种&#xff1a;其一是基础的加密传输协议&#xff0c;用于信息分发&#xff0c;包括不经意传输、秘密分享、同态加密、零知识证明等。其二是加密计算协议&#xff0c;包括乱码电路、同态加密、零知识证明等。 不经意传输是所有隐私计算协…

python 运行错误收集

目录global全局声明错误 global全局声明错误 SyntaxError: name is_login is used prior to global declaration 解决办法:global is_login 放在 if is_login:的上面 is_login = Falsedef login_auth(func_name):def inner(*args, **kwargs):if is_login:res = func_name(*arg…

AlphaZero强化学习模型

搬来了DeepMind的AlphaTensor DeepMind前不久发在Nature上的论文Discovering faster matrix multiplication algorithms with reinforcement learning引发热议。 这篇论文在德国数学家Volken Strassen「用加法换乘法」思路和算法的基础上&#xff0c;构建了一个基于AlphaZero…

[GWCTF 2019]我有一个数据库

打开题目是乱码&#xff0c;好奇怪 御剑扫一下 扫到了phpmyadmin 版本为4.8.1 这个版本是有漏洞的&#xff08;CVE-2018-12613&#xff09;&#xff0c;复现一下 部分源码&#xff1a; $target_blacklist array (import.php, export.php ); ​ // If we have a valid target…

SpringBoot统一处理返回格式

在对接第三方接口的时候&#xff0c;第三方接口返回格式形式为{"result":null,"status":1010}&#xff0c;虽然返回了状态码&#xff0c;但是状态码对应的描述信息并没有携带&#xff0c;前端在使用的时候需要根据状态码返回一个友好的提示&#xff0c;如此…

刘韧:我每时每刻都会注意管理自己的知识

1. 担心总能让我积极行动起来。2. 要提早主动求变&#xff0c;不要等到被迫地、见招拆招地应变。3. 很多愚蠢的念头&#xff0c;都源于自己分内的事&#xff0c;却老想让别人负责&#xff0c;比如将自己的愿望寄托在子女身上。4. 推卸责任的同时&#xff0c;多少会对等地给予一…

ShardingSphere 5.2.0:分片审计功能拦截多分片场景下的不合理请求

一、背景Apache ShardingSphere 基于用户的实际使用场景&#xff0c;为用户打造了多种实用功能&#xff0c;包括数据分片、读写分离等。在数据分片功能中&#xff0c;我们发现有些用户涉及到的分片较多&#xff0c;一个分片逻辑表可能对应后端 1000 个物理表&#xff0c;这给用…