使用ElementUI完成登入注册的跨域请求,结合vue-cli搭建的SPA项目,减少冗余代码提升开发效率

news2024/11/18 11:45:39

目录

一、跨域的概述

( 1 )  讲述

( 2 )  特点

如何跨域: 

二、ElementUI

( 1 )  导入

( 2 )  搭建

( 3 )  页面

三、数据交互

( 1 )  安装相关模块

安装模块

 引用模块

( 2 )  axios的get请求

( 3 )  axios的post请求

四、注册功能

带来的收获


一、跨域的概述

( 1 )  讲述

跨域(Cross-Origin)是指在浏览器环境下,当前网页的域名、协议或端口与请求资源的域名、协议或端口不一致,导致浏览器限制了这种跨域请求的访问。

跨域请求受到浏览器的同源策略(Same-Origin Policy)的限制。同源策略是浏览器的一种安全机制,用于保护用户的隐私和数据安全。同源策略要求,如果两个URL的协议、域名和端口都相同,则这两个URL同源,可以进行跨域通信。否则,就是跨域请求,浏览器会阻止这种跨域请求的访问。

跨域请求的限制主要体现在以下几个方面:

  • 1.Cookie、LocalStorage和IndexDB的限制:跨域请求默认不携带Cookie、LocalStorage和IndexDB等存储数据的信息。这是因为这些信息可能包含用户的敏感信息,如果跨域请求可以携带这些信息,就会造成安全风险。如果需要在跨域请求中携带这些信息,可以通过设置相应的响应头部(Access-Control-Allow-Credentials)和请求头部(withCredentials)来实现。

  • 2. XMLHttpRequest和Fetch API的限制:XMLHttpRequest和Fetch API是浏览器提供的用于发送HTTP请求的接口,它们遵循同源策略,不允许跨域请求。如果需要进行跨域请求,可以使用CORS(Cross-Origin Resource Sharing)来解决。

CORS是一种基于HTTP头部的跨域解决方案。服务器在响应中添加Access-Control-Allow-Origin头部,指定允许跨域访问的域名,浏览器在发送跨域请求时,会先发送一个OPTIONS请求进行预检,如果服务器返回的响应头部中包含Access-Control-Allow-Origin,就允许跨域访问。

  • 3. 脚本访问的限制:在浏览器中,通过<script>标签加载的脚本(例如使用JSONP)可以跨域访问。但是,由于脚本的执行是在全局作用域下进行的,跨域脚本可以获取和修改当前页面的信息,可能存在安全风险。因此,浏览器对跨域脚本的访问进行了限制。

总结起来,跨域是指浏览器中当前网页与请求资源的域名、协议或端口不一致,需要通过一些特定的方法来解决跨域请求的问题,保证数据的安全性和可靠性

以上是跨域请求的一些限制和安全考虑。为了解决这些问题,可以采用以下几种常见的跨域解决方法:

  1. JSONP:通过动态创建<script>标签,将跨域请求的数据作为参数传递到服务器上的一个回调函数中,服务器返回的数据会被包裹在回调函数中,从而实现跨域请求。

  2. CORS:通过在服务器端设置响应头部,允许指定的域名进行跨域访问。

  3. 代理服务器:通过在同一域名下设置代理服务器,将跨域请求转发到目标服务器,再将结果返回给浏览器。这种方式需要在服务器端进行配置,适用于无法修改前端代码的情况。

  4. WebSocket:WebSocket协议不受同源策略的限制,可以在不同域名之间进行双向通信。通过建立WebSocket连接,可以实现跨域通信。

需要注意的是,不同的解决方法适用于不同的场景和需求,开发人员需要根据具体情况选择合适的解决方案。同时,跨域请求的限制是由浏览器实现的,不同浏览器对跨域请求的支持程度可能会有所不同。因此,开发人员在进行跨域请求时,需要考虑浏览器的兼容性

( 2 )  特点

跨域具有以下几个特点:

1. 安全性:同源策略是浏览器的一种安全机制,限制了跨域请求的访问。跨域请求可能会引发安全风险,例如跨站脚本攻击(XSS)和跨站请求伪造(CSRF)。同源策略可以保护用户的隐私和数据安全。

