Vue 使用vue完成登录+注册前后端交互的实现

news2024/11/23 23:01:29

前言:

我们上一篇已经讲解了如何使用vue去构建一个SPA项目。今天我们就在昨天的基础之上完成登录+注册前后端交互的实现。

我们使用Vue构建登录+注册前后端交互的实现有以下好处、意义和效率:

  1. 好处:

    • 响应式渲染:Vue采用了虚拟DOM技术,能够高效地追踪页面的状态变化,并只更新必要的部分,提升页面性能和用户体验。
    • 组件化开发:Vue的核心理念是组件化开发,将应用划分为一系列可复用、独立的组件,能够提高代码的可维护性和复用性。
    • 渐进式:Vue是一个渐进式框架,可以逐步引入和使用其功能,可与传统的HTML、CSS和JavaScript代码混合开发,无需全面重构。
    • 生态丰富:Vue生态系统提供了大量的插件和工具,能够迅速满足项目需求,提升开发效率。
  2. 意义:

    • 提升开发效率:Vue提供了直观、简洁的API和文档,容易上手,减少了开发人员的学习成本和工作量。
    • 优化用户体验:SPA可以实现前端路由,实现快速、无刷新的页面切换,提供流畅的用户体验。
    • 提升代码质量:Vue的组件化开发能够促使代码的模块化、可复用,使得项目结构清晰,易于维护和拓展。
  3. 效率:

    • 快速开发:Vue提供了一系列的工具和特性,如VueCLI、Vue Router和Vuex等,能够快速搭建项目骨架,并提供开箱即用的路由和状态管理解决方案。
    • 热重载:Vue在开发模式下支持热重载,可以实时预览修改的效果,大大提高了开发效率。
    • 社区支持:Vue拥有庞大的开发者社区和活跃的维护团队,能够及时解决问题并提供支持。

一,前期准备

1.使用命令添加Element-UI模块

Element 介绍:

Element 是一款基于 Vue.js 的开源 UI 组件库,旨在帮助开发者构建出现代化的 Web 应用程序界面。它提供了丰富多样的可重用组件,并支持自定义主题和样式,使开发者能够快速搭建出具有良好用户体验的界面。

Element 是一个功能强大的前端 UI 组件库,通过提供丰富的组件和灵活的定制选项,使开发者能够快速构建现代化的 Web 应用程序界面。

npm install element-ui -S

2.使用命令添加安装axios(这里我就直接将一次性下载完)

这是axios中的 get请求命令

npm i axios -S

这是axios中的 post请求命令

npm install qs -S

注意事项:

1.这里我们要确保网络通畅!!!

2.在指定的SPA根目录下运行cmd才能进行添加下载的插件。

3.下载插件前我们要将运行的项目关闭,关闭项目的快捷键:Ctrl+C,选择Y选项。

4.指令后的-s/-g/-d有什么区别?

重视项目的稳定性和可维护性:

使用-s选项安装包可以确保项目的依赖项被明确地列出。这意味着其他人在克隆项目或部署项目时能够准确地获得相同的依赖项,从而提高项目的稳定性和可维护性。

关注全局安装的适用性:某些包提供了全局命令工具,通过-g选项安装可以让这些工具在终端中以全局命令的方式使用。这对于开发人员来说很方便,可以在任意目录下使用这些命令,提高开发效率。

开发依赖项的管理:-d选项用于保存开发依赖项,这些依赖项通常是在构建、测试和调试等过程中使用的工具和库。在开发过程中,我们可能会使用一些临时性的依赖项,而不希望它们被包含在最终的生产代码中。将这些依赖项保存为devDependencies可以使项目更加整洁和可管理。

二,登录+注册静态页实现

第一步:在src目录下创建views目录(该目录用于存放vue组件,今天我们要存放Login.vue和register.vue)

第二步:在main.js中引入element-ui模块(注意顺序不能错)

import Vue from 'vue'

// 新添加1
import ElementUI from 'element-ui' 
// 新添加2,避免后期打包样式不同,要放在import App from './App';之前
import 'element-ui/lib/theme-chalk/index.css' 

import App from './App'
import router from './router'

// 新添加3
Vue.use(ElementUI)   
Vue.config.productionTip = false

Element - 网站快速成型工具icon-default.png?t=N7T8https://element.eleme.cn/#/zh-CN引入好了我们就去组件中copy一个样式复制到SPA项目中,进行运行查看是否能运行。

这里我们测试一波:

