Use vue-cli to create login page & background interaction

Table of contents

1. Build the project

1.1 Create a project with vue-cli

1.2 Install element-ui via npm

1.3 Import components

2 Create the login page

2.1 Create the login component

2.2 Import css (css.txt)

2.3 Configure routing

2.4 Adjust the submit button to 100% width in the Login component

2.5 Running effect

3. Background interaction

3.1 Introducing axios

3.2 axios/qs/vue-axios installation and use

3.2.1 Install axios

3.2.2 Send get request:

3.2.3 Send post request:

3.2.4 Simplify the use of axios


1. Build the project

To build a project in engineering mode, please prepare the background web service program required for the test in advance.

1.1 Create a project with vue-cli

On the command line, go to the directory where your vue project is stored, and run the command, provided that vue-cli is installed first.

vue init webpack vuepro

1.2 Install element-ui via npm

npm install element-ui -S

1.3 Import components

Open main.js in the src directory , this file is the entry file of the project, so import it here, other components can be used, no need to import.

import Vue from 'vue'

//新添
import ElementUI from 'element-ui' 

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

//新增
Vue.use(ElementUI) 
。。。

2 Create the login page

2.1 Create the login component

1) Create a new views directory, right-click on the directory, select New vue (simple module) to create a Login

<template>
</template>

<script>
</script>

<style>
</style>

2) In the element-ui component, find a component similar to the login page in the form component, copy the code to the newly created Login component, and modify it to the login page you need. The page contains: account, password, submit button

<template>
    <div>
        <el-form >
            <el-form-item label="账户" >
              <el-input type="password" v-model="userName" autocomplete="off"></el-input>
            </el-form-item>
            <el-form-item label="密码" >
              <el-input type="password" v-model="passWord" autocomplete="off"></el-input>
            </el-form-item>
            <el-form-item>
              <el-button type="primary" @click="submitForm('ruleForm')">提交</el-button>
            </el-form-item>
         </el-form>
    </div>
</template>

<script>
  export default {
    name: 'Login',
    data: function() {
      return {
         userName: null,
         passWord: null,
      }
    },
    methods: {
      submitForm: function() {
          console.log("fdfdd");
      }
    }
  }
</script>

<style>
</style>

2.2 Import css (css.txt)

Import according to the instructions in css.txt to control styles and add styles

 

css style:

<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;
}
.remember {
  margin: 0px 0px 35px 0px;
}
.code-box {
  text-align: right;
}
.codeimg {
  height: 40px;
}
.title {
  text-align: center;

}
</style>
 

 

Base64 encoding:
Based on 64 printable characters to represent binary data, it is used to transmit 8Bit byte codes, which can be used to transmit long identification information in the HTTP environment. Encoding with Base64 is unreadable and needs to be decoded before it can be read.

2.3 Configure routing

router/index.js

import Vue from 'vue'
import Router from 'vue-router'
import HelloWorld from '@/components/HelloWorld'

//首先导入组件
import Login from '@/views/Login'

Vue.use(Router)

export default new Router({
  routes: [
    {
      //配置路由,根路径访问Login组件
      path: '/',
      name: 'Login',
      component: Login
    }
  ]
})

2.4 Adjust the submit button to 100% width in the Login component

<el-button type="primary" @click="submitForm('ruleForm')" style="width:100%">提交</el-button>

2.5 Running effect

In the project directory, run the following command to start the service:

npm run dev

Interface effect:

3. Background interaction

3.1 Introducing axios

Axios is a lightweight version of ajax advocated by vue2. It is a promise-based HTTP library. It creates XMLHttpRequests from the browser and works great with Vue.
Vue.js has the famous family bucket series: vue-router, vuex, vue-resource, plus the build tool vue-cli, which is the core component of a complete vue project. Among them, vue-resource is a plug-in of Vue.js. It can initiate requests and process responses through XMLHttpRequest or JSONP, but after vue is updated to 2.0, the author announced that vue-resource will no longer be updated, but the recommended axios

3.2 axios/qs/vue-axios installation and use

Note:
qs.js is a js library for url parameter conversion. There are two usages:

var obj = qs.parse('a=b&c=d');  //将URL解析成对象的形式:{a:'b',c:'d'}
var str = qs.stringify(obj);    //将对象 序列化成URL的形式,以&进行拼接:a=b&c=d'

vue-axios is a plugin that extends on the basis of axios. It extends properties such as $http on the Vue.prototype prototype, which makes it easier to use axios

3.2.1 Install axios

npm install axios -S

You can see the new library installed under dependencies in package.json