2. 限制性:跨域请求受到浏览器的限制,不同域名之间的通信受到限制。这是因为浏览器出于安全考虑,不希望恶意网站通过跨域请求获取用户的敏感信息,或者进行非法操作。

3. 解决方法多样:虽然跨域请求受到限制,但是有多种解决方法可以绕过这个限制,实现跨域通信。常见的解决方法包括JSONP、CORS、代理服务器和WebSocket等。开发人员可以根据具体的需求和场景选择合适的解决方案。

4. 浏览器支持:跨域请求的限制是由浏览器实现的,不同浏览器对跨域请求的支持程度可能会有所不同。大多数现代浏览器都支持CORS,但是对于一些旧版本的浏览器可能不支持或支持不完全。

5. 适用范围广:跨域请求不仅限于浏览器环境,也存在于其他网络环境中。例如,在移动应用开发中,如果需要从一个域名获取数据,也会遇到跨域请求的问题。因此,跨域请求的解决方法具有一定的通用性。

综上所述,跨域具有安全性、限制性、多样的解决方法、浏览器支持和适用范围广等特点。了解这些特点可以帮助开发人员更好地理解跨域问题,并选择合适的解决方案。

如何跨域: 

需要进行前后端访问,及数据进行交互就需要解决跨域的问题。

以下是跨域问题的体现,有该错误就说明是跨域问题

如图 : 

需要解决呢,在maven项目中的创建一个过滤器,名为: CorsFilter

代码如下 : 

package com.CloudJun.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.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

/**
 * 配置tomcat允许跨域访问
 * 
 * @author Administrator
 *
 */
public class CorsFilter 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;
		HttpServletRequest req = (HttpServletRequest) servletRequest;
		// Access-Control-Allow-Origin就是我们需要设置的域名
		// Access-Control-Allow-Headers跨域允许包含的头。
		// Access-Control-Allow-Methods是允许的请求方式
		httpResponse.setHeader("Access-Control-Allow-Origin", "*");// *,任何域名
		httpResponse.setHeader("Access-Control-Allow-Methods", "POST, GET, PUT, DELETE");
		
		//允许客户端发一个新的请求头jwt
		httpResponse.setHeader("Access-Control-Allow-Headers","responseType,Origin,X-Requested-With, Content-Type, Accept, jwt");
		//允许客户端处理一个新的响应头jwt
		httpResponse.setHeader("Access-Control-Expose-Headers", "jwt,Content-Disposition");
		
		//httpResponse.setHeader("Access-Control-Allow-Headers", "Origin, X-Requested-With, Content-Type, Accept");
		//httpResponse.setHeader("Access-Control-Allow-Methods", "POST, GET, PUT, DELETE");
		
		// axios的ajax会发两次请求,第一次提交方式为:option,直接返回即可
		if ("OPTIONS".equals(req.getMethod())) {
			return;
		}
		filterChain.doFilter(servletRequest, servletResponse);
	}
	@Override
	public void destroy() {

	}
}

如何在maven项目中的 web.xml 文件中进行配置该过滤器

配置如下 :

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

 完成以上就可以解决跨域的问题,之后就可以进行前后端的访问,进行数据交互

二、ElementUI

( 1 )  导入

第一步:使用CMD命令窗口,并跳转到指定工作目录下创建项目

输入以下命令来创建项目 : 

vue init webpack spa

注 : 其中 spa 是项目名称,可以自己进行修改项目名称。

关于项目的创建及搭建在我博客中的项目搭建的构建中:

使用vue-cli搭建SPA项目及使用和路由及路由嵌套的使用

第二步:使用CMD命令窗口,并跳转到指定项目的目录下面

如 : cd spa  (其中spa是项目名称已是要进入的目录名称)

第三步:使用命令npm install element-ui -S,添加Element-UI模块到项目中

 操作如图: 

最后,打开项目的package.json文件可查看具体添加模块信息。

如图所示 : 

( 2 )  搭建

在项目中的src目录下创建views目录(该目录用于存放vue组件)。