第三步:创建用户登录组件Login.vue

<template>
	<div class="login-wrap">
		<el-form class="login-container">
			<h1 class="title">用户登录</h1>
			<el-form-item label="">
				<el-input type="text" v-model="username" placeholder="登录账号" autocomplete="off"></el-input>
			</el-form-item>
			<el-form-item label="">
				<el-input type="password" v-model="password" placeholder="登录密码" autocomplete="off"></el-input>
			</el-form-item>
			<el-form-item>
				<el-button type="primary" style="width:100%;" @click="doSubmit()">提交</el-button>
			</el-form-item>
			<el-row style="text-align: center;margin-top:-10px">
				<el-link type="primary">忘记密码</el-link>
				<el-link type="primary" @click="gotoRegister()">用户注册</el-link>
			</el-row>
		</el-form>
	</div>
</template>

<script>
	import axios from 'axios'
	export default {
		name: 'Login',
		data: function() {
			return {
				username: "",
				password: ""
			}
		},
		methods: {
			doSubmit: function() {
				let params = {
					username: this.username,
					password: this.password
				};
				console.log(params);
				var url = "http://localhost:8080/user/userLogin";

				axios.get(url, {
					params: params
				}).then(res => {
					console.log(res);
					if (res.data.success) {
						this.$message({
							message: res.data.msg,
							type: 'success'
						});
						// this.$router.push()
					} else {
						this.$message.error('用户暂未注册!')
					}
				}).catch(function(error) {
					// console.log(error);
					// this.$message.error('用户暂未注册!');
				});
			},
			gotoRegister: function() {
				this.$router.push('/Register')
		},
		}
	}
</script>


<style scoped>
	.login-wrap {
		box-sizing: border-box;
		width: 100%;
		height: 100%;
		padding-top: 10%;
		background-image: url();
		/* background-color: #112346; */
		background-repeat: no-repeat;
		background-position: center right;
		background-size: 100%;
	}

	.login-container {
		border-radius: 10px;
		margin: 0px auto;
		width: 350px;
		padding: 30px 35px 15px 35px;
		background: #fff;
		border: 1px solid #eaeaea;
		text-align: left;
		box-shadow: 0 0 20px 2px rgba(0, 0, 0, 0.1);
	}

	.title {
		margin: 0px auto 40px auto;
		text-align: center;
		color: #505458;
	}
</style>

第四步:创建用户注册组件R.vue

<template>
	<div class="login-wrap">
		<el-form class="login-container">
			<h1 class="title">用户注册</h1>
			<el-form-item label="">
				<el-input type="text" v-model="username" placeholder="注册账号" autocomplete="off"></el-input>
			</el-form-item>
			<el-form-item label="">
				<el-input type="password" v-model="password" placeholder="注册密码" autocomplete="off"></el-input>
			</el-form-item>
			<el-form-item>
				<el-button type="primary" style="width:100%;" @click="doSubmit()">提交</el-button>
			</el-form-item>
			<el-row style="text-align: center;margin-top:-10px">
				<!-- <el-link type="primary">忘记密码</el-link> -->
				<el-link type="primary" @click="gotoLogin()">用户登录</el-link>
			</el-row>
		</el-form>
	</div>
</template>

<script>
import axios from 'axios'
export default {
    name: 'Login',
    data: function() {
        return {
            username: "",
            password: ""
        }
    },
   methods: {
   	doSubmit: function() {
   		let params = {
   			username: this.username,
   			password: this.password
   		};
   		console.log(params);
   		var url = "http://localhost:8888/ssm/user/userLogin";
   
   		axios.get(url, {
   			params: params
   		}).then(res => {
   			console.log(res);
   			if (res.data.success) {
   				this.$message({
   					massage: res.data.msg,
   					type: 'success'
   				});
   				// this.$router.push()
   			} else {
   				this.$message.error('用户暂未注册!')
   			}
   		}).catch(function(error) {
   		});
   	},
   	gotoLogin: function() {
   		this.$router.push('/')
   },
   }
}
</script>



<style scoped>
	.login-wrap {
		box-sizing: border-box;
		width: 100%;
		height: 100%;
		padding-top: 10%;
		background-image: url();
		/* background-color: #112346; */
		background-repeat: no-repeat;
		background-position: center right;
		background-size: 100%;
	}

	.login-container {
		border-radius: 10px;
		margin: 0px auto;
		width: 350px;
		padding: 30px 35px 15px 35px;
		background: #fff;
		border: 1px solid #eaeaea;
		text-align: left;
		box-shadow: 0 0 20px 2px rgba(0, 0, 0, 0.1);
	}

	.title {
		margin: 0px auto 40px auto;
		text-align: center;
		color: #505458;
	}
