Registration of Spa project development

Keywords: Javascript Front-end Ajax

catalogue

1: The spa project completes the login and registration layout

1. Install development module

2. Introduce the main.js configuration (leading css and then JS)

Tests: adding   elementUI   Component view effect  

  3. Login registration layout

1,src/App.vue

2,src/router/index.js

3. src/views/Login.vue (login)

4. src/views/Reg.vue (registered)

  2: Spa project completes the login function

1. Import an existing project

  2. Start front and rear data interaction

  3: This   Variable pollution caused by pointer

  1. Add message prompt

  ​   2. Perfect login  

4: ajax   Cross domain problem

1. Comment out web.xml in eclipse   To solve the cross domain problem of CORS, the filter will report the following errors (any CORS in the error is   Cross domain issues)

5: xios   of   get/post   Differences between(   qs  )

  1. axios original writing

1: The spa project completes the login and registration layout

1. Install development module

Enter NPM install element UI - S   (install element UI)

npm install axios -S (plug-in for front and rear data interaction)

npm install qs -S   (solve the difference between get/post of axios)

NPM install Vue Axios - S (for integration)


Note: ERR cannot appear during installation and download. If the installation of element UI fails, press the up key to re install  

2. Introduce the main.js configuration (leading css and then JS)

import Vue from 'vue'

import ElementUI from 'element-ui'

import 'element-ui/lib/theme-chalk/index.css'  , Avoid different packaging styles in the later stage, and put them before import App from './App

import App from './App'

import router from './router'

Vue.use(ElementUI) 

Vue.config.productionTip = false

Tests: adding   elementUI   Component view effect  

<template>
  <div id="app">
    <el-row>
  <el-button>Default button</el-button>
  <el-button type="primary">Main button</el-button>
  <el-button type="success">Success button</el-button>
  <el-button type="info">Information button</el-button>
  <el-button type="warning">Warning button</el-button>
  <el-button type="danger">Danger button</el-button>
</el-row>
    <router-link to="/">home page</router-link>
    <router-link to="/Abort">about</router-link>
    <!-- The content displayed by the anchor depends on the component to which the route points-->
    <router-view/>
  </div>
</template>
<script>
export default {
  name: 'App'
}
</script>
 
<style>
#app {
  font-family: 'Avenir', Helvetica, Arial, sans-serif;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-align: center;
  color: #2c3e50;
  margin-top: 60px;
}
</style>

Display results

  3. Login registration layout

First, learn new things from imitation

Components: public components

views: business component

1,src/App.vue

<template>
  <div id="app">
 
    <router-view></router-view>
  </div>
</template>
 
<script>
export default {
  name: 'App'
}
</script>
 
<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>

2,src/router/index.js

import Vue from 'vue'
import Router from 'vue-router'
import HelloWorld from '@/components/HelloWorld'
import Login from '@/views/Login'
import Reg from '@/views/Reg'
Vue.use(Router)
 
export default new Router({
  routes: [{
      path: '/',
      name: 'Login',
      component: Login
    },
    {
      path: '/Login',
      name: 'Login',
      component: Login
    },
    {
      path: '/Reg',
      name: 'Reg',
      component: Reg
    }
  ]
})

3. src/views/Login.vue (login)

<template>
  <div id="app" class="login-wrap">
 
    <el-form :model="ruleForm" status-icon ref="ruleForm" class="demo-ruleForm login-container ">
      <h3 style="text-align: center;">User login interface</h3>
      <el-form-item label="account number" prop="uname">
        <el-input type="text" v-model="ruleForm.uname" autocomplete="off"></el-input>
      </el-form-item>
      <el-form-item label="Confirm password" prop="pwd">
        <el-input type="password" v-model="ruleForm.pwd" autocomplete="off"></el-input>
      </el-form-item>
 
      <el-form-item>
        <el-row>
          <el-col :span="24">
            <div class="grid-content bg-purple-dark"></div>
          </el-col>
          <el-button style="width: 100%;" type="primary" @click="submitForm('ruleForm')">Submit</el-button>
        </el-row>
 
        <el-row>
          <el-col :span="12">
            <div class="grid-content bg-purple-dark"></div>
          </el-col>
          <el-link type="primary" @click="toReg">User registration</el-link>
 
          <el-col :span="12">
            <div class="grid-content bg-purple-dark"></div>
          </el-col>
          <el-link type="success">Forget password</el-link>
 
        </el-row>
 
      </el-form-item>
    </el-form>
  </div>