添加Element-UI模块到项目中后,在项目的src目录中找main.js中引入element-ui模块

需要引入的代码:

import ElementUI from 'element-ui'

import 'element-ui/lib/theme-chalk/index.css'

Vue.use(ElementUI)

注 : 导入依赖需要按照顺序要求进行

如图:

所有代码:

// The Vue build version to load with the `import` command
// (runtime-only or standalone) has been set in webpack.base.conf with an alias.
import Vue from 'vue'

// 1 导入ElementUI依赖
import ElementUI from 'element-ui'
// 2 导入ElementUI的样式,注意:导入ElementUI要放在import App from './App';之前
import 'element-ui/lib/theme-chalk/index.css'

import App from './App'
import router from './router'
// 3 增加ElementUI实例
Vue.use(ElementUI)
Vue.config.productionTip = false

/* eslint-disable no-new */
new Vue({
  el: '#app',
  router,
  components: { App },
  template: '<App/>'
})

( 3 )  页面

views目录下创建一个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="Register()">用户注册</el-link>
			</el-row>
		</el-form>
	</div>
</template>

<script>
export default {
  name: 'Login',
  data () {
    return {
      username:"",
      password:"",
      msg: '嗨!嗨!嗨!'
    }
  },
  methods:{
   Register(){
      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>

修改 App.vue 组件的css样式进行登入页面的效果美化,将以下代码覆盖到style标签中

<style>
html,
body {
    width: 100%;
    height: 100%;
    box-sizing: border-box;
    padding: 0px;
    margin: 0px;
}
#app {
    font-family: "Avenir", Helvetica, Arial, sans-serif;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    color: #2c3e50;
    widows: 100%;
    height: 100%;
}
</style>

然后在项目路径下面,输入以下命令开启项目。

开启命令 :  npm run pev

开起后访问指定路径在浏览器中进行访问,如 :   http://localhost:8080

效果如图 : 

三、数据交互

( 1 )  安装相关模块

安装模块

在我们的maven项目中,需要前后端请求的话,需要在maven项目中安装ajax模块

在前端的spa项目中,在本地的根本路径下,Win+R,输入cmd,打开cmd窗口。

输入以下命令安装所需模块

npm i axios -S

npm i qs-S

操作命令如图 : 

 

axios是vue2提倡使用的轻量版的ajax。它是基于promise的HTTP库。它会从浏览器中创建XMLHttpRequests,与Vue配合使用非常好。

冗余代码的模块

在此,我们前端的代码会有请求路径及引入模块等等的很多冗余代码。

为解决这一问题,我们只需下载一个vue-axios的引用整合模块

在项目中安装之后,对于后期项目的维护有极大的帮助和很大的提升项目开发的效率

在前端的spa项目中,在本地的根本路径下,Win+R,输入cmd,打开cmd窗口。

输入以下命令安装所需模块

npm i vue-axios -S

 

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

查看模块

在前端项目的package.json的文件中看到以下,就说明安装模块已经完成

 引用模块

安装后就在项目中进行引用,添加axios的全局配置,创建一个actio.js

/**
 * 对后台请求的地址的封装,URL格式如下:
 * 模块名_实体名_操作
 */
export default {
	'SERVER': 'http://localhost:8080/ssm', //服务器地址
	'SYSTEM_USER_DOLOGIN': '/user/userLogin', //登陆请求
	'SYSTEM_USER_DOREG': '//user/userRegister', //注册请求
	'getFullPath': k => { //获得请求的完整地址,用于mockjs测试时使用
		return this.SERVER + this[k];
	}
}

action.js针对后台请求接口的封装定义)和http.js(针对axios的全局配置)两个文件。​​​​​​​

创建http.js,用于vue项目对axios的全局配置

/**
 * vue项目对axios的全局配置
 */
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);
});

