目录
1、确保后台项目T216_SSH能够运行起来,标志: http://localhost:8080/T216_SSH/vue/treeNodeAction.action 能够返回数据
this.axios.post(url,this.param)
跨域产生的因素:协议、ip、端口、项目有任意一处发生改变,都会产生跨域的现象
准备步骤:
1、确保后台项目T216_SSH能够运行起来,标志: http://localhost:8080/T216_SSH/vue/treeNodeAction.action 能够返回数据
2、要将api的文件夹导入src的目录
3、下载js依赖
axios:前端向后台发送请求
qs:解决发送post请求代码冗余的问题
ElementUI:快速布局
vue-axios:将axios依赖整合进vue中
eclipse导入项目:

选择maven工程:

选择项目所在路径:

导入成功后再运行:
(要注意Tomact的配置问题!)

之后测试能不能访问到数据,如下:

返回了数据:

紧接着去黑窗口下载四个js依赖:
你们可以在项目所在的目录下去执行:

由于本人下载了WebStorm,

因此我直接在那里面输入:

下载成功后注意package.json有没有生成 element-ui:

成功后继续下载:


将以下四个依赖下载完之后,
npm install element-ui -S
npm install axios -S
npm install qs -S
npm install vue-axios -S
对应的 package.json 里面也生成了四个依赖:

前置工作已都准备完毕!

复制到App.vue中:
- <div id="app">
- <el-row>
- <el-button>默认按钮el-button>
- <el-button type="primary">主要按钮el-button>
- <el-button type="success">成功按钮el-button>
- <el-button type="info">信息按钮el-button>
- <el-button type="warning">警告按钮el-button>
- <el-button type="danger">危险按钮el-button>
- el-row>
-
- <router-view/>
- div>
-
- <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>
npm run dev 运行:
目前页面效果这样:

接下来写我们的登录界面:

复制到新建的views文件夹内的Login.vue中:
然后其中进行调整代码即样式:
Login.vue:
- <template>
- <div class="login-wrap">
- <el-row>
- <el-col :span="24">
- <div style="text-align: center" class="grid-content bg-purple-dark"><h3>用户登录h3>
- div>el-col>
- el-row>
-
- <el-form :model="ruleForm" status-icon label-width="100px" class="demo-ruleForm login-container">
- <el-form-item label="用户名" prop="uname">
- <el-input type="text" v-model="ruleForm.uname" autocomplete="off">el-input>
- el-form-item>
- <el-form-item label="密码" 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 style="text-align: center" class="grid-content bg-purple-dark">
- <el-button style="width: 100%" type="primary" @click="submitForm">提交el-button>
- div>
- el-col>
- el-row>
- el-form-item>
- <el-form-item>
- <el-row>
- <el-col :span="12">
- <div style="text-align: center" class="grid-content bg-purple-dark">
- <el-link type="success">用户注册el-link>
- div>
- el-col>
- <el-col :span="12">
- <div style="text-align: center" class="grid-content bg-purple-dark">
- <el-link type="warning">忘记密码el-link>
- div>
- el-col>
- el-row>
- el-form-item>
-
- el-form>
- div>
- template>
-
- <script>
- export default {
- name: 'Login',
- data () {
- return {
- ruleForm: {}
- }
- },
- methods:{
- submitForm(){
-
- },
- resetForm(){
-
- }
- }
- }
- 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>
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: [
- {
- path: '/',
- name: 'Login',
- component: Login
- },
- {
- path: '/Login',
- name: 'Login',
- component: Login
- },
- ]
- })
App.vue:
- <template>
- <div id="app">
-
-
- <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>
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 ElementUI from 'element-ui' // 新添加 1
- import 'element-ui/lib/theme-chalk/index.css' // 新添加 2 ,避免后期打包样式
- import App from './App'
- import router from './router'
-
- Vue.use(ElementUI)//新添加 3
- Vue.config.productionTip = false
-
- /* eslint-disable no-new */
- new Vue({
- el: '#app',
- router,
- components: { App },
- template: '
' - })
页面运行效果:

用户登录界面排版完成~
this.$router.push(.....);
axios相当于jQuery中的ajax
作用:试用获取后台数据,做局部刷新
语法:
this.axios.post(url,this.param)
.then(function(resp){ })
.catch(function(error){ })
首先再添加一个用户注册,实现登录时假若没有注册就可以跳转注册页面:
Reg.vue:
- <template>
- <div class="login-wrap">
- <el-row>
- <el-col :span="24">
- <div style="text-align: center" class="grid-content bg-purple-dark"><h3>用户注册h3>
- div>el-col>
- el-row>
-
- <el-form :model="ruleForm" status-icon label-width="100px" class="demo-ruleForm login-container">
- <el-form-item label="用户名" prop="uname">
- <el-input type="text" v-model="ruleForm.uname" autocomplete="off">el-input>
- el-form-item>
- <el-form-item label="密码" 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 style="text-align: center" class="grid-content bg-purple-dark">
- <el-button style="width: 100%" type="primary" @click="submitForm">提交el-button>
- div>
- el-col>
- el-row>
- el-form-item>
- <el-form-item>
- <el-row>
- <el-col :span="12">
- <div style="text-align: center" class="grid-content bg-purple-dark">
- <el-link type="success" @click="toLogin">用户登录el-link>
- div>
- el-col>
- <el-col :span="12">
- <div style="text-align: center" class="grid-content bg-purple-dark">
- <el-link type="warning">忘记密码el-link>
- div>
- el-col>
- el-row>
- el-form-item>
-
- el-form>
- div>
- template>
-
- <script>
- export default {
- name: 'Reg',
- data () {
- return {
- ruleForm: {}
- }
- },
- methods:{
- submitForm(){
-
- },
- resetForm(){
-
- },
- 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>
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
- }
- ]
- })
效果:

