实现vue项目和springboot项目前后端数据交互-CSDN博客

阿里云国内75折 回扣 微信号:monov8
阿里云国际,腾讯云国际,低至75折。AWS 93折 免费开户实名账号 代冲值 优惠多多 微信号:monov8 飞机:@monov6

1、安装node.js

  • 太高版本的win7不支持
    这里安装node-v12.16.2-x64.msi指定安装位置后直接按下一步就可以。
  • npm是node内置的工具
    这里配置npm的镜像cnpm提高下载速度以后用到npm的命令都可以用cnpm命令替换不指定cnpm版本使用如下命令会报错
npm install -g cnpm --registry=https://registry.npm.taobao.org
  • 错误信息
npm WARN notsup Unsupported engine for npm-normalize-package-bin@3.0.1: wanted:{"node":"^14.17.0 || ^16.13.0 || >=18.0.0"} (current: {"node":"12.16.2","npm":"6.14.4"})
npm WARN notsup Not compatible with your version of node/npm: npm-normalize-package-bin@3.0.1
  • 检查错误参照网上的对应版本图node12要用cnpm 6版本输入如下命令
npm install -g cnpm@6 --registry=https://registry.npm.taobao.org

在这里插入图片描述

  • 查看node和npm版本
node -v
npm -v

2、安装vue-cli脚手架

  • vue-cli是在node基础上构建的工具而vue-cli又可以快速搭建含vue功能的模块即模块化开发。安装vue-cli 3.x脚手架命令如下
cnpm install @vue/cli -g
  • 查看版本
vue -V

3、创建vue项目

vue-cli脚手架创建的是模块化项目使用模块化开发.vue后缀的文件为单文件组件一个文件里封装了html、js、css代码。项目属于单页面应用SPA通过路由跳转链接不利于SEO爬虫抓取不到内容可以用Nuxt框架解决该问题这是后话。所以说vue比较适合做后台管理系统。但前端分离的插拔特性可以让它方便地切换为移动端浏览器、app或小程序。

  • 这里有两种方法创建第一种是用命令会在当前文件夹下创建文件夹
vue create 项目名 
  • 第二种用UI可视化界面创建
vue ui

启动vue可视化工具会在浏览器中打开创建过项目的需要返回主页
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
选手动配置
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
点创建即可。
在这里插入图片描述
这里不保存预设。
在这里插入图片描述
等待安装完来到欢迎界面就可以就可以关闭网页了后期安装其它插件我们可以通过命令行执行也很方便。

  • 进入项目文件夹下cmd执行命令启动项目
cd 项目文件夹名
npm run serve

运行后显示如下在浏览器中输入其中一个地址即可看到欢迎界面说明vue项目成功跑起来了。
在这里插入图片描述
在这里插入图片描述

4、数据交互的准备工作

这里默认你已经懂得vue编码的一些基础知识由于缩减篇幅所以在此只会贴上关键代码。

前后端分离的项目要进行数据交互我们使用的是异步请求工具JS使用的是Ajax而vue使用的是axios

  • 安装axios插件
cnpm install axios -S
cnpm i vue-axios -S

5、前后端数据交互之前端

前后端人员协商会有接口文档我们以登录和注册为例
在这里插入图片描述

  • 登录请求
//发送get请求 查询用户用post更安全这里只是举例使用方法
						this.axios.get("http://localhost:80/api/user/login",{
							params:{
								"username":username,
								"password":password
							}
						}).then(resp => { //数据传输成功
							//用户名密码正确
							if(resp.data.data_status === 0){
							//路由跳转
								router.push("/")
							}
							else{
							//显示失败消息可能是用户名或密码错误
								ElMessage({
									message:resp.data.data.message,
									duration:1000,
									type:"error"
								})
							}							
						}).catch(error => { //数据传输失败
							console.log(error)
						})
  • 注册
//访问后台保存用户(注册)
					  this.axios.post("http://localhost:80/api/user/register",{
						  "username":username,
						  "email":email,
						  "password":password
					  }).then(function(response){
						  //发送成功接受返回注册状态信息
						  if(response.data.data_status === 0){
							  //注册成功,路由跳转							
							  router.push("/login")
						  }
						  else{
						  	//显示注册失败用户已存在
							  ElMessage({
							  	message:response.data.data.message,
							  	duration:1000,
							  	type:"error"
							  })
						  }
					  }).catch(function(response){
						  alert("数据传输失败")
					  })
  • 注意这里的data_status、data.message是由后端返回的数据决定的名称要与后端设定的返回值一致可以先用console.log(response)查看一下返回的数据。