// // 路由请求拦截
// // http request 拦截器
// axios.interceptors.request.use(
// 	config => {
// 		//config.data = JSON.stringify(config.data);  
// 		//config.headers['Content-Type'] = 'application/json;charset=UTF-8';
// 		//config.headers['Token'] = 'abcxyz';
// 		//判断是否存在ticket,如果存在的话,则每个http header都加上ticket
// 		// if (cookie.get("token")) {
// 		// 	//用户每次操作,都将cookie设置成2小时
// 		// 	cookie.set("token", cookie.get("token"), 1 / 12)
// 		// 	cookie.set("name", cookie.get("name"), 1 / 12)
// 		// 	config.headers.token = cookie.get("token");
// 		// 	config.headers.name = cookie.get("name");
// 		// }
// 		return config;
// 	},
// 	error => {
// 		return Promise.reject(error.response);
// 	});

// // 路由响应拦截
// // http response 拦截器
// axios.interceptors.response.use(
// 	response => {
// 		if (response.data.resultCode == "404") {
// 			console.log("response.data.resultCode是404")
// 			// 返回 错误代码-1 清除ticket信息并跳转到登录页面
// 			//      cookie.del("ticket")
// 			//      window.location.href='http://login.com'
// 			return
// 		} else {
// 			return response;
// 		}
// 	},
// 	error => {
// 		return Promise.reject(error.response) // 返回接口返回的错误信息
// 	});



export default axios;

之后在前端项目中,关联相关的创建及js文件进行应用。

在前端的项目中main.js文件中引入vue-axios 模块

// 在main.js文件中引入vue-axios模块
import axios from '@/api/http'
import VueAxios from 'vue-axios'
// 增加VueAxios及axios实例
Vue.use(VueAxios,axios)

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

( 2 )  axios的get请求

在我们的登入组件中进行axios的get请求,编写Login.vue的代码

script标签的代码修改为以下代码进行get请求

<script>
  import axios from 'axios'
  export default {
    name: 'Login',
    data() {
      return {
        username: "",
        password: "",
        msg: '嗨!嗨!嗨!'
      }
    },
    methods: {
      Register() {
        this.$router.push('/Register');
      },
      doSubmit() {
        let params = {
          username: this.username,
          password: this.password
        };
        console.log(params);
        //定义后端都请求地址
        var url = "http://localhost:8080/ssm/user/userLogin";
        //注意数据是保存到json对象的params属性
        //进行请求携带数据进行登入访问
        axios.get(url, {
          //携带的参数(数据)
          params: params,
        }).then(r => {
          //如果携带的参数数据跟后端数据对应正确,说明登入成功,提示
          if(r.data.success){
             this.$message({
                      showClose: true,
                      message: r.data.msg,
                      type: 'success'
            });
          }else{
            //如果携带的参数数据跟后端数据对应错误,说明登入失败,提示
             this.$message.error(r.data.msg);
          }
          console.log(r);
        }).catch(e => {
          console.log(e);
        });
      }
    }
  }
</script>

在我们的后端项目中,有一个视图解析器来处理我们前端发过来的请求进行处理

代码如下 : 

package com.CloudJun.ssm.controller;

import com.CloudJun.ssm.service.IUserService;
import com.CloudJun.ssm.util.JsonResponseBody;
import com.CloudJun.ssm.util.PageBean;
import com.CloudJun.ssm.vo.UserVo;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import com.CloudJun.ssm.jwt.*;

@Controller
@RequestMapping("/user")
public class UserController {

    @Autowired
    private IUserService userService;

    @RequestMapping("/userLogin")
    @ResponseBody
    public JsonResponseBody<?> userLogin(UserVo userVo, HttpServletResponse response){
        if(userVo.getUsername().equals("admin")&&userVo.getPassword().equals("123")){
            //私有要求claim
//            Map<String,Object> json=new HashMap<String,Object>();
//            json.put("username", userVo.getUsername());
            //生成JWT,并设置到response响应头中
//            String jwt=JwtUtils.createJwt(json, JwtUtils.JWT_WEB_TTL);
//            response.setHeader(JwtUtils.JWT_HEADER_KEY, jwt);
            return new JsonResponseBody<>("用户登陆成功!",true,0,null);
        }else{
            return new JsonResponseBody<>("用户名或密码错误!",false,0,null);
        }
    }

