SPA項目開發之登陸

一、SPA項目完成登陸註冊

1.一、安裝開發模塊

      npm install element-ui -S    --安裝餓了麼所提供的vue組件,減小程序員本身開發組件的過程css

     npm install axios -S   --至關於jQuery中封裝的ajax方法vue

     npm install qs -S       --解決post異步提交的傳參問題,未使用qs以前傳遞到後臺傳的json對象,經過qs.stringify方法轉換後傳遞的是鍵值對的字符串。java

     npm install vue-axios -S   --起到橋接的做用,webpack

安裝方法:打開到項目所在的文件夾,shift+鼠標右鍵,選擇在此處打開cmd命令窗口,而後依次執行下載代碼,若有出現error,請從新下載。ios

                  下載完成以後能夠在項目中的package.json文件中查看,程序員

                

 

1.二、引入main.js配置

 1 // The Vue build version to load with the `import` command
 2 // (runtime-only or standalone) has been set in webpack.base.conf with an alias.
 3 import Vue from 'vue'
 4 import 'element-ui/lib/theme-chalk/index.css'
 5 import App from './App'
 6 import router from './router'
 7 import ElementUI from 'element-ui'
 8 import axios from '@/api/http'
 9 // import axios from 'axios'
10 import VueAxios from 'vue-axios'
11 
12 
13 
14 Vue.use(VueAxios,axios)
15 Vue.use(ElementUI)
16 Vue.config.productionTip = false
17 
18 /* eslint-disable no-new */
19 new Vue({
20   el: '#app',
21   router,
22   components: { App },
23   template: '<App/>'
24 })

1.三、index.js路由配置

 1 import Vue from 'vue'
 2 import Router from 'vue-router'
 3 import HelloWorld from '@/components/HelloWorld'
 4 import login from '@/views/login'
 5 import Reg from '@/views/Reg'
 6 
 7 Vue.use(Router)
 8 
 9 export default new Router({
10   routes: [{
11       path: '/',
12       name: 'login',
13       component: login
14     },
15     {
16       path: '/login',
17       name: 'login',
18       component: login
19     },
20     {
21       path: '/Reg',
22       name: 'Reg',
23       component: Reg
24     }
25   ]
26 })

1.四、導入對後臺請求地址的封裝--action.js,以及vue項目對axios的全局配置http.js

    action.js

 

 1 /**
 2  * 對後臺請求的地址的封裝,URL格式以下:
 3  * 模塊名_實體名_操做
 4  */
 5 export default {
 6     'SERVER': 'http://localhost:8080/T216_SSH', //服務器
 7     'SYSTEM_USER_DOLOGIN': '/vue/userAction_login.action', //用戶登錄
 8     'SYSTEM_USER_DOREG': '/vue/userAction_reg.action', //用戶註冊
 9     'SYSTEM_MENU_TREE': '/vue/treeNodeAction.action', //左側樹形菜單加載
10     'SYSTEM_ARTICLE_LIST': '/vue/articleAction_list.action', //文章列表
11     'SYSTEM_ARTICLE_ADD': '/vue/articleAction_add.action', //文章新增
12     'SYSTEM_ARTICLE_EDIT': '/vue/articleAction_edit.action', //文章修改
13     'SYSTEM_ARTICLE_DEL': '/vue/articleAction_del.action', //文章刪除
14     'SYSTEM_USER_GETASYNCDATA': '/vue/userAction_getAsyncData.action', //vuex中的異步加載數據
15     'getFullPath': k => { //得到請求的完整地址,用於mockjs測試時使用
16         return this.SERVER + this[k];
17     }
18 }

 

   http.js

 1 /**
 2  * vue項目對axios的全局配置
 3  */
 4 import axios from 'axios'
 5 import qs from 'qs'
 6 
 7 //引入action模塊,並添加至axios的類屬性urls上
 8 import action from '@/api/action'
 9 axios.urls = action