</template>
 
 
<script>
 
  export default {
    name: 'Login',
    data() {
      return {
        ruleForm: {}
      }
    },
    methods: {
      toReg() {
        this.$router.push({
          path: '/Reg'
        });
      }
    }
  }
</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>

4. src/views/Reg.vue (registered)

<template>
  <div id="app" class="login-wrap">
    <el-form :model="ruleForm" status-icon ref="ruleForm" class="demo-ruleForm login-container">
        <h2 style="text-align: center;">User registration</h2>
      <el-form-item label="account number" prop="pass">
        <el-input type="text" v-model="ruleForm.uname" autocomplete="off"></el-input>
      </el-form-item>
      <el-form-item label="password" prop="checkPass">
        <el-input type="password" v-model="ruleForm.pwd" autocomplete="off"></el-input>
      </el-form-item>
      <el-form-item label="Confirm password" prop="checkPass">
        <el-input type="password" v-model="ruleForm.pwd" autocomplete="off"></el-input>
      </el-form-item>
      <el-form-item>
        <el-row>
          <el-col :span="24">
            <div class="grid-content bg-purple-dark">
              <el-button style="width: 100%;" type="primary" @click="submitForm('ruleForm')">register</el-button>
            </div>
          </el-col>
        </el-row>
        <el-row>
          <el-col :span="12">
            <div class="grid-content bg-purple-dark">
              <el-link type="primary" @click="toLogin">User login</el-link>
            </div>
          </el-col>
          <el-col :span="12">
            <div class="grid-content bg-purple-dark">
              <el-link type="success">Forget password</el-link>
            </div>
          </el-col>
        </el-row>
      </el-form-item>
    </el-form>
  </div>
</template>

<script>
  export default {
    name: 'Login',
    data() {
      return {
        ruleForm: {}
      }
    },
    methods:{
      toLogin(){
         this.$router.push({path:'/Login'});
      }
    }
  }
</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>

Where: main code of page Jump:

< El link type = "primary" @ Click = "toreg" > user registration < / El link >

<script>
 
  export default {
    name: 'Login',
    data() {
      return {
        ruleForm: {}
      }
    },
    methods: {
      toReg() {
        this.$router.push({
          path: '/Reg'
        });
      }
    }
  }
</script>

Operation results:

  Register run results

  2: Spa project completes the login function

1. Import an existing project

1. Open eclipse and click file - > Import.. - > existing Maven Projects - > broese to select your existing ready-made projects

2. The following instructions are successful when running

  2. Start front and rear data interaction

1. Import Api folder to src

   (1).action.js

/**
 * Encapsulation of the address requested by the background. The URL format is as follows:
 * Module name entity name operation
 */
export default {
	'SERVER': 'http://localhost:8080/T216_SSH ', / / server
	'SYSTEM_USER_DOLOGIN': '/vue/userAction_login.action', //User login
	'SYSTEM_USER_DOREG': '/vue/userAction_reg.action', //User registration
	'SYSTEM_MENU_TREE': '/vue/treeNodeAction.action', //Left tree menu loading
	'SYSTEM_ARTICLE_LIST': '/vue/articleAction_list.action', //Article list
	'SYSTEM_ARTICLE_ADD': '/vue/articleAction_add.action', //Article addition
	'SYSTEM_ARTICLE_EDIT': '/vue/articleAction_edit.action', //Article modification
	'SYSTEM_ARTICLE_DEL': '/vue/articleAction_del.action', //Article deletion
	'SYSTEM_USER_GETASYNCDATA': '/vue/userAction_getAsyncData.action', //Asynchronous loading data in vuex
	'getFullPath': k => { //Obtain the full address of the request for use in mockjs testing
		return this.SERVER + this[k];
	}
}
/**
 * vue Project global configuration for axios
 */