    @RequestMapping("/queryUserPager")
    @ResponseBody
    public JsonResponseBody<List<Map<String,Object>>>
            queryUserPager(UserVo userVo, HttpServletRequest request){
        try {
            PageBean pageBean=new PageBean();
            pageBean.setRequest(request);
            List<Map<String, Object>> users = userService.queryUserPager(userVo, pageBean);
            return new JsonResponseBody<>("OK",true,pageBean.getTotal(),users);
        } catch (Exception e) {
            e.printStackTrace();
            return new JsonResponseBody<>("分页查询用户信息失败!",false,0,null);
        }

    }
}

注 : ( 其中的导包需要根据自己的项目包的结构进行导包方可 )

在前端项目的根本路径下,Win+R,输入cmd,打开cmd窗口。

输入命令开启项目 : 

npm run dev

并且在后端的maven项目,开启服务器(开启项目),可以进行访问才可

之后在指定的请求地址进行访问,显示前端的页面(视图或者说组件)

展现的效果如图 : 

( 3 )  axios的post请求

使用pos请求一并也进行资源的整合

之前我们把需要的应用模块及组件配置都已经完成,现在我们只需要编写我们的登入组件。

将名为 : 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="Register()">用户注册</el-link>
      </el-row>
    </el-form>
  </div>
</template>

<script>
  import axios from 'axios' //用于GET请求
  import qs from 'qs' //用于post请求
  export default {
    name: 'Login',
    data() {
      return {
        username: "",
        password: "",
        msg: '嗨!嗨!嗨!'
      }
    },
    methods: {
      Register() {
        this.$router.push('/Register');
      },
      doSubmit() {
        let params = {
          username: this.username,
          password: this.password
        };
        console.log(params);
        //定义后端都请求地址
        var url = this.axios.urls.SYSTEM_USER_DOLOGIN;
        //注意数据是保存到json对象的params属性

        //以下是GET请求
        //进行请求携带数据进行登入访问
        // axios.get(url, {
        //   //携带的参数(数据)
        //   params: params,
        // }).then(r => {
        //   //如果携带的参数数据跟后端数据对应正确,说明登入成功,提示
        //   if (r.data.success) {
        //     this.$message({
        //       showClose: true,
        //       message: r.data.msg,
        //       type: 'success'
        //     });
        //   } else {
        //     //如果携带的参数数据跟后端数据对应错误,说明登入失败,提示
        //     this.$message.error(r.data.msg);
        //   }
        //   console.log(r);
        // }).catch(e => {
        //   console.log(e);
        // });

        //以下是post请求及整合资源
        //通过qs中的stringify方法进行格式转换
        //注意数据是保存到json对象的params属性
        this.axios.post(url,params).then(r => {
          console.log(r);
          //如果携带的参数数据跟后端数据对应正确,说明登入成功,提示
          if (r.data.success) {
            this.$message({
              showClose: true,
              message: r.data.msg,
              type: 'success'
            });
          } else {
            //如果携带的参数数据跟后端数据对应错误,说明登入失败,提示
            this.$message.error(r.data.msg);
          }
        }).catch(e => {
          console.log(e);
        });


      }
    }
  }
</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>

展现的效果已是一样,并且将代码减少提高开发效率。

效果如图 : 

四、注册功能

在前端创建组件 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="输入密码" show-password autocomplete="off"></el-input>
      </el-form-item>

      <el-form-item label="账号名称" label-width="80px" style="margin-left: 5px;" prop="name">
        <el-input v-model="realname"></el-input>
      </el-form-item>

      <el-form-item label="性别" style="margin-left: 20px;">
        <el-radio-group v-model="sex">
          <el-radio label="1">男</el-radio>
          <el-radio label="2">女</el-radio>
          <el-radio label="3">人妖</el-radio>
        </el-radio-group>
      </el-form-item>

      <el-form-item label="身 份 证" label-width="80px" style="margin-left: 0px;" prop="name">
        <el-input v-model="idcard"></el-input>
      </el-form-item>

      <el-input type="textarea" :rows="2" placeholder="请输入地址" v-model="address">
      </el-input>

      <el-form-item style="margin-top: 30px;">
        <el-button type="primary" style="width:100%;"
          @click="Register()">注&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;册</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="Login()">用户登入</el-link>
      </el-row>
    </el-form>
  </div>