</style>

三,后台实现

介绍axios

Axios是一个基于Promise 用于浏览器和 nodejs 的 HTTP 客户端,本质上也是对原生XHR的封装,只不过它是Promise的实现版本,符合最新的ES规范。

vue-axios是在axios基础上扩展的插件,在Vue.prototype原型上扩展了$http等属性,可以更加方便的使用axios

第一步:下载安装vue-axios

第二步:导入api模块,添加axios的全局配置

将api模块导入到SPA项目的src目录下,其中api模块包含了action.js(针对后台请求接口的封装定义)和http.js(针对axios的全局配置)两个文件。

如下图:

action.js

export default {
    'SERVER': 'http://localhost:8080/j2ee15', //服务器
    'SYSTEM_USER_DOLOGIN': '/userAction.action', //登陆
    'SYSTEM_USER_DOREG': '/userAction.action', //注册
    'getFullPath': k => { //获得请求的完整地址,用于mockjs测试时使用
        return this.SERVER + this[k];
    }
}

对后台请求的地址的封装,URL格式:模块名实体名操作

http.js

import axios from 'axios'
import qs from 'qs'
​
//引入action模块,并添加至axios的类属性urls上
import action from '@/api/action'
axios.urls = action
​
// axios默认配置
axios.defaults.timeout = 10000; // 超时时间
// axios.defaults.baseURL = 'http://localhost:8080/j2ee15'; // 默认地址
axios.defaults.baseURL = action.SERVER;
​
//整理数据
// 只适用于 POST,PUT,PATCH,transformRequest` 允许在向服务器发送前,修改请求数据
axios.defaults.transformRequest = function(data) {
    data = qs.stringify(data);
    return data;
};
​
// 请求拦截器
axios.interceptors.request.use(function(config) {
    return config;
}, function(error) {
    return Promise.reject(error);
});
​
// 响应拦截器
axios.interceptors.response.use(function(response) {
    return response;
}, function(error) {
    return Promise.reject(error);
});
export default axios;

3.1axios之get请求

<script>
	import axios from 'axios'
	export default {
		name: 'Login',
		data: function() {
			return {
				username: "",
				password: ""
			}
		},
		methods: {
			doSubmit: function() {
				let params = {
					username: this.username,
					password: this.password
				};
				console.log(params);
				var url = "http://localhost:8080/user/userLogin";//与后台的地址保持一致

				axios.get(url, {
					params: params
				}).then(res => {
					console.log(res);
					if (res.data.success) {
						this.$message({
							message: res.data.msg,
							type: 'success'
						});
						// this.$router.push()
					} else {
						this.$message.error('用户暂未注册!')
					}
				}).catch(function(error) {
					// console.log(error);
					// this.$message.error('用户暂未注册!');
				});
			},
			gotoRegister: function() {
				this.$router.push('/Register')
		},
		}
	}
</script>

get传递参数带来的弊端:

3.2axios之post请求

与get请求有大的区别:

1.导入qs

2.改变传递的参数写法

代码的优化:

因为我们不管是发送get或post请求时我们都要写,所以我们封装一个公共的资源,只调用就行了。

第三步:cmd执行:

npm i vue-axios -S

我们在之前已经导入过了api文件。

第二步:修改main.js配置vue-axios

在main.js文件中引入api模块和vue-axios模块

import axios from '@/api/http'                 
import VueAxios from 'vue-axios' 
​
Vue.use(VueAxios,axios)

第三步:这里我们也要对Login进行处理(符合规则)

doSubmit() {
        let url = this.axios.urls.SYSTEM_USER_DOLOGIN;
        let params = {
          username: this.username,
          password: this.password
        }
 
 
        //前端发送ajax的post方式
        this.axios.post(url,params).then(r=> {
          // console.log(r);
          if (r.data.success) {
            this.$message({
              message: r.data.msg,
              type: 'success'
            });
          } else {
            this.$message.error(r.data.msg);
          }
 
        }).catch(r=> {
          //如果有问题就会走这里
          // console.log(error);
        });
 
 
 
      }

3.3注册的后台:

Register.vue