import axios from 'axios'
import qs from 'qs'
 
//The action module is introduced and added to the class attribute urls of axios
import action from '@/api/action'
axios.urls = action
 
// axios default configuration
axios.defaults.timeout = 10000; // Timeout
// axios.defaults.baseURL = 'http://localhost:8080/j2ee15 '; / / default address
axios.defaults.baseURL = action.SERVER;
 
//Organize data
// Only applicable to POST,PUT,PATCH, transformRequest ` allows you to modify the request data before sending it to the server
axios.defaults.transformRequest = function(data) {
	data = qs.stringify(data);
	return data;
};
 
 
// request interceptor 
axios.interceptors.request.use(function(config) {
	// var jwt = window.vm.$store.getters.getJwt;
	// config.headers['jwt'] = jwt;
	return config;
}, function(error) {
	return Promise.reject(error);
});
 
// Response interceptor
axios.interceptors.response.use(function(response) {
	// debugger;
	// var jwt = response.headers['jwt'];
	// if(jwt){
	// 	window.vm.$store.commit('setJwt',{jwt:jwt});
	// }
	return response;
}, function(error) {
	return Promise.reject(error);
});
 
// //Route request interception
// //http request interceptor
// axios.interceptors.request.use(
// 	config => {
// 		//config.data = JSON.stringify(config.data);  
// 		//config.headers['Content-Type'] = 'application/json;charset=UTF-8';
// 		//config.headers['Token'] = 'abcxyz';
// 		//Judge whether there is a ticket. If so, add a ticket to each http header
// 		// if (cookie.get("token")) {
// 		//  	// The user sets the cookie to 2 hours for each operation
// 		// 	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);
// 	});
 
// //Route response interception
// //http response interceptor
// axios.interceptors.response.use(
// 	response => {
// 		if (response.data.resultCode == "404") {
// 			console.log("response.data.resultCode is 404")
// 			//Return error code - 1, clear the ticket information and jump to the login page
// 			//      cookie.del("ticket")
// 			//      window.location.href='http://login.com'
// 			return
// 		} else {
// 			return response;
// 		}
// 	},
// 	error => {
// 		return Promise.reject(error.response) / / returns the error information returned by the interface
// 	});
 
 
 
export default axios;

2. Introduce the main.js configuration (newly added)

import axios from '@/api/http'  # Global configuration of Axios by vue project      
import VueAxios from 'vue-axios'
Vue.use(VueAxios,axios)

(3).main.js

// 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'
import 'element-ui/lib/theme-chalk/index.css' // Add 2 to avoid later packaging style
import App from './App'
import router from './router'
import ElementUI from 'element-ui' // Add new 1
import axios from '@/api/http' // #Global configuration of axios by vue project      
 
import VueAxios from 'vue-axios'
 
 
Vue.use(ElementUI)   // Add new 3
Vue.use(VueAxios,axios)
Vue.config.productionTip = false
 
/* eslint-disable no-new */
new Vue({
  el: '#app',
  router,
  components: { App },
  template: '<App/>'
})

3.src/views/Login.vue

<template>
  <div id="app" class="login-wrap">
 
    <el-form :model="ruleForm" status-icon ref="ruleForm" class="demo-ruleForm login-container ">
      <h3 style="text-align: center;">User login interface</h3>
      <el-form-item label="account number" prop="uname">
        <el-input type="text" v-model="ruleForm.uname" autocomplete="off"></el-input>
      </el-form-item>
      <el-form-item label="Confirm password" prop="pwd">
        <el-input type="password" v-model="ruleForm.pwd" autocomplete="off"></el-input>
      </el-form-item>
 
      <el-form-item>
        <el-row>
          <el-col :span="24">
            <div class="grid-content bg-purple-dark"></div>
          </el-col>
          <el-button style="width: 100%;" type="primary" @click="submitForm">Submit</el-button>
        </el-row>
 
        <el-row>
          <el-col :span="12">
            <div class="grid-content bg-purple-dark"></div>
          </el-col>
          <el-link type="primary" @click="toReg">User registration</el-link>
 
          <el-col :span="12">
            <div class="grid-content bg-purple-dark"></div>
          </el-col>
          <el-link type="success">Forget password</el-link>
 
        </el-row>
 
      </el-form-item>
    </el-form>
  </div>