进行数据交互登录功能的实现:
- <template>
- <div class="login-wrap">
- <el-row>
- <el-col :span="24">
- <div style="text-align: center" class="grid-content bg-purple-dark"><h3>用户登录h3>
- div>el-col>
- el-row>
-
- <el-form :model="ruleForm" status-icon label-width="100px" class="demo-ruleForm login-container">
- <el-form-item label="用户名" prop="uname">
- <el-input type="text" v-model="ruleForm.uname" autocomplete="off">el-input>
- el-form-item>
- <el-form-item label="密码" 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 style="text-align: center" class="grid-content bg-purple-dark">
- <el-button style="width: 100%" type="primary" @click="submitForm">提交el-button>
- div>
- el-col>
- el-row>
- el-form-item>
- <el-form-item>
- <el-row>
- <el-col :span="12">
- <div style="text-align: center" class="grid-content bg-purple-dark">
- <el-link type="success" @click="toReg">用户注册el-link>
- div>
- el-col>
- <el-col :span="12">
- <div style="text-align: center" class="grid-content bg-purple-dark">
- <el-link type="warning">忘记密码el-link>
- div>
- el-col>
- el-row>
- el-form-item>
-
- el-form>
- div>
- template>
-
- <script>
- export default {
- name: 'Login',
- data () {
- return {
- ruleForm: {}
- }
- },
- methods:{
- submitForm(){
- //this.axios找到的是 /api/http.js文件
- //xios.urls——>this.axios/urls找到了 /api/action.js
- //action.js是一个JSON对象,那么就可以取到请求的值
- let url = this.axios.urls.SYSTEM_USER_DOLOGIN;
- // alert(url);
- // {uname:'zs',pwd:'123'}
- this.axios.post(url,this.ruleForm)
- .then(function (resp){//代表成功
- console.log(resp);
- }).catch(function (){//代表失败
-
- });
- },
- resetForm(){
-
- },
- 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>
直接点击提交:

输错密码:

输入正确:

到这里呢,那么我们的Vue的数据交互登录功能就已实现啦!
当我们登录时 密码错误/密码正确/账户密码为空 时,要出现相应的消息提示框,所以我们可去element官网上进行查找我们需要的提示框源代码:

我们就以成功和错误的消息提示来做案例:

进行代码调整:
Login.vue:
- export default {
- name: 'Login',
- data () {
- return {
- ruleForm: {}
- }
- },
- methods:{
- submitForm(){
- //this.axios找到的是 /api/http.js文件
- //xios.urls——>this.axios/urls找到了 /api/action.js
- //action.js是一个JSON对象,那么就可以取到请求的值
- let url = this.axios.urls.SYSTEM_USER_DOLOGIN;
- // {uname:'zs',pwd:'123'}
-
- //this指的是vue实例
- this.axios.post(url,this.ruleForm)
- .then(resp => {//代表成功 箭头函数 jdk8的语法
- console.log(resp);
- if(resp.data.code == 1){
- //this指的是http.js
- this.$message({
- message: resp.data.msg,
- type: 'success'
- });
- }else if(resp.data.code == 0) {
- //this指的是http.js
- this.$message.error(resp.data.msg);
- }
- }).catch(function (){//代表失败
-
- });
- },
- resetForm(){
-
- },
- toReg(){
- this.$router.push({path:'/Reg'})
- }
- }
- }
未填任何数据,直接提交:
填写错误用户或者密码:
填写正确用户或者密码:

在T216_SSH项目中的web.xml有个解决cors跨域问题的过滤器:

再去运行项目,直接点提交:
跨域的现象:

请求地址由协议+ip+端口+项目+....等构成
解决方案:
- package com.javaxl.util;
-
- import java.io.IOException;
-
- import javax.servlet.Filter;
- import javax.servlet.FilterChain;
- import javax.servlet.FilterConfig;
- import javax.servlet.ServletException;
- import javax.servlet.ServletRequest;
- import javax.servlet.ServletResponse;
- import javax.servlet.http.HttpServletResponse;
-
- /**
- * 配置tomcat允许跨域访问
- *
- * @author Administrator
- *
- */
- public class CorsFilter implements Filter {
-
- @Override
- public void init(FilterConfig filterConfig) throws ServletException {
- }
-
- @Override
- public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain)
- throws IOException, ServletException {
- HttpServletResponse httpResponse = (HttpServletResponse) servletResponse;
-
- // Access-Control-Allow-Origin就是我们需要设置的域名
- // Access-Control-Allow-Headers跨域允许包含的头。
- // Access-Control-Allow-Methods是允许的请求方式
- httpResponse.addHeader("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);
- }
-
- @Override
- public void destroy() {
-
- }
- }
- // 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' // 新添加 2
- import App from './App'
- import router from './router'
- import ElementUI from 'element-ui' // 新添加 1
- // import axios from '@/api/http'
- import axios from 'axios'
- import VueAxios from 'vue-axios'
-
- Vue.use(ElementUI)
- Vue.use(VueAxios,axios)
- Vue.config.productionTip = false
-
- /* eslint-disable no-new */
- new Vue({
- el: '#app',
- router,
- components: { App },
- template: '
' - })
- let url = 'http://localhost:8080/T216_SSH/vue/userAction_login.action';
-
- this.axios.post(url, this.ruleForm).then(function(response) {
- console.log(response);
- }).catch(function(error) {
- console.log(error);
- });
import qs from 'qs'
- let url = 'http://localhost:8080/T216_SSH/vue/userAction_login.action';
-
- this.axios.post(url, qs.stringify(this.ruleForm)).then(function(response) {
- console.log(response);
- }).catch(function(error) {
- console.log(error);
- });
1、将原生的json对象转换成字符串,通过拦截器转
2、将本项目中的所有接口地址,进行统一管理
get请求:
- let url = this.axios.urls.SYSTEM_USER_DOLOGIN;
-
- this.axios.get(url, { //注意数据是保存到json对象的params属性
- params: this.ruleForm
- }).then(function(response) {
- console.log(response);
- }).catch(function(error) {
- console.log(error);
- });
post请求:
- let url = this.axios.urls.SYSTEM_USER_DOLOGIN;
-
- this.axios.post(url, this.ruleForm).then(function(response) {
- console.log(response);
- }).catch(function(error) {
- console.log(error);
- });
今日分享就结束啦!如果觉得对您有帮助的话可以点点赞好嘛~