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 // 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 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 /** 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 }
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 <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 <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>
用戶爲空web
用戶錯誤ajax
登陸成功 vue-router
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 });
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的這種傳參方式後臺是 接受不到的,因此會致使用戶爲空,vuex
而get方法的傳參方式後臺是能夠接受到的,因此get在沒有其餘的代碼輔助的狀況下是能夠傳值到後臺並接收的;
錯誤:
解決方案
步驟一:在後臺添加處理跨域問題的一個助手類,
如 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>
在後臺加入代碼,問題解決!
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 },