</template>
 
 
<script>
 
  export default {
    name: 'Login',
    data() {
      return {
        ruleForm: {}
      }
    },
    methods: {
      toReg() {
        this.$router.push({
          path: '/Reg'
        });
      },
      submitForm() {
        //$.ajax({url,scuc})
       let url = this.axios.urls.SYSTEM_USER_DOLOGIN;
        /* Request background post (address, parameter, return)*/
this.axios.post(url,this.ruleForm).then(function(resp){
  console.log(resp)
}).catch(function(error){
  console.log(error)
});
      }
    }
  }
</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>

(1) Main code:

      submitForm() {
        //$.ajax({url,scuc})
       let url = this.axios.urls.SYSTEM_USER_DOLOGIN;
        /* Request background   Post (address, parameter, return)*/
this.axios.post(url,this.ruleForm).then(function(resp){
  console.log(resp)
}).catch(function(error){
  console.log(error)
});
      }

(2) Running result: (login succeeded)

(2.2) login failure (because there is no such user in my database)

 

  3: This   Variable pollution caused by pointer

  1. Add message prompt

1,src/views/Login.vue

<script>

  export default {
    name: 'Login',
    data() {
      return {
        ruleForm: {}
      }
    },
    methods: {
      toReg() {
        this.$router.push({
          path: '/Reg'
        });
      },
      submitForm() {
        //$.ajax({url,scuc})
       let url = this.axios.urls.SYSTEM_USER_DOLOGIN;
        /* Request background post (address, parameter, return)*/

//this refers to the vue instance
this.axios.post(url,this.ruleForm).then(function(resp){
  console.log(resp);

//this refers to axios. There is no message method
   this.$message({
                message: "Congratulations on your successful login",
                type: 'success'
              });
}).catch(function(error){
  console.log(error)
});
      }
    }
  }
</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>

As follows: (indicates that the attribute cannot be read)  

   Solution: 1. Save the above this

 submitForm() {
        //$.ajax({url,scuc})
       let url = this.axios.urls.SYSTEM_USER_DOLOGIN;
        /* Request background post (address, parameter, return)*/
        let obj=this;
this.axios.post(url,this.ruleForm).then(function(resp){
  console.log(resp);
    obj.$message({
                message: "Congratulations on your success",
                type: 'success'
              });
}).catch(function(error){
  console.log(error)
});
      }

Operation results

However, if many layers are nested, it is not advisable. Therefore, there is a second solution:

2. Solving the pollution problem of this pointer with arrow function

submitForm() {
        //$.ajax({url,scuc})
       let url = this.axios.urls.SYSTEM_USER_DOLOGIN;
        /* Request background post (address, parameter, return)*/

this.axios.post(url,this.ruleForm).then((resp)=>{
  console.log(resp);
   this.$message({
                message: "Congratulations on your success. That's great",
                type: 'success'
              });
}).catch(function(error){
  console.log(error)
});
      }

 
  2. Perfect login  

  submitForm() {
        //$.ajax({url,scuc})
        let url = this.axios.urls.SYSTEM_USER_DOLOGIN;
        /* Request background    Post (address, parameter, return)*/

        this.axios.post(url, this.ruleForm).then((resp) => {
            console.log(resp);
            if (resp.data.code == 1) {
              this.$message({
                message: resp.data.msg,
                type: 'success'
              });
            } else {
              this.$message({
                message: resp.data.msg,
                type: 'warning'
              });
}
            }).catch(function(error) {
            console.log(error)
          });
        }

Running result (login successful)

Login failed

 

4: ajax   Cross domain problem