2) Import axios in the Login component

  import axios from 'axios'
  export default {
  ......

3.2.2 Send get request:

Add the code that sends the get request to the listener function of the submit button:

//请求url,需要保证服务可用
let url = 'http://localhost:8080/webserver/userMsg/userAction!login.action';
//注意数据是保存到json对象的params属性
axios.get(url, {
  params: {
    userNo: this.userNo,
    userPwd: this.userPwd
  }
}).then(function(response) {
  console.log(response);
}).catch(function(error) {
  console.log(error);
});

Please pay attention to the error message on the following figure, the request has a cross-domain error problem:

Cross-domain request problem:
Because we use the method of separating the front-end and back-end for development, the front-end and back-end are on different servers. Based on security considerations, the browser has a same-origin policy, so there is a cross-domain problem.
Same-origin policy is a security feature of browsers. Client-side scripts from different origins cannot read or write resources from each other without explicit authorization. The Same Origin Policy is the cornerstone of browser security.

4)
Handling of cross-domain problems To handle cross-domain problems in the filter, the key code:

// Access-Control-Allow-Origin就是我们需要设置的域名
// Access-Control-Allow-Headers跨域允许包含的头。
// Access-Control-Allow-Methods是允许的请求方式
httpResponse.setHeader("Access-Control-Allow-Origin", "*");// *,任何域名
httpResponse.setHeader("Access-Control-Allow-Headers", "Origin, X-Requested-With, Content-Type, Accept");
httpResponse.setHeader("Access-Control-Allow-Methods", "POST, GET, PUT, DELETE");
filterChain.doFilter(servletRequest, servletResponse);

CorsFilter is provided in the courseware materials and configured in web.xml to intercept all requests, which can solve cross-domain problems. Note: Please configure before struts central controller

3.2.3 Send post request:

//注意数据是直接保存到json对象
axios.post(url, {
    userNo: 'admin',
    userPwd: '123'
}).then(function(response) {
    console.log(response);
}).catch(function(error) {
    console.log(error);
});

The input test account and password are correct, and the response obtained by using get to send the request is "password is correct", but the response of the request sent by post method is "password is incorrect"!

Reason analysis :

By observing the console, it can be found that when the post sends a request, the request parameters are sent in json format through the request payload, and the struts does not handle the parameters passed in this way (at least the struts version we use), so pass it to The server parameters were not parsed efficiently.

Problem handling:
The first way: Implement the request payload parameter parsing by coding on the server side. Add a method to BaseAction that gets json data from the request payload and converts it to the specified class.

public Object getRequestBody(Class clazz) {   

        BufferedReader br;
        HttpServletRequest request = ServletActionContext.getRequest();

        try {
            br = request.getReader();
            String str, aStr = "";
            while((str = br.readLine()) != null){
                aStr += str;
            }

            System.out.println(aStr);
            Object obj = JSONObject.parseObject(aStr, clazz);

            return obj;
        } catch (IOException e) {
           throw new RuntimeException("获取请求参数异常: " + e);
        }
    }

Call this method when getting parameters to get

User user = (User)this.getRequestBody(User.class);

The second way: use the qs.js library to convert {a:'b',c:'d'} into 'a=b&c=d'.
1) Install qs and vue-axios

npm install qs -S

npm install vue-axios -S

After the installation is successful, you will see the new library installed in "dependencies" in package.json.


Use qs to convert the json object when submitting the request

//注意数据是直接保存到json对象
let params = {
  userNo: 'admin',
  userPwd: '123'
};

//参数格式转换
let paramStr = qs.stringify(params);
console.log(paramStr);

//提交时使用转换之后的参数
axios.post(url, paramStr).then(function(response) {
  console.log(response);
}).catch(function(error) {
  console.log(error);
});

Observe the output in the console, the json format has been converted to & concatenated format. See if the returned result is the expected value.

3.2.4 Simplify the use of axios

To simplify the use of axios, you can also use axios global configuration and interceptors

1) Install vue-axios

npm install vue-axios -S

2) Test the api directory provided with the courseware to the src root path

 

Now you can delete the import axios and qs statements in the Login component. For the configuration of action.js and http.js, see the comments in the code.

3) Modify the configuration in action to your own background service configuration

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

4) Configure main.js

import Vue from 'vue'

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

5) There is no need to manually process the conversion when submitting, and the global configuration is converted.

//修改url的获取方式,url已经配置在了action.js中,这里只要指定action路径
//服务地址和服务上下文已经在http.js中设置了axios.defaults.baseURL,
//axios会根据配置自动获取。
let url = this.axios.urls.SYSTEM_USER_DOLOGIN;
this.axios.post(url, params).then(resp => {
  console.log(resp);
}).catch(resp => {});

6) A post request occurs, test

Guess you like

Origin blog.csdn.net/qq_64001795/article/details/127102912