vue+elementUI完成注册及登陆

本文介绍了如何使用Vue.js结合ElementUI框架搭建注册和登录页面,详细阐述了Vue项目中引入和配置ElementUI的步骤,以及如何通过axios进行后台交互。在axios的使用中,讨论了跨域问题的解决方法,并引入qs库处理POST请求的数据格式问题,以确保后台能够正确接收数据。最后展示了简化后的axios和vue-axios配置,以及登录功能的实现方法。

1. vue怎么引入和配置使用element-ui框架
  1.1 使用vue-cli脚手架工具创建一个vue项目
      vue init webpack pro01

  1.2 npm安装elementUI
      cd pro01                                   #进入新建项目的根目录
      npm install element-ui -S                  #安装element-ui模块
1.3 在项目中src目录下找到main.js,并在指定位置添加三行代码(main.js是入口文件,所以在这里引入就行,页面就不用引入了)

2,创建登录注册页面,更改样式
3. 后台交互(axios/qs/vue-axios)

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

3.2 导入axios

然后重新启动项目(npm run dev)

把axios导入登录页面中 

 

 定义请求路径和参数

2.GET提交
      axios.get('/user', {//注意数据是保存到json对象的params属性
        params: {
          ID: 12345
        }
      }).then(function (response) {
        console.log(response);
      }).catch(function (error) {
        console.log(error);
      });

3.POST提交
      axios.post('/user', {//注意数据是直接保存到json对象
        firstName: 'Fred',
        lastName: 'Flintstone'
      }).then(function (response) {
        console.log(response);
      }).catch(function (error) {
        console.log(error);
      });

  注1:axios跨域问题,因为使用了前后端分离开发,跨域访问了,解决方案:需要配置tomcat允许跨域访问,
           tomcat跨域配置方法很多,但最简单的方式是自己写一个过滤器CorsFilter实现,添加一个响应头

 GET提交

 

设置提示框

  注2:axios.get提交没有问题,axios.post提交后台接收不到数据
           因为POST提交的参数的格式是Request Payload,这样后台取不到数据的,解决方案:使用qs.js库,将{a:'b',c:'d'}转换成'a=b&c=d'

 POST提交

 下载qs进行参数转换

导入qs 

将参数进行转换 

 

 拼接式

 简化axios/qs/vue-axios安装及使用步骤

 复制两个请求地址

 2.修改main.js文件

 import axios from '@/api/http'             #vue项目对axios的全局配置      
 mport VueAxios from 'vue-axios' 
 Vue.use(VueAxios,axios)

 login就可以不用引入了

 简化后的POST

 

 也是可以的 

 简化后的GET

 

 可以查看请求方式

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

<script>
  /* import axios from 'axios'
  import qs from 'qs' */
  export default {
    name:'Login',
    data:function(){
      return {
        username:'',
        password:''
      }
    },
    methods: {
      doLogin:function(){
        let username=this.username;
        let password=this.password;
        console.log("username=%s,password=%s",username,password);
        //定义请求路径
        let url=this.axios.urls.SYSTEM_USER_DOLOGIN;  //  /userAction.action
        //定义请求参数
        let params={
          username:username,
          password:password,
          methodName:'userLogin'
        }
        console.log(params);
        //发起ajax请求-GET(注意参数必须保存到params属性中)
        this.axios.get(url,{params:params}).then(resp=>{
          console.log(resp);
          let data=resp.data;
          console.log(data);
            this.$message({
                      message: data.msg,
                      type: data.code==1?'success':'error'
                    });
        }).catch(err=>{
          console.log(err);
        });
        //发起ajax请求-POST
        //payload:{a:'zs','b':'123'} ---> a=zs&b=123
        /* let str=qs.stringify(params);
        console.log(str); */
        /* this.axios.post(url,params).then(resp=>{
          console.log(resp);
        }).catch(err=>{
          console.log(err);
        });*/
      },
      toRegister:function(){
        this.$router.push('/Register');
      }
    }
  }
</script>

<style>
  .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>

连接数据库登录

 1,写一个登录方法

package com.zking.vue.dao;

import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.List;

import com.zking.vue.entity.User;
import com.zking.vue.util.CommonUtils;

public class UserDao extends BaseDao{
	
	public User userLogin(User user) {
		String sql="select * from t_user_vue where username='"+user.getUsername()+"' and password='"+user.getPassword()+"'";
		System.out.println(sql);
		@SuppressWarnings("unchecked")
		List<User> lst=super.executeQuery(sql, null, new CallBack<User>() {

			@Override
			public List<User> forEach(ResultSet rs) throws SQLException {
				return CommonUtils.toList(rs, User.class);
			}
			
		});
		if(lst!=null&&lst.size()!=0)
			return lst.get(0);
		else
		return null;
		
	}
}

2,调用方法

package com.zking.vue.action;

import java.io.IOException;
import java.util.HashMap;
import java.util.Map;

import javax.servlet.ServletException;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import com.fasterxml.jackson.databind.ObjectMapper;
import com.zking.mvc.framework.DispatcherAction;
import com.zking.mvc.framework.ModelDriver;
import com.zking.vue.dao.UserDao;
import com.zking.vue.entity.User;

public class UserAction extends DispatcherAction implements ModelDriver<User> {
	private User user=new User();
	private UserDao userDao=new UserDao();
	private ObjectMapper mapper=new ObjectMapper();
	@Override
	public User getModel() {
		return user;
	}

	public String userLogin(HttpServletRequest req,HttpServletResponse resp) 
			throws ServletException,IOException{
		Map<String,Object> json=new HashMap<String,Object>();
		User us=userDao.userLogin(user);
		if(us!=null) {
			json.put("code","1");
			json.put("msg", "用户登录成功");
		}else {
			json.put("code", "-1");
			json.put("msg", "用户名或密码错误");
		}
		mapper.writeValue(resp.getOutputStream(),json);
		return null;
	}
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值