10 
11 // axios默認配置
12 axios.defaults.timeout = 10000; // 超時時間
13 // axios.defaults.baseURL = 'http://localhost:8080/j2ee15'; // 默認地址
14 axios.defaults.baseURL = action.SERVER;
15 
16 //整理數據
17 // 只適用於 POST,PUT,PATCH,transformRequest` 容許在向服務器發送前,修改請求數據
18 axios.defaults.transformRequest = function(data) {
19     data = qs.stringify(data);
20     return data;
21 };
22 
23 
24 // 請求攔截器
25 axios.interceptors.request.use(function(config) {
26     // var jwt = window.vm.$store.getters.getJwt;
27     // config.headers['jwt'] = jwt;
28     return config;
29 }, function(error) {
30     return Promise.reject(error);
31 });
32 
33 // 響應攔截器
34 axios.interceptors.response.use(function(response) {
35     // debugger;
36     // var jwt = response.headers['jwt'];
37     // if(jwt){
38     //     window.vm.$store.commit('setJwt',{jwt:jwt});
39     // }
40     return response;
41 }, function(error) {
42     return Promise.reject(error);
43 });
44 
45 // // 路由請求攔截
46 // // http request 攔截器
47 // axios.interceptors.request.use(
48 //     config => {
49 //         //config.data = JSON.stringify(config.data);  
50 //         //config.headers['Content-Type'] = 'application/json;charset=UTF-8';
51 //         //config.headers['Token'] = 'abcxyz';
52 //         //判斷是否存在ticket,若是存在的話,則每一個http header都加上ticket
53 //         // if (cookie.get("token")) {
54 //         //     //用戶每次操做,都將cookie設置成2小時
55 //         //     cookie.set("token", cookie.get("token"), 1 / 12)
56 //         //     cookie.set("name", cookie.get("name"), 1 / 12)
57 //         //     config.headers.token = cookie.get("token");
58 //         //     config.headers.name = cookie.get("name");
59 //         // }
60 //         return config;
61 //     },
62 //     error => {
63 //         return Promise.reject(error.response);
64 //     });
65 
66 // // 路由響應攔截
67 // // http response 攔截器
68 // axios.interceptors.response.use(
69 //     response => {
70 //         if (response.data.resultCode == "404") {
71 //             console.log("response.data.resultCode是404")
72 //             // 返回 錯誤代碼-1 清除ticket信息並跳轉到登陸頁面
73 //             //      cookie.del("ticket")
74 //             //      window.location.href='http://login.com'
75 //             return
76 //         } else {
77 //             return response;
78 //         }
79 //     },
80 //     error => {
81 //         return Promise.reject(error.response) // 返回接口返回的錯誤信息
82 //     });
83 
84 
85 
86 export default axios;

 

