目录

1.vue项目登录注册

  1.1 :使用vue-cli搭建vue项目

  1.2:使用npm 下载element-ui

  1.3编写登录注册页面

一:在src目录下创建views目录

二:在main.js中引入element-ui模块

三:element-ui官网组件

四:注册路由

五:修改端口

六:运行项目

 2.axios请求

  2.1:什么是axios?

  2.2:安装并使用axios

  2.3:编写axios请求

  2.4 调用该接口(先打开后端项目接口)

3:axios的轻量封装

4:跨域问题


1.vue项目登录注册

  1.1 :使用vue-cli搭建vue项目

 使用vscode打开项目

  1.2:使用npm 下载element-ui

npm install element-ui -s

 

 表示下载成功。

  1.3编写登录注册页面
一:在src目录下创建views目录

二:在main.js中引入element-ui模块
import Vue from 'vue'

// 新添加1
import ElementUI from 'element-ui'
// 新添加2,避免后期打包样式不同,要放在import App from './App';之前
import 'element-ui/lib/theme-chalk/index.css'

import App from './App'
import router from './router'


// 新添加3
Vue.use(ElementUI)
Vue.config.productionTip = false

/* eslint-disable no-new */
new Vue({
  el: '#app',
  router,
  components: { App },
  template: '<App/>'
})
三:element-ui官网组件
<template>
	<div class="login-wrap">
		<el-form class="login-container">
			<h1 class="title">用户登录</h1>
			<el-form-item label="">
				<el-input type="text" v-model="username" placeholder="登录账号" autocomplete="off"></el-input>
			</el-form-item>
			<el-form-item label="">
				<el-input type="password" v-model="password" placeholder="登录密码" autocomplete="off"></el-input>
			</el-form-item>
			<el-form-item>
				<el-button type="primary" style="width:100%;" @click="doSubmit()">提交</el-button>
			</el-form-item>
			<el-row style="text-align: center;margin-top:-10px">
				<el-link type="primary">忘记密码</el-link>
				<el-link type="primary" @click="gotoRegister()">用户注册</el-link>
			</el-row>
		</el-form>
	</div>
</template>

<script>
export default {
  name: 'Login',
  data () {
    return {
      msg: 'Welcome to Your Vue.js App'
    }
  }
}
</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>

四:注册路由

来到router文件夹的index.js下注册路由

import Vue from 'vue'
import Router from 'vue-router'
import HelloWorld from '@/components/HelloWorld'
// 导入Login登录组件
import Login from '@/views/Login'

Vue.use(Router)

export default new Router({
  routes: [
    {
        path: '/',   //设置默认显示路由
        name: 'Login',
        component: Login
    },
    {
        path: '/HelloWorld',
        name: 'HelloWorld',
        component: HelloWorld
    }
  ]
})
五:修改端口

在config文件夹下的index.js修改端口

六:运行项目

使用npm run dev 启动项目

        这个时候我们可以通过java构建后台,使用vue请求接口即可。

 2.axios请求

  2.1:什么是axios?

Axios 是一个基于 promise 的 HTTP 库,可以用在浏览器和 node.js 中

axios的github: https://github.com/axios/axios

           Axios 是一个基于 promise 的 HTTP 库,简单的讲就是可以发送get、post等请求,可以用在浏览器和 node.js 中。React等框架的出现,促使了Axios轻量级库的出现,因为Vue等,不需要操作Dom,所以不需要引入Jquery.js了。

 promise:

         异步编程的一种解决方案所谓Promise,简单说就是一个容器,里面保存着某个未来才会结束的事件(通常是一个异步操作)的结果。

Promise提供统一的API,各种异步操作都可以用同样的方法进行处理。

Promise对象代表一个异步操作,有三种状态:Pending(进行中)、Resolved(已完成,又称Fulfilled)和Rejected(已失败)。只有异步操作的结果,可以决定当前是哪一种状态,任何其他操作都无法改变这个状态 (英语意思就是“承诺”,表示其他手段无法改变)

与事件(Event)完全不同,事件的特点是,如果你错过了它,再去监听,是得不到结果的。 有了Promise对象,就可以将异步操作以同步操作的流程表达出来,避免了层层嵌套的回调函数

 特性:
1.从浏览器创建 XMLHttpRequests
2.从 node.js 创建 http 请求
3.支持 Promise API
4.拦截请求和响应
5.转换请求和响应数据
6.取消请求
7.自动转换JSON数据
8.客户端支持防御XSRF

  2.2:安装并使用axios

npm i axios -s

  引入axios

 import axios from 'axios'

  2.3:编写axios请求