<template>
	<div class="login-wrap">
		<el-form class="login-container">
			<h1 class="title">用户注册</h1>
			<el-form-item label="">
				<el-input type="text" v-model="username" placeholder="注册账号" autocomplete="off"></el-input>
			</el-form-item>
			<el-form-item label="">
				<el-input type="password" v-model="password" placeholder="注册密码" autocomplete="off"></el-input>
			</el-form-item>
			<el-form-item>
				<el-button type="primary" style="width:100%;" @click="doSubmit()">提交</el-button>
			</el-form-item>
			<el-row style="text-align: center;margin-top:-10px">
				<!-- <el-link type="primary">忘记密码</el-link> -->
				<el-link type="primary" @click="gotoLogin()">用户登录</el-link>
			</el-row>
		</el-form>
	</div>
</template>

<script>
import axios from 'axios'
export default {
    name: 'Login',
    data: function() {
        return {
            username: "",
            password: ""
        }
    },
   methods: {
   	doSubmit: function() {
   		let params = {
   			username: this.username,
   			password: this.password
   		};
   		console.log(params);
   		var url = "http://localhost:8888/user/Register";
   
   		axios.get(url, {
   			params: params
   		}).then(res => {
   			console.log(res);
   			if (res.data.success) {
   				this.$message({
   					massage: res.data.msg,
   					type: 'success'
   				});
   				// this.$router.push()
   			} else {
   				this.$message.error('用户暂未注册!')
   			}
   		}).catch(function(error) {
   		});
   	},
   	gotoLogin: function() {
   		this.$router.push('/')
   },
   }
}
</script>



<style scoped>
	.login-wrap {
		box-sizing: border-box;
		width: 100%;
		height: 100%;
		padding-top: 10%;
		background-image: url();
		/* background-color: #112346; */
		background-repeat: no-repeat;
		background-position: center right;
		background-size: 100%;
	}

	.login-container {
		border-radius: 10px;
		margin: 0px auto;
		width: 350px;
		padding: 30px 35px 15px 35px;
		background: #fff;
		border: 1px solid #eaeaea;
		text-align: left;
		box-shadow: 0 0 20px 2px rgba(0, 0, 0, 0.1);
	}

	.title {
		margin: 0px auto 40px auto;
		text-align: center;
		color: #505458;
	}
</style>

当我们写到注册时,我们应该要实现从注册跳转到登录,登录跳转到注册的功能实现。

 methods: {
      gotoRegister() {
        this.$router.push('/Register')
      }
 
    }

使用我们的idea编写我们后端业务:

IUserService

int insertSelective(User record);


 
实现IUserService

  @Override
    public int insertSelective(User record) {
        return userMapper.insertSelective(record);
    }


在Controller中写一个实现IUserService
 

  @RequestMapping("/Register")
    @ResponseBody
    public JsonResponseBody<?> userRegistered(UserVo userVo, HttpServletRequest request){
        int i = userService.insertSelective(userVo);
        if(i>0){
            return new JsonResponseBody<>("用户注册成功!",true,0,null);
        }else{
            return new JsonResponseBody<>("注册失败!",false,0,null);
        }
    }

四、跨域问题

4.1.什么是跨域问题
跨域指的是在浏览器中,当前网页的域名与发送请求的目标资源所在的域名不一致。具体来说,当浏览器发起一个跨域请求时,会受到同源策略(Same Origin Policy)的限制。

同源策略是浏览器的一种安全机制,它限制了来自不同源(域名、协议、端口)的 JavaScript 代码对当前文档的访问。换句话说,JavaScript 只能访问与其所在文档具有相同源的资源,而无法直接访问跨域的资源。

解决跨域问题:在我们的项目中添加配置

CorsFilter2.java

package com.zking.ssm.util;
 
import java.io.IOException;
 
import javax.servlet.Filter;
import javax.servlet.FilterChain;
import javax.servlet.FilterConfig;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
import javax.servlet.http.HttpServletResponse;
 
/**
 * 配置tomcat允许跨域访问
 * 
 * @author Administrator
 *
 */
public class CorsFilter2 implements Filter {
 
	@Override
	public void init(FilterConfig filterConfig) throws ServletException {
	}
 