</template>

<script>
  export default {
    name: 'Register',
    data() {
      return {
        username: "",
        password: "",
        realname: '',
        sex: 0,
        idcard: '',
        address: '',
        msg: '嗨!嗨!嗨!',
        rules: {
          realname: [{
              required: true,
              message: '请输入账号名称',
              trigger: 'blur'
            },
            {
              min: 3,
              max: 18,
              message: '长度在 3 到 18 个字符',
              trigger: 'blur'
            }
          ]
        }
      }

    },
    methods: {
      Login() {
        this.$router.push('/');
      },
      Register() {
        let params = {
          username: this.username,
          password: this.password,
          realname: this.realname,
          sex: this.sex,
          idcard: this.idcard,
          address: this.address
        };
        //定义后端都请求地址
        var url = this.axios.urls.SYSTEM_USER_DOREG;
        console.log(params);
        console.log(url);
        //以下是post请求及整合资源
        //通过qs中的stringify方法进行格式转换
        //注意数据是保存到json对象的params属性
        this.axios.post(url, params).then(r => {
          console.log(r);
          //如果携带的参数数据跟后端数据对应正确,说明登入成功,提示
          if (r.data.success) {
            this.$message({
              showClose: true,
              message: r.data.msg,
              type: 'success'
            });
            //注册完成后自动进入登入界面
            this.$router.push('/');
          } else {
            //如果携带的参数数据跟后端数据对应错误,说明登入失败,提示
            this.$message.error(r.data.msg);
          }
        }).catch(e => {
          console.log(e);
        });



      }
    }
  }
</script>