<script>
import axios from 'axios'
export default {
    name: 'Login',
    data: function() {
        return {
            username: "admin",
            password: "123"
        }
    },
    methods: {
    	doSubmit: function() {
            let params = {
                username: this.username,
                password: this.password
            };
            console.log(params);
            var url = "http://localhost:8080/ssm/user/userLogin";

            axios.get(url, { //注意数据是保存到json对象的params属性
            	params: params
            }).then(function(response) {
            	console.log(response);
            }).catch(function(error) {
            	console.log(error);
            });
        }
    }
}
</script>
 2.4 调用该接口(先打开后端项目接口)

发送请求调用接口,登录成功

 这里我们使用的是get请求,post请求为如下代码

<script>
import axios from 'axios'
import qs from 'qs'
export default {
    name: 'Login',
    data: function() {
        return {
            username: "admin",
            password: "123"
        }
    },
    methods: {
    	doSubmit: function() {
            let params = {
                username: this.username,
                password: this.password
            };
            console.log(params);
            var url = "http://localhost:8080/ssm/user/userLogin";
            let str=qs.stringify(params);
			//注意数据是保存到json对象的params属性
            axios.post(url, str).then(function(response) { 
            	console.log(response);
            }).catch(function(error) {
            	console.log(error);
            });
        }
    }
}
</script>

3:axios的轻量封装

将api模块导入到SPA项目的src目录下,其中api模块包含了action.js(针对后台请求接口的封装定义)和http.js(针对axios的全局配置)两个文件。

action.js

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

http.js

import axios from 'axios'
import qs from 'qs'

//引入action模块,并添加至axios的类属性urls上
import action from '@/api/action'
axios.urls = action

// axios默认配置
axios.defaults.timeout = 10000; // 超时时间
// axios.defaults.baseURL = 'http://localhost:8080/j2ee15'; // 默认地址
axios.defaults.baseURL = action.SERVER;

//整理数据
// 只适用于 POST,PUT,PATCH,transformRequest` 允许在向服务器发送前,修改请求数据
axios.defaults.transformRequest = function(data) {
	data = qs.stringify(data);
	return data;
};

// 请求拦截器
axios.interceptors.request.use(function(config) {
	return config;
}, function(error) {
	return Promise.reject(error);
});

// 响应拦截器
axios.interceptors.response.use(function(response) {
	return response;
}, function(error) {
	return Promise.reject(error);
});
export default axios;

使用vue-axios和qs

import axios from '@/api/http'
import VueAxios from 'vue-axios' 
​Vue.use(VueAxios,axios)
let url=this.axios.urls.SYSTEM_USER_DOLOGIN;
this.axios.post(url,params).then(function(response) {
	console.log(response);
}).catch(function(error) {
	console.log(error);
});

 4:跨域问题

什么是跨域问题:

跨域:指的是浏览器不能执行其他网站的脚本。它是由浏览器的同源策略造成的,是浏览器对javascript施加的安全限制。

例如:a页面想获取b页面资源,如果a、b页面的协议、域名、端口、子域名不同,所进行的访问行动都是跨域的,而浏览器为了安全问题一般都限制了跨域访问,也就是不允许跨域请求资源。注意:跨域限制访问,其实是浏览器的限制。理解这一点很重要。

同源策略:是指协议,域名,端口都要相同,其中有一个不同都会产生跨域;

简单说,跨域分为 简单跨域 和 复杂跨域

简单跨域:不会发送OPTIONS请求

复杂跨域:会发送一个预检查OPTIONS请求

复杂跨域的条件是:

①、非GET、HEAD、POST请求。

②、POST请求的Content-Type不是application/x-www-form-urlencoded, multipart/form-data, 或text/plain。

③、添加了自定义header,例如Token。

跨域请求浏览器会在Headers中添加Origin,通常情况下不允许用户修改其值。

我们在ssm项目中怎么解决跨域问题?

在web.xml配置

  <!--CrosFilter跨域过滤器-->
  <filter>
    <filter-name>corsFilter</filter-name>
    <filter-class>com.zking.ssm.util.CorsFilter2</filter-class>
  </filter>
  <filter-mapping>
    <filter-name>corsFilter</filter-name>
    <url-pattern>/*</url-pattern>
  </filter-mapping>

我们在springboot使用@CrossOrigin注解解决跨域问题。

在前后端分离的项目中,我们可以使用Nginx web服务器来处理跨域问题,通过配置conf文件,反向代理解决跨域问题。

location /
{
      add_header Access-Control-Allow-Origin *;
      add_header 'Access-Control-Allow-Credentials''true'; # 是否允许后续请求携带cookies,该值只能是true,否则不返回。如果上面的Access-Control-Allow-Origin设置的是* 而你又需要cookie信息,则 必须设置这行。 
      add_header Access-Control-Allow-Methods 'GET, POST, OPTIONS'; 
      add_header Access-Control-Allow-Headers *;
      if($request_method = 'OPTIONS')
      {
         return204;
      }
}

Logo

为开发者提供学习成长、分享交流、生态实践、资源工具等服务,帮助开发者快速成长。

更多推荐