	@Override
	public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain)
			throws IOException, ServletException {
		HttpServletResponse httpResponse = (HttpServletResponse) servletResponse;
 
		// Access-Control-Allow-Origin就是我们需要设置的域名
		// Access-Control-Allow-Headers跨域允许包含的头。
		// Access-Control-Allow-Methods是允许的请求方式
		httpResponse.setHeader("Access-Control-Allow-Origin", "*");// *,任何域名
		httpResponse.setHeader("Access-Control-Allow-Headers", "responseType,Origin, X-Requested-With, Content-Type, Accept");
		httpResponse.setHeader("Access-Control-Allow-Methods", "POST, GET, PUT, DELETE");
 
		//允许客户端处理一个新的响应头jwt
		//httpResponse.setHeader("Access-Control-Expose-Headers", "jwt,Content-Disposition");
		filterChain.doFilter(servletRequest, servletResponse);
	}
 
	@Override
	public void destroy() {
 
	}
}

web.xml

 <!--CrosFilter跨域过滤器-->
  <filter>
    <filter-name>corsFilter</filter-name>
    <filter-class>com.zking.ssm.util.CorsFilter2</filter-class>
  </filter>
  <filter-mapping>
    <filter-name>corsFilter</filter-name>
    <url-pattern>/*</url-pattern>
  </filter-mapping>

五,效果:

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Coupang走什么物流?Coupang火箭颜色什么意思?——站斧浏览器

coupang物流包括三个选项&#xff0c;分别是“自发货”“CGF”和“CGF LITE”&#xff0c;怎么选择才对自己最有利的呢&#xff1f;coupang火箭颜色什么意思&#xff1f;一起来了解下吧。 coupang走什么物流? ① 自发货 也就是卖家自己找第三方货代公司帮你发货&#xff0c…

C++ - map 和 set 的模拟实现 - 红黑树当中的仿函数 - 红黑树的迭代器实现

简单了解map 和 set 的实现 首先我们要知道&#xff0c;map 和 set 的底层就是 红黑树&#xff0c;但是 STL 当中 &#xff0c;map 和 set 并不是我们想象的&#xff0c;直接使用一个 pair 对象来存储一个 key-value 或者 是 一个 key。具体如下所示&#xff1a; set&#xff…

大数据Flink(八十九):Temporal Join(快照 Join)

文章目录 Temporal Join(快照 Join) Temporal Join(快照 Join) Temporal Join 定义(支持 Batch\Streaming):Temporal Join 在离线的概念中其实是没有类似的 Join 概念的,但是离线中常常会维护一种表叫做 拉链快照表,使用一个明细表去 join 这个 拉链快照表 的 join …

介绍 Docker 的基本概念和优势V2.0

介绍 Docker 的基本概念和优势V2.0 一、Docker 的基本概念1.1 Docker 是什么&#xff1f;1.2 Docker 的组成部分1.3 Docker 的基本概念 二、Docker 的优势1. 轻量级&#xff1a;2. 可移植性&#xff1a;3. 自包含&#xff1a;4. 隔离性&#xff1a;5. 可扩展性&#xff1a;6. 易…

SpringBoot 学习(八)异步任务,邮件发送和定时执行

8. 异步任务 (1) 开启异步注解 // 启动类 EnableAsync SpringBootApplication public class TestApplication {public static void main(String[] args) {SpringApplication.run(TestApplication.class, args);}}(2) 声明异步方法 // service Service public class AsyncSer…

更新node版本运行程序报错

更新了电脑上的node以及npm的版本&#xff0c;出现了一些问题&#xff1a; 1.npm 报错 Class extends value undefined is not a constructor or null 在运行或者安装依赖的时候&#xff0c;出现这个问题的话&#xff0c;可以先下载一个低一级别的node版本&#xff0c;然后升…

安卓生成公钥和md5签名

安卓公钥和md5证书签名 大家好&#xff0c;最近需要备案app&#xff0c;用到了公钥和md5&#xff0c;MD5签名我倒是知道&#xff0c;然而对于公钥却一下子不知道了&#xff0c; 现在我讲一下我的流程。 首先是md5证书签名的查看&#xff0c; 生成了apk和签名.jks后&…

人工智能赋能财务体系架构

我看到这个价格给我的感觉上半部分是一个数据中台&#xff0c;下半部分全部就是机器学习的原理&#xff1b;

Learn Prompt- Midjourney案例:建筑设计

基础结构​ 这是一个非常适合在 V5 中的生产建筑的提示结构。 我们不妨先回顾一下上一章节的通用模板&#xff1a; 主题 背景,环境,氛围 风格 参数 在建筑生成的设定下&#xff0c;我们可以使用 主题详细描述 周边环境 建筑风格或时期、建筑师、设计师和摄影师 参数…

【深度学习实验】卷积神经网络(一):卷积运算及其Pytorch实现(一维卷积:窄卷积、宽卷积、等宽卷积;二维卷积)

目录 一、实验介绍 二、实验环境 1. 配置虚拟环境 2. 库版本介绍 三、实验内容 1. 一维卷积 a. 概念 b. 示例 c. 分类 窄卷积&#xff08;Narrow Convolution&#xff09; 宽卷积&#xff08;Wide Convolution&#xff09; 等宽卷积&#xff08;Same Convolution&am…

通信协议:Uart的Verilog实现(上)

1、前言 调制解调器是主机/设备与串行数据通路之间的接口&#xff0c;以串行单比特格式发送和接收数据。它也被称为通用异步收发器(Uart, Universal Asynchronous Receiver/Transmitter)&#xff0c;这表明该设备能够接收和发送数据&#xff0c;并且发送和接收单元不同步。 本节…

Python项目实战:基于2D或3D的区域增长算法

文章目录 一、简介二、项目实战2.1、2D图像&#xff08;10x10&#xff09;2.2、2D图像&#xff08;100x100&#xff09;2.3、3D图像&#xff08;10x10x10&#xff09; 一、简介 区域增长算法是一种用于图像分割方法&#xff0c;将相邻像素按照一定的相似性合并成一个区域。 步…

Spring 学习(九)整合 Mybatis

1. 整合 Mybatis 步骤 导入相关 jar 包 <dependencies><dependency><groupId>junit</groupId><artifactId>junit</artifactId><version>4.12</version><scope>test</scope></dependency><dependency>…

规模化、可复制的大模型应用——企业知识管家

9月18日&#xff0c; “2023可信AI大会暨南京人工智能产业发展大会大模型高质量发展分论坛”在南京成功举办&#xff0c;九章云极DataCanvas公司受邀出席论坛&#xff0c;和与会嘉宾共同探讨大模型时代企业知识管理面临的挑战和机遇&#xff0c;同时作为大模型创新与应用代表企…

每日一题2023.9.25|LeetCode1367.二叉树中的链表

1367.二叉树中的链表 链接&#xff1a;LeetCode1367.二叉树中的链表 错误分析 其实这道题目思路很简单&#xff1a; 采用前序遍历的方式从根节点开始遍历二叉树&#xff0c;并在遍历的过程中比较与链表节点的值是否相等&#xff0c;如果当前链表节点的值和树节点的值相等&am…

怎样提高外贸业务销售能力

怎样提高外贸业务销售能力 一、市场分析与研究1. 了解目标市场&#xff1a;2. 收集客户信息&#xff1a; 二、产品知识和差异化竞争1. 熟悉产品&#xff1a;2. 差异化竞争&#xff1a; 三、制定销售策略和计划1. 制定销售计划&#xff1a;2. 销售策略&#xff1a; 四、谈判技巧…

Python开发与应用实验2 | Python基础语法应用

*本文是博主对学校专业课Python各种实验的再整理与详解&#xff0c;除了代码部分和解析部分&#xff0c;一些题目还增加了拓展部分&#xff08;⭐&#xff09;。拓展部分不是实验报告中原有的内容&#xff0c;而是博主本人自己的补充&#xff0c;以方便大家额外学习、参考。 &a…

Wespeaker框架训练(1)

1. 数据集准备(Data preparation) 进入wespeaker目录文件/home/username/wespeaker/examples/voxceleb/v2 对run.sh文件进行编辑 vim run.sh 可以看到run.sh里面的配置内容 #数据集下载&#xff0c;解压 stage1 #插入噪音&#xff0c;制作音频文件 stop_stage2 #数据集放置…

如何重装Windows Mirosoft Store

重装Windows Mirosoft Store 如何重装Windows Mirosoft Store呢&#xff1f;如何下载Windows Mirosoft Store呢&#xff1f;Windows Mirosoft Store不见了咋办&#xff1f;Windows 自带软件不见了咋办等等&#xff1f;写在前面 1.文件准备2.安装 如何重装Windows Mirosoft Stor…

Java之序列化的详细解析

3. 序列化 3.1 概述 Java 提供了一种对象序列化的机制。用一个字节序列可以表示一个对象&#xff0c;该字节序列包含该对象的数据、对象的类型和对象中存储的属性等信息。字节序列写出到文件之后&#xff0c;相当于文件中持久保存了一个对象的信息。 反之&#xff0c;该字节…