1. Comment out web.xml in eclipse   To solve the cross domain problem of CORS, the filter will report the following errors (any CORS in the error is   Cross domain issues)

 

1. Causes of cross domain  

 http://localhost:8088/#/

Protocol + IP+port + Project

Reasons for cross domain: one of the above four is different, which will occur

 2.web.xml 

<!-- solve cors Cross domain problem filter -->
	 <filter>
		<filter-name>corsFilter</filter-name>
		<filter-class>com.zking.vue.util.CorsFilter</filter-class>
	</filter>
	<filter-mapping>
		<filter-name>corsFilter</filter-name>
		<url-pattern>/*</url-pattern>
	</filter-mapping> 

5: xios   of   get/post   Differences between(   qs  )

  1. axios original writing

main.js

import Vue from 'vue'
Import 'element UI / lib / theme talk / index. CSS' / / add 2 to avoid later packaging style
import App from './App'
import router from './router'
Import elementui from 'element UI' / / add 1
//import axios from '@/api/http' // #vue project global configuration of axios      
import axios from 'axios'
import VueAxios from 'vue-axios'
 

login.vue 

 methods: {
      toReg() {
        this.$router.push({
          path: '/Reg'
        });
      },
      submitForm() {
        //$.ajax({url,scuc})
        //let url = this.axios.urls.SYSTEM_USER_DOLOGIN;

        // The original writing method is directly dead
         let url = 'http://localhost:8080/T216_SSH/vue/userAction_login.action';
        /* Request background   Post (address, parameter, return)*/

        this.axios.post(url, this.ruleForm).then((resp) => {
            console.log(resp);
            if (resp.data.code == 1) {
              this.$message({
                message: resp.data.msg,
                type: 'success'
              });
            } else {
              this.$message({
                message: resp.data.msg,
                type: 'warning'
              });
}
            }).catch(function(error) {
            console.log(error)
          });
        }
      }

What passed is the object

2.import axios from '@/api/http'   Writing method  

main.js

import Vue from 'vue'
Import 'element UI / lib / theme talk / index. CSS' / / add 2 to avoid later packaging style
import App from './App'
import router from './router'
Import elementui from 'element UI' / / add 1
import axios from '@/api/http' // #vue project global configuration of axios      
//import axios from 'axios'
import VueAxios from 'vue-axios'

login.vue

  submitForm() {
        //$.ajax({url,scuc})
      let url = this.axios.urls.SYSTEM_USER_DOLOGIN;
         //  let url = 'http://localhost:8080/T216_SSH/vue/userAction_login.action';
        /* Request background   Post (address, parameter, return)*/

        this.axios.post(url, this.ruleForm).then((resp) => {
            console.log(resp);
            if (resp.data.code == 1) {
              this.$message({
                message: resp.data.msg,
                type: 'success'
              });
            } else {
              this.$message({
                message: resp.data.msg,
                type: 'warning'
              });
}
            }).catch(function(error) {
            console.log(error)
          });
        }

String passed

2. Influence
① . axios original writing

(1) The object passed is not available in the background

(2) Workaround (convert object to string)   stringify())

login.vue

<script>

import qs from 'qs'

  export default {
  export default {
    name: 'Login',
    data() {
      return {
        ruleForm: {}
      }
    },
    methods: {
      toReg() {
        this.$router.push({
          path: '/Reg'
        });
      },
      submitForm() {
        //$.ajax({url,scuc})
      // let url = this.axios.urls.SYSTEM_USER_DOLOGIN;
         let url = 'http://localhost:8080/T216_SSH/vue/userAction_login.action';
        /* Request background   Post (address, parameter, return)*/

   this.axios.post(url, qs.stringify(this.ruleForm)).then((resp) => {
            console.log(resp);
            if (resp.data.code == 1) {
              this.$message({
                message: resp.data.msg,
                type: 'success'
              });
            } else {
              this.$message({
                message: resp.data.msg,
                type: 'warning'
              });
}
            }).catch(function(error) {
            console.log(error)
          });
        }
      }
    }
</script>

Posted by gavinr98 on Thu, 11 Nov 2021 15:16:27 -0800