1.五、登陸頁面login.vue

  1 <template>
  2   <div class="login-wrap">
  3     <el-form :model="ruleForm" label-width="100px" class="demo-ruleForm login-container">
  4         <h3 style="text-align: center;">用戶登陸</h3>
  5       <el-form-item label="用戶名" prop="uname">
  6         <el-input type="uname" v-model="ruleForm.uname" autocomplete="off"></el-input>
  7       </el-form-item>
  8       <el-form-item label="密碼" prop="pwd">
  9         <el-input type="pwd" v-model="ruleForm.pwd" autocomplete="off"></el-input>
 10       </el-form-item>
 11       <el-form-item>
 12         <el-row>
 13           <el-col :span="24">
 14             <div class="grid-content bg-purple-dark">
 15               <el-button style="width: 100%;" type="primary" round @click="doSub">提交</el-button>
 16             </div>
 17           </el-col>
 18         </el-row>
 19         <el-row>
 20           <el-col :span="12">
 21             <div class="grid-content bg-purple-dark">
 22               <el-link type="success" round @click="toReg">用戶註冊</el-link>
 23             </div>
 24           </el-col>
 25           <el-col :span="12">
 26             <div class="grid-content bg-purple-dark">
 27               <el-link type="success">忘記密碼?</el-link>
 28             </div>
 29           </el-col>
 30         </el-row>
 31       </el-form-item>
 32     </el-form>
 33   </div>
 34 </template>
 35 
 36 <script>
 37   // import qs from 'qs'
 38   // import axios from 'axios'
 39   export default {
 40     data() {
 41       return {
 42         ruleForm: {
 43           uname: '',
 44           pwd: ''
 45         }
 46       };
 47     },
 48     methods:{
 49         //登陸提交
 50       doSub(){
 51          let url = this.axios.urls.SYSTEM_USER_DOLOGIN;
 52          // let url = 'http://localhost:8080/T216_SSH/vue/userAction_login.action';
 53          this.axios.post(url, this.ruleForm).then((response)=> {
 54                              console.log(response);
 55                   if(response.data.code == 1){
 56                     this.$message({
 57                               showClose: true,
 58                               message: response.data.msg,
 59                               type: 'success'
 60                             });
 61                             this.$router.push({
 62                               path:'/AppMain'
 63                             })
 64                   }else{
 65                     this.$message({
 66                               showClose: true,
 67                               message: response.data.msg,
 68                               type: 'error'
 69                             });
 70                   }
 71                          }).catch(function(error) {
 72                              console.log(error);
 73                          });
 74       },
 75       //註冊按鈕的跳轉方法
 76       toReg(){
 77         this.$router.push({
 78           path:'/Reg'
 79         });
 80       }
 81 
 82     }
 83   }
 84 </script>
 85 
 86 <style scoped>
 87   .login-wrap {
 88     box-sizing: border-box;
 89     width: 100%;
 90     height: 100%;
 91     padding-top: 10%;
 92     background-image: url();
 93     /* background-color: #112346; */
 94     background-repeat: no-repeat;
 95     background-position: center right;
 96     background-size: 100%;
 97   }
 98 
 99   .login-container {
100     border-radius: 10px;
101     margin: 0px auto;
102     width: 350px;
103     padding: 30px 35px 15px 35px;
104     background: #fff;
105     border: 1px solid #eaeaea;
106     text-align: left;
107     box-shadow: 0 0 20px 2px rgba(0, 0, 0, 0.1);
108   }
109 
110   .title {
111     margin: 0px auto 40px auto;
112     text-align: center;
113     color: #505458;
114   }
115 </style>

 

 

1.六、註冊頁面Reg.vue

 1 <template>
 2   <div class="login-wrap">
 3     <el-form :model="ruleForm" label-width="100px" class="demo-ruleForm login-container">
 4         <h3 style="text-align: center;">用戶註冊</h3>
 5       <el-form-item label="用戶名" prop="uname">
 6         <el-input type="uname" v-model="ruleForm.uname" autocomplete="off"></el-input>
 7       </el-form-item>
 8       <el-form-item label="密碼" prop="pwd">
 9         <el-input type="pwd" v-model="ruleForm.pwd" autocomplete="off"></el-input>