6、前后端数据交互之后端

  • GET提交请求的数据会附在URL之后在地址栏显示出来POST提交把提交的数据放置在是 HTTP 包的包体请求体中。地址栏不会改变。
  • 后端Get不要在参数加@RequestBody因为请求是在url里中传参
    Post要在参数加@RequestBody因为是在请求体中取值
  • 后端登录
	//后端登录
	@GetMapping("/api/user/login")
	@ResponseBody//使用ajax时必须加会把返回类转化为json  Get不要加@RequestBody是在url里中传参
	public CommonResult<Message> loginVue(User user){
		
		//注册用户逻辑
		int data_status = userService.loginVue(user);
		if (data_status == 0) {
			return CommonResult.success(Message.createMessage("注册成功"));
		} 
		//实际开发中的状态码举例   10001 用户已存在  10002 用户名或密码错误  20001 商品已存在 。。。
		else if(data_status == 2){
			return CommonResult.failed(data_status, Message.createMessage("用户名或密码错误"));
		}
		else {
			return null;
		}
		
	}
  • 后端注册
	@PostMapping("/api/user/register")
	@ResponseBody//使用ajax时必须加会把返回类转化为json  Post要加@RequestBody是在请求体中取值
	public CommonResult<Message> registerVue(@RequestBody User user){
		
		//System.out.println(username);
//		System.out.println(user);
		//注册用户逻辑
		int data_status = userService.registerVue(user);
		if (data_status == 0) {
			return CommonResult.success(Message.createMessage("注册成功"));			
		} else {
			return CommonResult.failed(data_status, Message.createMessage("用户名或邮箱已存在请更改信息"));
		}
		
	}

Get请求不要在参数前加@RequestBodyPost请求要在参数前加@RequestBody。重要的事情说三遍

这样就可以直接使用User user参数来接受值

  • 后端登录还是注册都会有返回值类名可以自定义但类里的属性名称定义要和接口文档一致这样前端接收到对应的值。这里我们定义了一个泛型的CommonResult<Message>。
package com.zzz.login_demo.utils;

public class CommonResult<T> {

	private Integer data_status;
	private T data;
	
	protected CommonResult() {
	}
	
	protected CommonResult(int data_status, T data){
		this.data_status = data_status;
		this.data = data;
	}
	
	//返回成功不带data信息
	public static CommonResult<Object> success() {
		return new CommonResult<Object>(0, null);
	}
	//返回成功带data信息
	public static <T> CommonResult<T> success(T data) {
		return new CommonResult<T>(0, data);
	}
	//返回失败带data信息
	public static <T> CommonResult<T> failed(int data_status, T data) {
		return new CommonResult<T>(data_status, data);
	}

	//get/set...
}
package com.zzz.login_demo.utils;

public class Message {
	
	private String message;

	protected Message() {
	}
	
	public Message(String message) {
		super();
		this.message = message;
	}
	
	public static Message createMessage(String message) {
		return new Message(message);
	}

	//get/set...

}
  • 测试前后端数据交互时报错Access-Control-Allow-Origin
Access to XMLHttpRequest at 'http://xxx' from origin 'http://localhost:8080' has been blocked by CORS policy: No 'Access-Control-Allow-Origin' header is present on the requested resource.

这是跨域请求出错可以在前端或后端配置跨域请求。
感觉添加后端配置跨域请求比较方便在每个Controller类的注解@Contoller的下一行添加注解@CrossOrigin即可。

7、扩展

vue项目如何部署到服务器Nginx
前端、后端分开开发时如何模拟用假数据测试mockjs、postman
感兴趣的童靴可以留言给我我会安排写作。

阿里云国内75折 回扣 微信号:monov8
阿里云国际,腾讯云国际,低至75折。AWS 93折 免费开户实名账号 代冲值 优惠多多 微信号:monov8 飞机:@monov6
标签: Springvue

“实现vue项目和springboot项目前后端数据交互-CSDN博客” 的相关文章