<style scoped>
  .login-wrap {
    padding-top: 30px;
    box-sizing: border-box;
    width: 100%;
    height: 100%;
    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>

在后端的maven项目中 IUserService 的代码

 int insertSelective(User record);

在后端的maven项目中 UserServiceImpl 的代码

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

在后端的maven项目中 UserController(控制器) 的代码

    @RequestMapping("/userRegister")
    @ResponseBody
    public JsonResponseBody<?> userRegister(UserVo userVo, HttpServletResponse response){
        //状态新注册默认为0
        userVo.setStatus("0");
        //因为ID为String类型需要手动设置,当然可以根据自己的需要改为Int类型
        userVo.setId("5");
        int i = userService.insertSelective(userVo);
        if(i>0){
            return new JsonResponseBody<>("用户注册完成!快去登入吧!",true,0,null);
        }else{
            return new JsonResponseBody<>("用户注册失败!重新输入。",false,0,null);
        }
    }

展现效果 : 

带来的收获

学习跨域及ElementUI的使用和前后端的数据交互可以带来以下收获:

1. 跨域解决方案:了解跨域问题的产生原因和解决方案,掌握常见的跨域解决方法,例如JSONP、CORS、代理等,能够有效处理前端页面与后端接口之间的跨域请求问题。

2. ElementUI的使用:ElementUI是一套基于Vue.js的组件库,学习使用ElementUI可以快速搭建美观、易用的前端界面,提高开发效率。掌握ElementUI的基本组件和布局,能够快速构建前端界面,并且能够根据项目需求进行自定义样式和功能。

3. 前后端数据交互:学习前后端数据交互的方法,包括发送请求、处理响应、处理异常等,能够实现前后端数据的传递和交互。掌握常见的数据格式,例如JSON、XML等,能够处理数据的序列化和反序列化。了解常见的前后端数据交互方式,例如RESTful API、GraphQL等,能够根据项目需求选择合适的数据交互方式

4. 提升项目开发能力:掌握跨域解决方案、ElementUI的使用和前后端数据交互,能够更好地完成前端项目的开发工作,提升自己的项目开发能力。能够快速解决跨域问题,提高前端页面的用户体验;能够使用ElementUI构建美观、易用的前端界面,提高项目的用户满意度;能够实现前后端数据的传递和交互,提高项目的功能完整性和稳定性。

总之,学习跨域及ElementUI的使用和前后端的数据交互,可以帮助我们更好地完成前端项目的开发工作,提升自己的技术能力和项目开发能力。

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

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

相关文章

安卓实现网格布局的效果

文章目录 页面子项布局 Activity适配器 运行结果其他文章 页面 RecyclerView是Android开发中常用的列表控件之一&#xff0c;可以用于展示大量数据以及实现各种布局效果。本文章使用RecyclerView的GridLayoutManager来实现网格布局&#xff0c;显示指定列数。 首先&#xff0c…

25. 图论 - 路径和算法

文章目录 拓展:顶点和边的互换最短路径问题Dijkstra算法Hi, 你好。我是茶桁。 在充分了解图的概念,构成以及种类之后,我们要开始进入稍微有点难度的部分了。这节课,咱们来了解一下路径和Dijkstra算法。 拓展:顶点和边的互换 在这节课正式开始之前,我们对上一节课稍微扩…

Java笔记:认识运行时数据区

1. 运行时数据区概述 1.1 JVM运行时数据区规范 JVM虚拟机组成&#xff1a;方法区(类信息)、堆(伊甸园、老年代、永久代:new的对象等)、虚拟机栈、程序计数器、本地方法栈1.方法区和堆是内存共享的 2.虚拟机栈、本地方法栈、程序计数器是内存不共享的3.方法区&#xff1a;类信息…

描述符——接口描述符

描述符定义 描述符实现 /*** brief USB interface descriptor.*/ typedef struct __attribute__ ((packed)) {uint8_t bLength ; /**< Size of this descriptor in bytes. */uint8_t bDescriptorType ; /**< INTERFACE Descriptor Type. */uint8_t bIn…

MySQL数据库——索引(3)-索引语法(创建索引、查看索引、删除索引、案例演示),SQL性能分析(SQL执行频率,慢查询日志)

目录 索引语法 创建索引 查看索引 删除索引 案例演示 SQL性能分析 SQL执行频率 慢查询日志 索引语法 创建索引 CREATE [ UNIQUE | FULLTEXT ] INDEX index_name ON table_name (index_col_name,... ) ; 查看索引 SHOW INDEX FROM table_name ; 删除索引 DROP INDEX …

AD拼板技巧

AD拼板设置 如图&#xff0c;有一个需要拼板的PCB&#xff0c;想要在生产是拼接生产&#xff0c;节省材料。 操作如下&#xff1a; 1、全选如下&#xff0c;按复制CtrlC。 2、把输入法调整至英文&#xff0c;按快捷键E&#xff08;先&#xff09;&#xff0c; A&#xff08;后…

开发工具MobaXterm(终极终端)

MobaXterm 又名 MobaXVT&#xff0c;是一款增强型终端、X 服务器和 Unix 命令集(GNU/ Cygwin)工具箱。 常用SSH客户端介绍&#xff1a; SSH 为 Secure Shell 的缩写&#xff0c;是目前较可靠&#xff0c;专为远程登录会话和其他网络服务提供安全性的协议。利用 SSH 协议可以有…

【1993. 树上的操作】

来源&#xff1a;力扣&#xff08;LeetCode&#xff09; 描述&#xff1a; 给你一棵 n 个节点的树&#xff0c;编号从 0 到 n - 1 &#xff0c;以父节点数组 parent 的形式给出&#xff0c;其中 parent[i] 是第 i 个节点的父节点。树的根节点为 0 号节点&#xff0c;所以 par…

C++中的Template

模板的概念 建立通用的模具&#xff0c;大大提高复用性 模板不可直接使用 函数模板 函数模板语法 函数模板作用&#xff1a; 建立一个通用函数&#xff0c;其函数返回值类型和形参类型可以不具体制定&#xff0c;用一个虚拟的类型来代表。 语法&#xff1a; template&l…

小程序社区团购demo

概述 实现了用户登录或者手机号&#xff0c;加入团长&#xff0c;邀请团长&#xff0c;各种佣金明细等页面 详细 需求&#xff1a; 根据市场信息反馈&#xff0c;社区团购比较火&#xff0c;有流量的用户可以推广页面 实现了功能&#xff1a; 实现了用户微信登录自动获取…

vue之 h() 函数

前言 Vue推荐在绝大数情况下使用模板来创建HTML&#xff0c;然后一些特殊的场景&#xff0c;你真的需要JavaScript的完全编程的能力&#xff0c;这个时候你可以使用渲染函数 &#xff0c;它比模板更接近编译器&#xff1b; h()函数是什么 Vue在生成真实的DOM之前&#xff0c…

如何用好免费的ChatGPT

如何用好免费的ChatGPT 前言ChatGPT使用入口在线体验地址&#xff1a;点我体验 ChatGPT介绍ChatGPT初级使用技巧初级使用技巧&#xff1a;清晰明了的问题表达 ChatGPT中级使用语法中级使用语法&#xff1a;具体化问题并提供背景信息 ChatGPT高级使用高级使用&#xff1a;追问、…

Vue中如何进行表格排序与过滤

Vue中如何进行表格排序与过滤 在Vue.js中&#xff0c;表格是一个常见的数据展示方式。很多时候&#xff0c;我们需要对表格中的数据进行排序和过滤&#xff0c;以提供更好的用户体验。本文将介绍如何在Vue中实现表格的排序和过滤功能&#xff0c;并提供相关的代码示例。 准备工…

WebSocket通信安全概览

文章前言 在一次做项目的时候本来是想去点击Burpsuite的Proxy界面的HTTP History选项卡来查看HTTP历史请求记录信息并做测试的&#xff0c;但是在查看的时候却下意识的点击到了HTTP Proxy右侧的"WebSockets History"选项卡中&#xff0c;从界面的交互历史中发现网站…

2023华为杯数模C题——大规模创新类竞赛评审方案研究

B题——大规模创新类竞赛评审方案研究 思路&#xff1a;采用数据分析等手段改进评分算法性能 完成情况(1-2问已经完成) 代码下载 问题一 在每个评审阶段&#xff0c;作品通常都是随机分发的&#xff0c;每份作品需要多位评委独立评审。为了增加不同评审专家所给成绩之间的可比…

c语言代码

目录 1.利用goto的关机程序 2.交换两个整数&#xff08;容易出现的错误&#xff09; 2.1 错误示范 2.1.1 错误的原因 3.函数调用进行折半查找 3.1错误版本 3.1.1错误原因 4.写一个函数&#xff0c;每调用一次这个函数&#xff0c;就会将num的值增加1。 4.1使用传值进去 5.有关p…

【初阶数据结构】二叉树全面知识总结

二叉树详解 树的概念及其结构树的概念树的相关概念树的表示方法孩纸兄弟表示法双亲表示法&#xff08;并查集&#xff09; 树的实际应用 二叉树二叉树的概念二叉树的种类二叉树的性质二叉树的存储结构 二叉树顺序结构的实现堆的概念及结构堆向上、向下调整法堆的插入堆的删除堆…

基于ENC28J60+uIP1.0+STM32的UDP Server实现,服务器主动发送数据的实现,几个关键的问题可算整明白了!

ENC28J60&#xff0c;是一款SPI接口的以太网PHYMAC芯片&#xff0c;实现以太网物理层和MAC层硬件通信。uIP是一个TCP/IP软件协议栈&#xff0c;实现TCP、UDP、ARP、ICMP等网络协议。STM32F103RCT6通过SPI接口与ENC28J60通讯&#xff0c;并移植uIP协议&#xff0c;实现一个小型的…

20230224_HDR-ISP_环境配置

https://github.com/JokerEyeAdas/HDR-ISP/tree/main 一、环境配置 *.VS2015编译不过&#xff1b;VS2017没问题 *.将红框部分复制到工程下面 *.添加头文件路径 *.添加原文件

【C#】Redis在net core下使用教程

系列文章 文章目录 系列文章前言一、Redis 简介1.1 Redis 优势1.2 Redis与其他key-value存储有什么不同&#xff1f; 二、Redis安装步骤2.1 下载链接2.2 安装测试 三、Redis修改帐户密码四、Redis写成Windows服务五、.net core - 使用CSRedisCore操作redis 前言 官方教程&…