10       </el-form-item>
11       <el-form-item>
12         <el-row>
13           <el-col :span="24">
14             <div class="grid-content bg-purple-dark">
15               <el-button style="width: 100%;" type="primary" round @click="doSub">提交</el-button>
16             </div>
17           </el-col>
18         </el-row>
19         <el-row>
20           <el-col :span="12">
21             <div class="grid-content bg-purple-dark">
22               <el-link type="success" round @click="toLogin">去登陸 >-></el-link>
23             </div>
24           </el-col>
25           <el-col :span="12">
26             <div class="grid-content bg-purple-dark">
27               <el-link type="success">更多....</el-link>
28             </div>
29           </el-col>
30         </el-row>
31       </el-form-item>
32     </el-form>
33   </div>
34 </template>
35 
36 <script>
37   export default {
38     data() {
39       return {
40         ruleForm: {
41           uname: '',
42           pwd: ''
43         }
44       };
45     },
46     methods:{
47       doSub(){
48         
49       },
50       toLogin(){
51           this.$router.push({
52             path:'/login'
53           });
54       }
55     }
56   }
57 </script>
58 
59 <style scoped>
60   .login-wrap {
61     box-sizing: border-box;
62     width: 100%;
63     height: 100%;
64     padding-top: 10%;
65     background-image: url();
66     /* background-color: #112346; */
67     background-repeat: no-repeat;
68     background-position: center right;
69     background-size: 100%;
70   }
71 
72   .login-container {
73     border-radius: 10px;
74     margin: 0px auto;
75     width: 350px;
76     padding: 30px 35px 15px 35px;
77     background: #fff;
78     border: 1px solid #eaeaea;
79     text-align: left;
80     box-shadow: 0 0 20px 2px rgba(0, 0, 0, 0.1);
81   }
82 
83   .title {
84     margin: 0px auto 40px auto;
85     text-align: center;
86     color: #505458;
87   }
88 </style>

 

1.七、運行效果

  用戶爲空web

 

 

  用戶錯誤ajax

 

  登陸成功 vue-router

 

 

二、axios中 get方法和post方法的不一樣

  2.一、get方法

1     let url = this.axios.urls.SYSTEM_USER_DOLOGIN;
2 
3                 this.axios.get(url, { //注意數據是保存到json對象的params屬性
4                     params: this.ruleForm
5                 }).then(function(response) {
6                     console.log(response);
7                 }).catch(function(error) {
8                     console.log(error);
9                 });

  2.二、post方法

1 let url = this.axios.urls.SYSTEM_USER_DOLOGIN;
2                 
3                 this.axios.post(url, this.ruleForm).then(function(response) {
4                     console.log(response);
5                 }).catch(function(error) {
6                     console.log(error);
7                 });

 

post向後臺傳參的方式:

      

post的這種傳參方式後臺是 接受不到的,因此會致使用戶爲空,vuex

get向後臺傳參的方式:

 

 而get方法的傳參方式後臺是能夠接受到的,因此get在沒有其餘的代碼輔助的狀況下是能夠傳值到後臺並接收的;

 

三、ajax跨域問題

錯誤:

 

解決方案

步驟一:在後臺添加處理跨域問題的一個助手類,

 如  CorsFilter

 1 package com.yuan.vue.util;
 2 
 3 import java.io.IOException;
 4 
 5 import javax.servlet.Filter;
 6 import javax.servlet.FilterChain;
 7 import javax.servlet.FilterConfig;
 8 import javax.servlet.ServletException;
 9 import javax.servlet.ServletRequest;
10 import javax.servlet.ServletResponse;
11 import javax.servlet.http.HttpServletRequest;
12 import javax.servlet.http.HttpServletResponse;
13 
14 /**
15  * 配置tomcat容許跨域訪問
16  * 
17  * @author Administrator
18  *
19  */
20 public class CorsFilter implements Filter {
21 
22     @Override
23     public void init(FilterConfig filterConfig) throws ServletException {
24     }
25 
26     // @Override
27     // public void doFilter(ServletRequest servletRequest, ServletResponse
28     // servletResponse, FilterChain filterChain)
29     // throws IOException, ServletException {
30     // HttpServletResponse httpResponse = (HttpServletResponse) servletResponse;
31     //
32     // // Access-Control-Allow-Origin就是咱們須要設置的域名
33     // // Access-Control-Allow-Headers跨域容許包含的頭。
34     // // Access-Control-Allow-Methods是容許的請求方式
35     // httpResponse.addHeader("Access-Control-Allow-Origin", "*");// *,任何域名
36     // httpResponse.setHeader("Access-Control-Allow-Methods", "POST, GET, PUT,
37     // DELETE");
38     // // httpResponse.setHeader("Access-Control-Allow-Headers", "Origin,
39     // // X-Requested-With, Content-Type, Accept");
40     //
41     // // 容許請求頭Token
42     // httpResponse.setHeader("Access-Control-Allow-Headers",
43     // "Origin,X-Requested-With, Content-Type, Accept, Token");
44     // HttpServletRequest req = (HttpServletRequest) servletRequest;
45     // System.out.println("Token=" + req.getHeader("Token"));
46     // if("OPTIONS".equals(req.getMethod())) {
47     // return;
48     // }
49     //
50     //
51     // filterChain.doFilter(servletRequest, servletResponse);
52     // }
53 
54     @Override
55     public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain)
56             throws IOException, ServletException {
57         HttpServletResponse resp = (HttpServletResponse) servletResponse;
58         HttpServletRequest req = (HttpServletRequest) servletRequest;
59 
60         // Access-Control-Allow-Origin就是咱們須要設置的域名
61         // Access-Control-Allow-Headers跨域容許包含的頭。
62         // Access-Control-Allow-Methods是容許的請求方式
63         resp.setHeader("Access-Control-Allow-Origin", "*");// *,任何域名
64         resp.setHeader("Access-Control-Allow-Methods", "POST, GET, PUT, DELETE");
65         // resp.setHeader("Access-Control-Allow-Headers", "Origin,X-Requested-With,
66         // Content-Type, Accept");
67         // 容許客戶端,發一個新的請求頭jwt
68         resp.setHeader("Access-Control-Allow-Headers", "Origin,X-Requested-With, Content-Type, Accept, jwt");
69 
70         // 容許客戶端,處理一個新的響應頭jwt
71         resp.setHeader("Access-Control-Expose-Headers", "jwt");
72         // String sss = resp.getHeader("Access-Control-Expose-Headers");
73         // System.out.println("sss=" + sss);
74 
75         // 容許請求頭Token
76         // httpResponse.setHeader("Access-Control-Allow-Headers","Origin,X-Requested-With,
77         // Content-Type, Accept, Token");
78         // System.out.println("Token=" + req.getHeader("Token"));
79 
80         if ("OPTIONS".equals(req.getMethod())) {// axios的ajax會發兩次請求,第一次提交方式爲:option,直接返回便可
81             return;
82         }
83         filterChain.doFilter(servletRequest, servletResponse);
84     }
85 
86     @Override
87     public void destroy() {
88 
89     }
90 }

 步驟二:在web.xml中配置解決cors跨域問題過濾器

1 <!-- 解決cors跨域問題過濾器 -->
2     <filter>
3         <filter-name>corsFilter</filter-name>
4         <filter-class>com.yuan.vue.util.CorsFilter</filter-class>
5     </filter>
6     <filter-mapping>
7         <filter-name>corsFilter</filter-name>
8         <url-pattern>/*</url-pattern>
9     </filter-mapping>

 

在後臺加入代碼,問題解決!

 

四、This指針變量污染

 

 1 doSub(){
 2          let url = this.axios.urls.SYSTEM_USER_DOLOGIN;
 3          // let url = 'http://localhost:8080/T216_SSH/vue/userAction_login.action';
 4          this.axios.post(url, this.ruleForm).then((response)=> {  //(function(response){})   更改成箭頭函數的形式   ((response)=>{})
 5                              console.log(response);
 6                   if(response.data.code == 1){
 7                     this.$message({
 8                               showClose: true,
 9                               message: response.data.msg,
10                               type: 'success'
11                             });
12                             this.$router.push({
13                               path:'/AppMain'
14                             })
15                   }else{
16                     this.$message({
17                               showClose: true,
18                               message: response.data.msg,
19                               type: 'error'
20                             });
21                   }
22                          }).catch(function(error) {
23                              console.log(error);
24                          });
25       },

 

謝謝觀看!!!

相關文章
相關標籤/搜索