日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 前端技术 > vue >内容正文

vue

Vue项目使用拦截器和JWT验证 完整案例

發(fā)布時間:2023/12/8 vue 42 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Vue项目使用拦截器和JWT验证 完整案例 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

挺詳細(xì)的一個案例項目,值得參考!


作者:YXi

https://juejin.im/post/6844903959883218951)

https://gitee.com/gitee_fanjunyang/Inter_JWT

幾乎在所有的項目中都離不開攔截器登錄驗證,這是必需的。如果你學(xué)會了這個 demo,那么幾乎所有網(wǎng)站的登錄驗證,加載動畫就都會了,所以背也要背會

所以本章以一個 demo 為例,來幫助大家理解攔截器登錄驗證控制

文章后面有源碼,可以下載下來運行一下

先來看看效果:

功能:

  • 當(dāng)你訪問首頁的時候,會有一個加載動畫,就是攔截器的功勞,并且首頁會有一個當(dāng)前登錄的用戶名,默認(rèn)是 wangcai,等你登錄成功后,會替換成你自己登錄的用戶名

  • 當(dāng)你沒有登錄的時候,可以訪問首頁和登錄頁,但是訪問不了個人中心 (Profile),當(dāng)你訪問個人中心,會給你自動跳轉(zhuǎn)到登錄頁

  • 當(dāng)你在登錄頁進(jìn)行登錄,如果用戶名輸入錯誤的話,會彈出錯誤信息

  • 當(dāng)你輸入正確的時候 (我設(shè)置了 Fan 為正確的用戶名),點擊登錄,登錄成功后,會自動給你跳轉(zhuǎn)到首頁

  • 并且登錄成功后,如果你再點擊想進(jìn)入登錄頁,是不行的,他會自動給你跳轉(zhuǎn)到首頁

  • 登錄成功后,就可以訪問 個人中心頁面

  • 如果你超過 20 秒 不對頁面進(jìn)行操作 (我設(shè)置的是 20 秒,可以自行設(shè)置),那么 token 會自動失效,那么你就訪問不了個人中心,你需要再次登錄

  • 如果你在 20 秒 之內(nèi),操作頁面的話,那么 token 的值是不會失效的,所以是不需要再次登錄的。也就是說,在 20 秒 之內(nèi),你每次進(jìn)行路由跳轉(zhuǎn)的時候,token 的值和時間就會自動重置,防止失效讓你再次登錄(總不能讓你看著看著突然讓你登錄)

  • 搜索公縱號:MarkerHub,關(guān)注回復(fù)[?vue?]獲取前后端入門教程!

下面就讓我們開始吧!!!(有關(guān)代碼的解釋說明已在代碼中注釋

案例

使用攔截器并封裝axios

新建一個 Vue 項目 (vue create demo)

刪去不必要的文件和代碼,經(jīng)典化代碼

安裝需要的依賴:

package.json文件部分代碼:

"dependencies": {"axios": "^0.19.0","body-parser": "^1.19.0","core-js": "^2.6.5","express": "^4.17.1","iview": "^4.0.0-rc.4","jsonwebtoken": "^8.5.1","vue": "^2.6.10","vue-router": "^3.0.3","vuex": "^3.0.1" },

在server.js文件中配置跨域,并書寫測試接口:

let express = require('express') let bodyParser = require('body-parser')let app = express()// 配置跨域 app.use((req, res, next) => {res.header("Access-Control-Allow-Origin", "\*");res.header("Access-Control-Allow-Methods", "GET,HEAD,OPTIONS,POST,PUT"),res.header("Access-Control-Allow-Headers", "Origin,X-Requested-With,Content-Type,Accept,Authorization")if (req.method.toLowerCase() === "options") {return res.end();}next(); })// 配置bodyparser app.use(bodyParser.json())app.get("/user", (req, res) => {//在請求數(shù)據(jù)時,要加一個動畫,為了測試,所以讓它時間長點,加了一個定時器setTimeout(() => {res.json({name: "wangcai"})}, 500) })app.listen(3000)

在router.js中配置路由:

routes: \[{path: '/',name: 'home',component: Home},{path: '/login',name: 'login',component: () => import('./views/Login.vue')},{path: '/profile',name: 'profile',component: () => import('./views/Profile.vue')} \]

因為項目中需要用到樣式什么的,這里我引入了iView,main.js代碼:

import Vue from 'vue' import App from './App.vue' import router from './router' import store from './store'//引入iView import iView from 'iview' import 'iview/dist/styles/iview.css'; Vue.use(iView)Vue.config.productionTip = falsenew Vue({router,store,render: h => h(App) }).$mount('#app')

因為項目中要用到加載數(shù)據(jù)的動畫,所以需要在store.js中的state中配置:

state: {//定義動畫是否顯示isShowLoading:false,username:'wangcai'},mutations: {//使動畫顯示showLoading(state){state.isShowLoading = true;},//使動畫隱藏hideLoading(state){state.isShowLoading = false;} },

在App.vue中配置跳轉(zhuǎn):

<template><div><div><router-link to="/">Home</router-link> |<router-link to="/login">Login</router-link> |<router-link to="/profile">Profile</router-link></div><router-view/></div> </template>

Home.vue代碼:

<template><div><h1>首頁面</h1></div> </template>

Login.vue代碼:

<template><div><i-input placeholder="請輸入用戶名..."></i-input><i-button type="primary">登錄</i-button></div> </template>

Profile.vue代碼:

<template> <div><h1>個人中心</h1> </div> </template>

然后在libs文件夾下面新建一個ajaxRequest.js文件,用來封裝我們自己的 axios 和 加載動畫 等

搜索公縱號:MarkerHub,關(guān)注回復(fù)[?vue?]獲取前后端入門教程!

import axios from 'axios' import store from '../store'//當(dāng)?shù)谝淮握埱髸r,顯示loading class AjaxRequest {//當(dāng)new的時候,調(diào)用這個方法constructor() {//請求的基礎(chǔ)路徑this.baseURL = process.env.NODE\_ENV == "production" ? "/" : "http://localhost:3000"this.timeout = 3000 //超時時間this.queue = {} //存放每一次的請求}//定義一個方法,把options展開merge(options) {return {...options,baseURL: this.baseURL,timeout: this.timeout}}//封裝一個攔截方法setInterceptor(instance, url) {//請求攔截,每次請求時,都要加上一個loading效果instance.interceptors.request.use((config) => {//每次請求時,都給他加一個Authorization頭,在JWT驗證時要用config.headers.Authorization = 'xxx'//第一次請求時,顯示loading動畫if (Object.keys(this.queue).length === 0) {store.commit('showLoading')}this.queue\[url\] = url;return config})//響應(yīng)攔截instance.interceptors.response.use((res) => {//刪除queue里面的鏈接,如果同一個按鈕,你一秒之內(nèi)點擊無數(shù)次,但是他只處理第一次操作delete this.queue\[url\]//隱藏loading動畫if (Object.keys(this.queue).length === 0) {store.commit('hideLoading')}//返回的結(jié)果return res.data})}request(options) {let instance = axios.create() //創(chuàng)建一個axios實例this.setInterceptor(instance, options.url) //設(shè)置攔截let config = this.merge(options)return instance(config) //axios執(zhí)行后,返回promise} }export default new AjaxRequest;

然后在api文件夾下新建一個user.js文件用來放用戶相關(guān)的調(diào)用接口的方法(當(dāng)你想要調(diào)用接口的時候,直接調(diào)用里面的方法就好):

import axios from '../libs/ajaxRequset'// 用戶相關(guān)的接口 export const getUser = ()=>{return axios.request({url:'/user',method:'get'}) }

修改Home.vue中的代碼:

<template><div><h1>首頁面</h1><p>當(dāng)前登錄的用戶名是{{$store.state.username}}</p></div> </template><script> //如果用export導(dǎo)出的話,要用這種形式,相當(dāng)于解構(gòu)賦值 import {getUser} from '../api/user' export default {name:'home',async mounted(){let r = await getUser()console.log(r);} } </script>

修改App.vue中的代碼(加動畫效果):

<template><div><Spin size="large" fix v-if="$store.state.isShowLoading">加載中...</Spin><div><router-link to="/">Home</router-link> |<router-link to="/login">Login</router-link> |<router-link to="/profile">Profile</router-link></div><router-view/></div> </template><style> #app {font-family: "Avenir", Helvetica, Arial, sans-serif;-webkit-font-smoothing: antialiased;-moz-osx-font-smoothing: grayscale;text-align: center;color: #2c3e50; } #nav {padding: 30px; }#nav a {font-weight: bold;color: #2c3e50; }#nav a.router-link-exact-active {color: #42b983; } </style>

運行效果:

使用 JWT

在server.js中新增代碼,使用 JWT,并寫好登錄和驗證的接口:

let jwt = require('jsonwebtoken')let secret = "xwc"//登錄的接口 app.post('/login',(req,res)=>{let {username} = req.body;if(username === 'Fan'){//登錄成功后返回一個tokenres.json({code:0,username:'Fan',token:jwt.sign({username:'Fan'},secret,{expiresIn:20 //表示token20秒過期})})}else{//登錄失敗res.json({code:1,data:'登錄失敗了'})} })//驗證token的接口 app.get('/validate',(req,res)=>{let token = req.headers.authorization; //我們會把token放到我們自己設(shè)置的http的頭authorization中,在這里可以直接拿到j(luò)wt.verify(token,secret,(err,decode)=>{ //驗證tokenif(err){return res.json({code:1,data:'token失效了'})}else{// token合法 在這里,需要把token的時效延長,//總不能我們看著看著突然讓我們重新登錄,token過期的意思是,你在這之間不進(jìn)行任何操作才會過期res.json({code:0,username:decode.username,token:jwt.sign({username:'Fan'},secret,{ //合法時,我們需要重新生成一個token,我們每次切換路由,都要重新生成一個tokenexpiresIn:20})})}}) })

接著在api文件夾下的user.js文件中添加登錄和驗證的方法:

import axios from '../libs/ajaxRequest'// 用戶相關(guān)的接口// 調(diào)獲取用戶信息的接口 向外暴露一個getUser方法 這個方法中調(diào)了接口 // 在組件中,就可以使用getUser,就相當(dāng)于調(diào)用接口 export const getUser = ()=>{return axios.request({url:'/user',method:'get'}) }// 再向外暴露一個登錄的方法,方法內(nèi)部也是調(diào)接口 // 在登錄組件中就可以調(diào)用Login方法,需要給方法傳遞一個用戶名 export const login = (username)=>{return axios.request({url:'/login',method:'post',data:{username}}) }//驗證token方法 export const validate = ()=>{return axios.request({url:'/validate',method:'get'}) }

接著我們在lib文件夾下新建一個local.js文件,用來設(shè)置或者獲取localStorage里的token:

//把獲得到的token存到localStorage里 export const setLocal = (key,value)=>{if(typeof value == 'object'){ //如果傳過來的是對象,則轉(zhuǎn)換成字符串value = JSON.stringify(value)}localStorage.setItem(key,value) //存到localStorage里 }//獲取localStorage里的token export const getLocal = (key)=>{return localStorage.getItem(key) }

然后修改store.js中的代碼:

import Vue from 'vue' import Vuex from 'vuex' import {login,validate} from './api/user' //必須用這種方式引入 import {setLocal} from './libs/local' //引入lib文件夾下的local.js文件中的setLocal方法(往localStorage里存放token)Vue.use(Vuex)export default new Vuex.Store({state: {//定義動畫是否顯示isShowLoading:false,username:'wangcai'},mutations: {//使動畫顯示showLoading(state){state.isShowLoading = true;},//使動畫隱藏hideLoading(state){state.isShowLoading = false;},//定義修改用戶名的方法setUser(state,username){state.username = username}},// actions存放接口的調(diào)用 dispatch actions里面放方法actions: {//這里面所有的方法都是異步的//登錄方法async toLogin({commit},username){let r = await login(username) //調(diào)用user.js中的login方法,也就是調(diào)用登錄接口// console.log(r);if(r.code === 0){ //登錄成功后會給你返回json數(shù)據(jù),里面有code//登錄成功了commit('setUser',r.username) //修改用戶名setLocal('token',r.token) //把得到的token存到localStorage里}else{// console.log('............');return Promise.reject(r.data); //如果失敗,返回一個promise失敗態(tài)}},//驗證token方法async validate({commit}){let r = await validate(); //調(diào)用user.js中的validate方法,也就是調(diào)用驗證接口if(r.code === 0){commit('setUser',r.username)setLocal('token',r.token) //我們說了,驗證通過,或者每次切換路由時,都要重新生成token}return r.code === 0; //返回token是否失效,true或者false}} })

修改Login.vue中的代碼:

<template><div><i-input v-model="username" placeholder="請輸入用戶名..."></i-input><i-button type="primary" @click="login()">登錄</i-button></div> </template><script> import {mapActions} from 'vuex' //使用vuex中的mapActions方法,不會的請參考我的文章vuex的使用方法 export default {data(){return{username:'' //定義一個用戶名}},methods:{...mapActions(\['toLogin'\]), //獲取store.js文件中的actions中的toLogin方法login(){// console.log(this\['toLogin'\](this.username));//使用獲取到的toLogin方法this\['toLogin'\](this.username).then(data=>{ //因為toLogin返回的是一個Promise,所以可以.thenthis.$router.push('/') //登錄成功,跳到首頁面},err=>{this.$Message.error(err)})}} } </script>

別忘了修改ajaxRequest.js文件,在請求攔截的時候,需要加個頭,前面我們寫死了,這里,要把 token 給他,然后每次路由跳轉(zhuǎn)訪問頁面的時候,都會帶上這個頭,用來驗證:

import {getLocal} from "../libs/local" //引入//請求攔截,每次請求時,都要加上一個loading效果 instance.interceptors.request.use((config) => {//每次請求時,都給他加一個Authorization頭,在JWT驗證時要用config.headers.Authorization = getLocal('token')//第一次請求時,顯示loading動畫if (Object.keys(this.queue).length === 0) {store.commit('showLoading')}this.queue\[url\] = url;return config })

接著在router.js中設(shè)置路由:
哪個頁面需要登錄后才能訪問的話,給這個路由添加meta,假如我的 個人中心頁面 需要登錄后才能訪問,那么我需要修改代碼:

{path: '/profile',name: 'profile',component: () => import('./views/Profile.vue'),meta:{needLogin:true} }

最后修改main.js中的代碼,當(dāng)切換路由時,進(jìn)行驗證:

import Vue from 'vue' import App from './App.vue' import router from './router' import store from './store'//引入iView import iView from 'iview' import 'iview/dist/styles/iview.css';Vue.use(iView)Vue.config.productionTip = false//每一次切換路由時,都執(zhí)行這個導(dǎo)航守衛(wèi) router.beforeEach(async (to,from,next)=>{let isLogin = await store.dispatch('validate') //判斷是否登錄了// needLogin 表示哪些路由需要在登錄條件下才能訪問console.log(to);let needLogin = to.matched.some(match=>match.meta.needLogin)if(needLogin){//需要登錄if(isLogin){//登錄過了next()}else{//沒有登錄next('/login')}}else{//不需要登錄if(isLogin && to.path === '/login'){ //如果你訪問login頁面,則給你跳到首頁面,因為不需要登錄next('/')}else{next()}} })new Vue({router,store,render: h => h(App) }).$mount('#app')

有關(guān)需要注意的點,都加注釋了,好好看注釋就行

至此,整個案例就結(jié)束了

?

挺詳細(xì)的一個案例項目,值得參考!


作者:YXi

https://juejin.im/post/6844903959883218951)

幾乎在所有的項目中都離不開攔截器登錄驗證,這是必需的。如果你學(xué)會了這個 demo,那么幾乎所有網(wǎng)站的登錄驗證,加載動畫就都會了,所以背也要背會

所以本章以一個 demo 為例,來幫助大家理解攔截器登錄驗證控制

文章后面有源碼,可以下載下來運行一下

先來看看效果:

功能:

  • 當(dāng)你訪問首頁的時候,會有一個加載動畫,就是攔截器的功勞,并且首頁會有一個當(dāng)前登錄的用戶名,默認(rèn)是 wangcai,等你登錄成功后,會替換成你自己登錄的用戶名

  • 當(dāng)你沒有登錄的時候,可以訪問首頁和登錄頁,但是訪問不了個人中心 (Profile),當(dāng)你訪問個人中心,會給你自動跳轉(zhuǎn)到登錄頁

  • 當(dāng)你在登錄頁進(jìn)行登錄,如果用戶名輸入錯誤的話,會彈出錯誤信息

  • 當(dāng)你輸入正確的時候 (我設(shè)置了 Fan 為正確的用戶名),點擊登錄,登錄成功后,會自動給你跳轉(zhuǎn)到首頁

  • 并且登錄成功后,如果你再點擊想進(jìn)入登錄頁,是不行的,他會自動給你跳轉(zhuǎn)到首頁

  • 登錄成功后,就可以訪問 個人中心頁面

  • 如果你超過 20 秒 不對頁面進(jìn)行操作 (我設(shè)置的是 20 秒,可以自行設(shè)置),那么 token 會自動失效,那么你就訪問不了個人中心,你需要再次登錄

  • 如果你在 20 秒 之內(nèi),操作頁面的話,那么 token 的值是不會失效的,所以是不需要再次登錄的。也就是說,在 20 秒 之內(nèi),你每次進(jìn)行路由跳轉(zhuǎn)的時候,token 的值和時間就會自動重置,防止失效讓你再次登錄(總不能讓你看著看著突然讓你登錄)

  • 搜索公縱號:MarkerHub,關(guān)注回復(fù)[?vue?]獲取前后端入門教程!

下面就讓我們開始吧!!!(有關(guān)代碼的解釋說明已在代碼中注釋

案例

使用攔截器并封裝axios

新建一個 Vue 項目 (vue create demo)

刪去不必要的文件和代碼,經(jīng)典化代碼

安裝需要的依賴:

package.json文件部分代碼:

"dependencies": {"axios": "^0.19.0","body-parser": "^1.19.0","core-js": "^2.6.5","express": "^4.17.1","iview": "^4.0.0-rc.4","jsonwebtoken": "^8.5.1","vue": "^2.6.10","vue-router": "^3.0.3","vuex": "^3.0.1" },

在server.js文件中配置跨域,并書寫測試接口:

let express = require('express') let bodyParser = require('body-parser')let app = express()// 配置跨域 app.use((req, res, next) => {res.header("Access-Control-Allow-Origin", "\*");res.header("Access-Control-Allow-Methods", "GET,HEAD,OPTIONS,POST,PUT"),res.header("Access-Control-Allow-Headers", "Origin,X-Requested-With,Content-Type,Accept,Authorization")if (req.method.toLowerCase() === "options") {return res.end();}next(); })// 配置bodyparser app.use(bodyParser.json())app.get("/user", (req, res) => {//在請求數(shù)據(jù)時,要加一個動畫,為了測試,所以讓它時間長點,加了一個定時器setTimeout(() => {res.json({name: "wangcai"})}, 500) })app.listen(3000)

在router.js中配置路由:

routes: \[{path: '/',name: 'home',component: Home},{path: '/login',name: 'login',component: () => import('./views/Login.vue')},{path: '/profile',name: 'profile',component: () => import('./views/Profile.vue')} \]

因為項目中需要用到樣式什么的,這里我引入了iView,main.js代碼:

import Vue from 'vue' import App from './App.vue' import router from './router' import store from './store'//引入iView import iView from 'iview' import 'iview/dist/styles/iview.css'; Vue.use(iView)Vue.config.productionTip = falsenew Vue({router,store,render: h => h(App) }).$mount('#app')

因為項目中要用到加載數(shù)據(jù)的動畫,所以需要在store.js中的state中配置:

state: {//定義動畫是否顯示isShowLoading:false,username:'wangcai'},mutations: {//使動畫顯示showLoading(state){state.isShowLoading = true;},//使動畫隱藏hideLoading(state){state.isShowLoading = false;} },

在App.vue中配置跳轉(zhuǎn):

<template><div><div><router-link to="/">Home</router-link> |<router-link to="/login">Login</router-link> |<router-link to="/profile">Profile</router-link></div><router-view/></div> </template>

Home.vue代碼:

<template><div><h1>首頁面</h1></div> </template>

Login.vue代碼:

<template><div><i-input placeholder="請輸入用戶名..."></i-input><i-button type="primary">登錄</i-button></div> </template>

Profile.vue代碼:

<template> <div><h1>個人中心</h1> </div> </template>

然后在libs文件夾下面新建一個ajaxRequest.js文件,用來封裝我們自己的 axios 和 加載動畫 等

搜索公縱號:MarkerHub,關(guān)注回復(fù)[?vue?]獲取前后端入門教程!

import axios from 'axios' import store from '../store'//當(dāng)?shù)谝淮握埱髸r,顯示loading class AjaxRequest {//當(dāng)new的時候,調(diào)用這個方法constructor() {//請求的基礎(chǔ)路徑this.baseURL = process.env.NODE\_ENV == "production" ? "/" : "http://localhost:3000"this.timeout = 3000 //超時時間this.queue = {} //存放每一次的請求}//定義一個方法,把options展開merge(options) {return {...options,baseURL: this.baseURL,timeout: this.timeout}}//封裝一個攔截方法setInterceptor(instance, url) {//請求攔截,每次請求時,都要加上一個loading效果instance.interceptors.request.use((config) => {//每次請求時,都給他加一個Authorization頭,在JWT驗證時要用config.headers.Authorization = 'xxx'//第一次請求時,顯示loading動畫if (Object.keys(this.queue).length === 0) {store.commit('showLoading')}this.queue\[url\] = url;return config})//響應(yīng)攔截instance.interceptors.response.use((res) => {//刪除queue里面的鏈接,如果同一個按鈕,你一秒之內(nèi)點擊無數(shù)次,但是他只處理第一次操作delete this.queue\[url\]//隱藏loading動畫if (Object.keys(this.queue).length === 0) {store.commit('hideLoading')}//返回的結(jié)果return res.data})}request(options) {let instance = axios.create() //創(chuàng)建一個axios實例this.setInterceptor(instance, options.url) //設(shè)置攔截let config = this.merge(options)return instance(config) //axios執(zhí)行后,返回promise} }export default new AjaxRequest;

然后在api文件夾下新建一個user.js文件用來放用戶相關(guān)的調(diào)用接口的方法(當(dāng)你想要調(diào)用接口的時候,直接調(diào)用里面的方法就好):

import axios from '../libs/ajaxRequset'// 用戶相關(guān)的接口 export const getUser = ()=>{return axios.request({url:'/user',method:'get'}) }

修改Home.vue中的代碼:

<template><div><h1>首頁面</h1><p>當(dāng)前登錄的用戶名是{{$store.state.username}}</p></div> </template><script> //如果用export導(dǎo)出的話,要用這種形式,相當(dāng)于解構(gòu)賦值 import {getUser} from '../api/user' export default {name:'home',async mounted(){let r = await getUser()console.log(r);} } </script>

修改App.vue中的代碼(加動畫效果):

<template><div><Spin size="large" fix v-if="$store.state.isShowLoading">加載中...</Spin><div><router-link to="/">Home</router-link> |<router-link to="/login">Login</router-link> |<router-link to="/profile">Profile</router-link></div><router-view/></div> </template><style> #app {font-family: "Avenir", Helvetica, Arial, sans-serif;-webkit-font-smoothing: antialiased;-moz-osx-font-smoothing: grayscale;text-align: center;color: #2c3e50; } #nav {padding: 30px; }#nav a {font-weight: bold;color: #2c3e50; }#nav a.router-link-exact-active {color: #42b983; } </style>

運行效果:

使用 JWT

在server.js中新增代碼,使用 JWT,并寫好登錄和驗證的接口:

let jwt = require('jsonwebtoken')let secret = "xwc"//登錄的接口 app.post('/login',(req,res)=>{let {username} = req.body;if(username === 'Fan'){//登錄成功后返回一個tokenres.json({code:0,username:'Fan',token:jwt.sign({username:'Fan'},secret,{expiresIn:20 //表示token20秒過期})})}else{//登錄失敗res.json({code:1,data:'登錄失敗了'})} })//驗證token的接口 app.get('/validate',(req,res)=>{let token = req.headers.authorization; //我們會把token放到我們自己設(shè)置的http的頭authorization中,在這里可以直接拿到j(luò)wt.verify(token,secret,(err,decode)=>{ //驗證tokenif(err){return res.json({code:1,data:'token失效了'})}else{// token合法 在這里,需要把token的時效延長,//總不能我們看著看著突然讓我們重新登錄,token過期的意思是,你在這之間不進(jìn)行任何操作才會過期res.json({code:0,username:decode.username,token:jwt.sign({username:'Fan'},secret,{ //合法時,我們需要重新生成一個token,我們每次切換路由,都要重新生成一個tokenexpiresIn:20})})}}) })

接著在api文件夾下的user.js文件中添加登錄和驗證的方法:

import axios from '../libs/ajaxRequest'// 用戶相關(guān)的接口// 調(diào)獲取用戶信息的接口 向外暴露一個getUser方法 這個方法中調(diào)了接口 // 在組件中,就可以使用getUser,就相當(dāng)于調(diào)用接口 export const getUser = ()=>{return axios.request({url:'/user',method:'get'}) }// 再向外暴露一個登錄的方法,方法內(nèi)部也是調(diào)接口 // 在登錄組件中就可以調(diào)用Login方法,需要給方法傳遞一個用戶名 export const login = (username)=>{return axios.request({url:'/login',method:'post',data:{username}}) }//驗證token方法 export const validate = ()=>{return axios.request({url:'/validate',method:'get'}) }

接著我們在lib文件夾下新建一個local.js文件,用來設(shè)置或者獲取localStorage里的token:

//把獲得到的token存到localStorage里 export const setLocal = (key,value)=>{if(typeof value == 'object'){ //如果傳過來的是對象,則轉(zhuǎn)換成字符串value = JSON.stringify(value)}localStorage.setItem(key,value) //存到localStorage里 }//獲取localStorage里的token export const getLocal = (key)=>{return localStorage.getItem(key) }

然后修改store.js中的代碼:

import Vue from 'vue' import Vuex from 'vuex' import {login,validate} from './api/user' //必須用這種方式引入 import {setLocal} from './libs/local' //引入lib文件夾下的local.js文件中的setLocal方法(往localStorage里存放token)Vue.use(Vuex)export default new Vuex.Store({state: {//定義動畫是否顯示isShowLoading:false,username:'wangcai'},mutations: {//使動畫顯示showLoading(state){state.isShowLoading = true;},//使動畫隱藏hideLoading(state){state.isShowLoading = false;},//定義修改用戶名的方法setUser(state,username){state.username = username}},// actions存放接口的調(diào)用 dispatch actions里面放方法actions: {//這里面所有的方法都是異步的//登錄方法async toLogin({commit},username){let r = await login(username) //調(diào)用user.js中的login方法,也就是調(diào)用登錄接口// console.log(r);if(r.code === 0){ //登錄成功后會給你返回json數(shù)據(jù),里面有code//登錄成功了commit('setUser',r.username) //修改用戶名setLocal('token',r.token) //把得到的token存到localStorage里}else{// console.log('............');return Promise.reject(r.data); //如果失敗,返回一個promise失敗態(tài)}},//驗證token方法async validate({commit}){let r = await validate(); //調(diào)用user.js中的validate方法,也就是調(diào)用驗證接口if(r.code === 0){commit('setUser',r.username)setLocal('token',r.token) //我們說了,驗證通過,或者每次切換路由時,都要重新生成token}return r.code === 0; //返回token是否失效,true或者false}} })

修改Login.vue中的代碼:

<template><div><i-input v-model="username" placeholder="請輸入用戶名..."></i-input><i-button type="primary" @click="login()">登錄</i-button></div> </template><script> import {mapActions} from 'vuex' //使用vuex中的mapActions方法,不會的請參考我的文章vuex的使用方法 export default {data(){return{username:'' //定義一個用戶名}},methods:{...mapActions(\['toLogin'\]), //獲取store.js文件中的actions中的toLogin方法login(){// console.log(this\['toLogin'\](this.username));//使用獲取到的toLogin方法this\['toLogin'\](this.username).then(data=>{ //因為toLogin返回的是一個Promise,所以可以.thenthis.$router.push('/') //登錄成功,跳到首頁面},err=>{this.$Message.error(err)})}} } </script>

別忘了修改ajaxRequest.js文件,在請求攔截的時候,需要加個頭,前面我們寫死了,這里,要把 token 給他,然后每次路由跳轉(zhuǎn)訪問頁面的時候,都會帶上這個頭,用來驗證:

import {getLocal} from "../libs/local" //引入//請求攔截,每次請求時,都要加上一個loading效果 instance.interceptors.request.use((config) => {//每次請求時,都給他加一個Authorization頭,在JWT驗證時要用config.headers.Authorization = getLocal('token')//第一次請求時,顯示loading動畫if (Object.keys(this.queue).length === 0) {store.commit('showLoading')}this.queue\[url\] = url;return config })

接著在router.js中設(shè)置路由:
哪個頁面需要登錄后才能訪問的話,給這個路由添加meta,假如我的 個人中心頁面 需要登錄后才能訪問,那么我需要修改代碼:

{path: '/profile',name: 'profile',component: () => import('./views/Profile.vue'),meta:{needLogin:true} }

最后修改main.js中的代碼,當(dāng)切換路由時,進(jìn)行驗證:

import Vue from 'vue' import App from './App.vue' import router from './router' import store from './store'//引入iView import iView from 'iview' import 'iview/dist/styles/iview.css';Vue.use(iView)Vue.config.productionTip = false//每一次切換路由時,都執(zhí)行這個導(dǎo)航守衛(wèi) router.beforeEach(async (to,from,next)=>{let isLogin = await store.dispatch('validate') //判斷是否登錄了// needLogin 表示哪些路由需要在登錄條件下才能訪問console.log(to);let needLogin = to.matched.some(match=>match.meta.needLogin)if(needLogin){//需要登錄if(isLogin){//登錄過了next()}else{//沒有登錄next('/login')}}else{//不需要登錄if(isLogin && to.path === '/login'){ //如果你訪問login頁面,則給你跳到首頁面,因為不需要登錄next('/')}else{next()}} })new Vue({router,store,render: h => h(App) }).$mount('#app')

有關(guān)需要注意的點,都加注釋了,好好看注釋就行

至此,整個案例就結(jié)束了

?

挺詳細(xì)的一個案例項目,值得參考!


作者:YXi

https://juejin.im/post/6844903959883218951)

幾乎在所有的項目中都離不開攔截器登錄驗證,這是必需的。如果你學(xué)會了這個 demo,那么幾乎所有網(wǎng)站的登錄驗證,加載動畫就都會了,所以背也要背會

所以本章以一個 demo 為例,來幫助大家理解攔截器登錄驗證控制

文章后面有源碼,可以下載下來運行一下

先來看看效果:

功能:

  • 當(dāng)你訪問首頁的時候,會有一個加載動畫,就是攔截器的功勞,并且首頁會有一個當(dāng)前登錄的用戶名,默認(rèn)是 wangcai,等你登錄成功后,會替換成你自己登錄的用戶名

  • 當(dāng)你沒有登錄的時候,可以訪問首頁和登錄頁,但是訪問不了個人中心 (Profile),當(dāng)你訪問個人中心,會給你自動跳轉(zhuǎn)到登錄頁

  • 當(dāng)你在登錄頁進(jìn)行登錄,如果用戶名輸入錯誤的話,會彈出錯誤信息

  • 當(dāng)你輸入正確的時候 (我設(shè)置了 Fan 為正確的用戶名),點擊登錄,登錄成功后,會自動給你跳轉(zhuǎn)到首頁

  • 并且登錄成功后,如果你再點擊想進(jìn)入登錄頁,是不行的,他會自動給你跳轉(zhuǎn)到首頁

  • 登錄成功后,就可以訪問 個人中心頁面

  • 如果你超過 20 秒 不對頁面進(jìn)行操作 (我設(shè)置的是 20 秒,可以自行設(shè)置),那么 token 會自動失效,那么你就訪問不了個人中心,你需要再次登錄

  • 如果你在 20 秒 之內(nèi),操作頁面的話,那么 token 的值是不會失效的,所以是不需要再次登錄的。也就是說,在 20 秒 之內(nèi),你每次進(jìn)行路由跳轉(zhuǎn)的時候,token 的值和時間就會自動重置,防止失效讓你再次登錄(總不能讓你看著看著突然讓你登錄)

  • 搜索公縱號:MarkerHub,關(guān)注回復(fù)[?vue?]獲取前后端入門教程!

下面就讓我們開始吧!!!(有關(guān)代碼的解釋說明已在代碼中注釋

案例

使用攔截器并封裝axios

新建一個 Vue 項目 (vue create demo)

刪去不必要的文件和代碼,經(jīng)典化代碼

安裝需要的依賴:

package.json文件部分代碼:

"dependencies": {"axios": "^0.19.0","body-parser": "^1.19.0","core-js": "^2.6.5","express": "^4.17.1","iview": "^4.0.0-rc.4","jsonwebtoken": "^8.5.1","vue": "^2.6.10","vue-router": "^3.0.3","vuex": "^3.0.1" },

在server.js文件中配置跨域,并書寫測試接口:

let express = require('express') let bodyParser = require('body-parser')let app = express()// 配置跨域 app.use((req, res, next) => {res.header("Access-Control-Allow-Origin", "\*");res.header("Access-Control-Allow-Methods", "GET,HEAD,OPTIONS,POST,PUT"),res.header("Access-Control-Allow-Headers", "Origin,X-Requested-With,Content-Type,Accept,Authorization")if (req.method.toLowerCase() === "options") {return res.end();}next(); })// 配置bodyparser app.use(bodyParser.json())app.get("/user", (req, res) => {//在請求數(shù)據(jù)時,要加一個動畫,為了測試,所以讓它時間長點,加了一個定時器setTimeout(() => {res.json({name: "wangcai"})}, 500) })app.listen(3000)

在router.js中配置路由:

routes: \[{path: '/',name: 'home',component: Home},{path: '/login',name: 'login',component: () => import('./views/Login.vue')},{path: '/profile',name: 'profile',component: () => import('./views/Profile.vue')} \]

因為項目中需要用到樣式什么的,這里我引入了iView,main.js代碼:

import Vue from 'vue' import App from './App.vue' import router from './router' import store from './store'//引入iView import iView from 'iview' import 'iview/dist/styles/iview.css'; Vue.use(iView)Vue.config.productionTip = falsenew Vue({router,store,render: h => h(App) }).$mount('#app')

因為項目中要用到加載數(shù)據(jù)的動畫,所以需要在store.js中的state中配置:

state: {//定義動畫是否顯示isShowLoading:false,username:'wangcai'},mutations: {//使動畫顯示showLoading(state){state.isShowLoading = true;},//使動畫隱藏hideLoading(state){state.isShowLoading = false;} },

在App.vue中配置跳轉(zhuǎn):

<template><div><div><router-link to="/">Home</router-link> |<router-link to="/login">Login</router-link> |<router-link to="/profile">Profile</router-link></div><router-view/></div> </template>

Home.vue代碼:

<template><div><h1>首頁面</h1></div> </template>

Login.vue代碼:

<template><div><i-input placeholder="請輸入用戶名..."></i-input><i-button type="primary">登錄</i-button></div> </template>

Profile.vue代碼:

<template> <div><h1>個人中心</h1> </div> </template>

然后在libs文件夾下面新建一個ajaxRequest.js文件,用來封裝我們自己的 axios 和 加載動畫 等

搜索公縱號:MarkerHub,關(guān)注回復(fù)[?vue?]獲取前后端入門教程!

import axios from 'axios' import store from '../store'//當(dāng)?shù)谝淮握埱髸r,顯示loading class AjaxRequest {//當(dāng)new的時候,調(diào)用這個方法constructor() {//請求的基礎(chǔ)路徑this.baseURL = process.env.NODE\_ENV == "production" ? "/" : "http://localhost:3000"this.timeout = 3000 //超時時間this.queue = {} //存放每一次的請求}//定義一個方法,把options展開merge(options) {return {...options,baseURL: this.baseURL,timeout: this.timeout}}//封裝一個攔截方法setInterceptor(instance, url) {//請求攔截,每次請求時,都要加上一個loading效果instance.interceptors.request.use((config) => {//每次請求時,都給他加一個Authorization頭,在JWT驗證時要用config.headers.Authorization = 'xxx'//第一次請求時,顯示loading動畫if (Object.keys(this.queue).length === 0) {store.commit('showLoading')}this.queue\[url\] = url;return config})//響應(yīng)攔截instance.interceptors.response.use((res) => {//刪除queue里面的鏈接,如果同一個按鈕,你一秒之內(nèi)點擊無數(shù)次,但是他只處理第一次操作delete this.queue\[url\]//隱藏loading動畫if (Object.keys(this.queue).length === 0) {store.commit('hideLoading')}//返回的結(jié)果return res.data})}request(options) {let instance = axios.create() //創(chuàng)建一個axios實例this.setInterceptor(instance, options.url) //設(shè)置攔截let config = this.merge(options)return instance(config) //axios執(zhí)行后,返回promise} }export default new AjaxRequest;

然后在api文件夾下新建一個user.js文件用來放用戶相關(guān)的調(diào)用接口的方法(當(dāng)你想要調(diào)用接口的時候,直接調(diào)用里面的方法就好):

import axios from '../libs/ajaxRequset'// 用戶相關(guān)的接口 export const getUser = ()=>{return axios.request({url:'/user',method:'get'}) }

修改Home.vue中的代碼:

<template><div><h1>首頁面</h1><p>當(dāng)前登錄的用戶名是{{$store.state.username}}</p></div> </template><script> //如果用export導(dǎo)出的話,要用這種形式,相當(dāng)于解構(gòu)賦值 import {getUser} from '../api/user' export default {name:'home',async mounted(){let r = await getUser()console.log(r);} } </script>

修改App.vue中的代碼(加動畫效果):

<template><div><Spin size="large" fix v-if="$store.state.isShowLoading">加載中...</Spin><div><router-link to="/">Home</router-link> |<router-link to="/login">Login</router-link> |<router-link to="/profile">Profile</router-link></div><router-view/></div> </template><style> #app {font-family: "Avenir", Helvetica, Arial, sans-serif;-webkit-font-smoothing: antialiased;-moz-osx-font-smoothing: grayscale;text-align: center;color: #2c3e50; } #nav {padding: 30px; }#nav a {font-weight: bold;color: #2c3e50; }#nav a.router-link-exact-active {color: #42b983; } </style>

運行效果:

使用 JWT

在server.js中新增代碼,使用 JWT,并寫好登錄和驗證的接口:

let jwt = require('jsonwebtoken')let secret = "xwc"//登錄的接口 app.post('/login',(req,res)=>{let {username} = req.body;if(username === 'Fan'){//登錄成功后返回一個tokenres.json({code:0,username:'Fan',token:jwt.sign({username:'Fan'},secret,{expiresIn:20 //表示token20秒過期})})}else{//登錄失敗res.json({code:1,data:'登錄失敗了'})} })//驗證token的接口 app.get('/validate',(req,res)=>{let token = req.headers.authorization; //我們會把token放到我們自己設(shè)置的http的頭authorization中,在這里可以直接拿到j(luò)wt.verify(token,secret,(err,decode)=>{ //驗證tokenif(err){return res.json({code:1,data:'token失效了'})}else{// token合法 在這里,需要把token的時效延長,//總不能我們看著看著突然讓我們重新登錄,token過期的意思是,你在這之間不進(jìn)行任何操作才會過期res.json({code:0,username:decode.username,token:jwt.sign({username:'Fan'},secret,{ //合法時,我們需要重新生成一個token,我們每次切換路由,都要重新生成一個tokenexpiresIn:20})})}}) })

接著在api文件夾下的user.js文件中添加登錄和驗證的方法:

import axios from '../libs/ajaxRequest'// 用戶相關(guān)的接口// 調(diào)獲取用戶信息的接口 向外暴露一個getUser方法 這個方法中調(diào)了接口 // 在組件中,就可以使用getUser,就相當(dāng)于調(diào)用接口 export const getUser = ()=>{return axios.request({url:'/user',method:'get'}) }// 再向外暴露一個登錄的方法,方法內(nèi)部也是調(diào)接口 // 在登錄組件中就可以調(diào)用Login方法,需要給方法傳遞一個用戶名 export const login = (username)=>{return axios.request({url:'/login',method:'post',data:{username}}) }//驗證token方法 export const validate = ()=>{return axios.request({url:'/validate',method:'get'}) }

接著我們在lib文件夾下新建一個local.js文件,用來設(shè)置或者獲取localStorage里的token:

//把獲得到的token存到localStorage里 export const setLocal = (key,value)=>{if(typeof value == 'object'){ //如果傳過來的是對象,則轉(zhuǎn)換成字符串value = JSON.stringify(value)}localStorage.setItem(key,value) //存到localStorage里 }//獲取localStorage里的token export const getLocal = (key)=>{return localStorage.getItem(key) }

然后修改store.js中的代碼:

import Vue from 'vue' import Vuex from 'vuex' import {login,validate} from './api/user' //必須用這種方式引入 import {setLocal} from './libs/local' //引入lib文件夾下的local.js文件中的setLocal方法(往localStorage里存放token)Vue.use(Vuex)export default new Vuex.Store({state: {//定義動畫是否顯示isShowLoading:false,username:'wangcai'},mutations: {//使動畫顯示showLoading(state){state.isShowLoading = true;},//使動畫隱藏hideLoading(state){state.isShowLoading = false;},//定義修改用戶名的方法setUser(state,username){state.username = username}},// actions存放接口的調(diào)用 dispatch actions里面放方法actions: {//這里面所有的方法都是異步的//登錄方法async toLogin({commit},username){let r = await login(username) //調(diào)用user.js中的login方法,也就是調(diào)用登錄接口// console.log(r);if(r.code === 0){ //登錄成功后會給你返回json數(shù)據(jù),里面有code//登錄成功了commit('setUser',r.username) //修改用戶名setLocal('token',r.token) //把得到的token存到localStorage里}else{// console.log('............');return Promise.reject(r.data); //如果失敗,返回一個promise失敗態(tài)}},//驗證token方法async validate({commit}){let r = await validate(); //調(diào)用user.js中的validate方法,也就是調(diào)用驗證接口if(r.code === 0){commit('setUser',r.username)setLocal('token',r.token) //我們說了,驗證通過,或者每次切換路由時,都要重新生成token}return r.code === 0; //返回token是否失效,true或者false}} })

修改Login.vue中的代碼:

<template><div><i-input v-model="username" placeholder="請輸入用戶名..."></i-input><i-button type="primary" @click="login()">登錄</i-button></div> </template><script> import {mapActions} from 'vuex' //使用vuex中的mapActions方法,不會的請參考我的文章vuex的使用方法 export default {data(){return{username:'' //定義一個用戶名}},methods:{...mapActions(\['toLogin'\]), //獲取store.js文件中的actions中的toLogin方法login(){// console.log(this\['toLogin'\](this.username));//使用獲取到的toLogin方法this\['toLogin'\](this.username).then(data=>{ //因為toLogin返回的是一個Promise,所以可以.thenthis.$router.push('/') //登錄成功,跳到首頁面},err=>{this.$Message.error(err)})}} } </script>

別忘了修改ajaxRequest.js文件,在請求攔截的時候,需要加個頭,前面我們寫死了,這里,要把 token 給他,然后每次路由跳轉(zhuǎn)訪問頁面的時候,都會帶上這個頭,用來驗證:

import {getLocal} from "../libs/local" //引入//請求攔截,每次請求時,都要加上一個loading效果 instance.interceptors.request.use((config) => {//每次請求時,都給他加一個Authorization頭,在JWT驗證時要用config.headers.Authorization = getLocal('token')//第一次請求時,顯示loading動畫if (Object.keys(this.queue).length === 0) {store.commit('showLoading')}this.queue\[url\] = url;return config })

接著在router.js中設(shè)置路由:
哪個頁面需要登錄后才能訪問的話,給這個路由添加meta,假如我的 個人中心頁面 需要登錄后才能訪問,那么我需要修改代碼:

{path: '/profile',name: 'profile',component: () => import('./views/Profile.vue'),meta:{needLogin:true} }

最后修改main.js中的代碼,當(dāng)切換路由時,進(jìn)行驗證:

import Vue from 'vue' import App from './App.vue' import router from './router' import store from './store'//引入iView import iView from 'iview' import 'iview/dist/styles/iview.css';Vue.use(iView)Vue.config.productionTip = false//每一次切換路由時,都執(zhí)行這個導(dǎo)航守衛(wèi) router.beforeEach(async (to,from,next)=>{let isLogin = await store.dispatch('validate') //判斷是否登錄了// needLogin 表示哪些路由需要在登錄條件下才能訪問console.log(to);let needLogin = to.matched.some(match=>match.meta.needLogin)if(needLogin){//需要登錄if(isLogin){//登錄過了next()}else{//沒有登錄next('/login')}}else{//不需要登錄if(isLogin && to.path === '/login'){ //如果你訪問login頁面,則給你跳到首頁面,因為不需要登錄next('/')}else{next()}} })new Vue({router,store,render: h => h(App) }).$mount('#app')

有關(guān)需要注意的點,都加注釋了,好好看注釋就行

至此,整個案例就結(jié)束了

總結(jié)

以上是生活随笔為你收集整理的Vue项目使用拦截器和JWT验证 完整案例的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。

欧美在线视频一区二区三区 | 亚洲国产日韩精品 | 亚洲欧洲精品久久 | 欧美性生活小视频 | 国产日韩在线看 | av在线播放快速免费阴 | 中文字幕在线观看免费 | 成人国产精品一区 | a级国产乱理伦片在线播放 久久久久国产精品一区 | 成人免费在线播放 | 91精品久久久久久 | 精品影院一区二区久久久 | 日日弄天天弄美女bbbb | av大全在线免费观看 | av在线色 | 免费看国产精品 | 五月婷婷六月丁香在线观看 | 黄色在线免费观看网站 | 激情欧美丁香 | 欧美日韩精品免费观看 | 天天爽夜夜操 | 久久免费精品视频 | 中文字幕国产视频 | 日日日爽爽爽 | 国语久久| 日日爱视频 | 五月天激情在线 | 中文字幕乱码电影 | 国产精品久久久久久久久久久久午夜片 | 天天干天天搞天天射 | 波多野结衣日韩 | 美女禁18| 日本99精品 | 美女视频永久黄网站免费观看国产 | 国产精品欧美久久久久无广告 | 国产一区私人高清影院 | www色com | 激情欧美xxxx | 亚洲国产精品成人精品 | 久久久久久久毛片 | 亚洲91网站 | 中文字幕第一页在线播放 | 一级理论片在线观看 | 毛片精品免费在线观看 | 三级av在线播放 | 欧美日韩一区二区三区视频 | 在线观看你懂的网址 | 欧美日韩中 | 日韩精品视频免费专区在线播放 | 色网站黄 | 国产91精品一区二区 | 亚洲综合在线五月 | 日本激情视频中文字幕 | 五月天国产 | 在线观看视频 | 黄色成人在线 | 午夜色站 | 免费看黄的| 午夜精品久久久久久99热明星 | 午夜精品一二区 | 日韩精品一区二区电影 | www.五月婷| 在线观看福利网站 | 韩日精品在线观看 | 六月天色婷婷 | 色视频在线免费观看 | 开心色激情网 | 亚洲精品欧美精品 | 久久a视频 | 色成人亚洲网 | 久久精品免费看 | 91看片网址 | 在线观看福利网站 | 国产精品毛片一区二区 | 国产成人黄色网址 | 日韩欧美黄色网址 | 99福利片 | 操操综合网 | 五月天综合激情 | 精品不卡视频 | 精品在线一区二区 | 三三级黄色片之日韩 | 日精品在线观看 | 黄色三级免费看 | 久久久久久免费毛片精品 | 成人在线观看日韩 | 在线三级播放 | 青青河边草免费观看 | 丰满少妇一级片 | 亚洲综合欧美精品电影 | 亚洲va欧美va | 精品国内 | 成人av中文字幕在线观看 | 色综合久久精品 | 天天色天天射综合网 | 91人人干| 玖玖在线播放 | av电影中文字幕 | 国产91精品久久久久 | 国产激情免费 | 日日爱网址 | 操综合 | 久久精品国产一区 | 久久精品这里热有精品 | 中文字幕在线影院 | 欧美一级免费在线 | 在线视频 91| 日韩在线视频网站 | 懂色av一区二区在线播放 | 国产裸体永久免费视频网站 | 久久亚洲二区 | 日韩特黄一级欧美毛片特黄 | 国产精品视频免费 | 国产精品 日韩 | 中文字幕一区二区三区乱码在线 | av黄色成人| 久久精品免费看 | 久草精品电影 | 国产在线精品一区二区不卡了 | 精品九九九| 国产精品视频一二三 | 中文字幕 第二区 | 涩涩网站在线观看 | 久久你懂得 | 亚洲五月婷婷 | 欧美一级片免费播放 | 精品99久久 | 狠狠色丁香久久婷婷综合五月 | 欧美亚洲国产精品久久高清浪潮 | 免费在线观看av网址 | 中文字幕在线网 | 亚洲三区在线 | 91桃色在线观看视频 | 蜜臀一区二区三区精品免费视频 | 91亚洲成人 | 97精品国产| 欧美天堂视频在线 | 高清精品在线 | 亚洲高清在线精品 | 91av原创 | 激情久久综合网 | 亚洲国产成人精品久久 | 国产一级片免费观看 | 国产一区二区三区高清播放 | 99热这里精品 | 久久国产精品免费看 | 91在线视频免费播放 | 夜添久久精品亚洲国产精品 | 国产精品精品 | 久久成人亚洲欧美电影 | 在线免费观看涩涩 | 操操操日日 | 美女免费视频网站 | 久久综合精品国产一区二区三区 | 亚洲国产字幕 | 色欧美成人精品a∨在线观看 | 婷婷色网 | 久久精品视频在线免费观看 | 91麻豆精品国产自产在线游戏 | 亚洲首页 | 久久久久在线 | 欧美狠狠色 | 久久官网 | 午夜久久久久久久久久影院 | 久久精品欧美一区二区三区麻豆 | 成人黄色av网站 | 久久综合久久久久88 | 在线观看网站你懂的 | 国产又粗又硬又长又爽的视频 | 欧美激情操 | 7777xxxx | 叶爱av在线 | 综合天堂av久久久久久久 | 亚洲成人av电影在线 | 精品国产成人在线 | 黄色一级免费电影 | 99资源网| 色婷婷成人网 | 色婷婷在线视频 | 精品不卡av | 国产精品永久久久久久久久久 | 日韩电影在线观看一区二区三区 | 狠狠操操| 久久精品久久久久久久 | 麻豆成人在线观看 | 久草精品资源 | 日本女人的性生活视频 | 国产这里只有精品 | 成人久久网 | 亚洲 精品在线视频 | www免费黄色 | 久艹视频在线观看 | 日韩精品一区二区三区外面 | 在线观看视频色 | 日本三级不卡 | 亚洲精品国产精品乱码不99热 | 免费看毛片在线 | 中文字幕在线视频国产 | 国产专区精品 | av大全在线观看 | 在线视频日韩一区 | 日韩欧美在线国产 | 日韩免费二区 | av免费看在线| 天天摸天天操天天爽 | 91亚洲视频在线观看 | 在线视频一二区 | 欧美在线你懂的 | 亚洲精区二区三区四区麻豆 | www免费网站在线观看 | 久久精品一级片 | 最新极品jizzhd欧美 | 亚洲黄色高清 | 国产精品久久精品 | 亚洲国产人午在线一二区 | 伊人久久国产精品 | 日韩丝袜在线观看 | 亚洲高清av在线 | 免费一级片视频 | 国产专区第一页 | 91最新地址永久入口 | 精品一区二区在线免费观看 | 中文字幕在线看视频 | 在线播放一区二区三区 | 中文字幕a在线 | 国产中文字幕精品 | 草久在线观看视频 | 国内成人av | 国产美女黄网站免费 | 三上悠亚一区二区在线观看 | 黄色精品国产 | 精品国产伦一区二区三区观看方式 | 久久久久久久久免费视频 | 天天久久夜夜 | 国产精品久久久久婷婷 | 9999毛片| 国产区欧美| www夜夜操com| 中文字幕中文字幕在线一区 | 国产手机在线观看视频 | 成人av一区二区兰花在线播放 | 99久久夜色精品国产亚洲96 | 91在线看视频 | 日韩v在线 | 欧美另类v | 综合色亚洲 | 日韩在线视频观看 | 成年人视频免费在线播放 | 日本中文在线播放 | 精品毛片在线 | 91在线免费观看国产 | 亚洲一区二区视频 | 国产美女视频免费 | 国产男男gay做爰 | 蜜臀av性久久久久蜜臀aⅴ流畅 | 精品日韩视频 | 亚洲黄色影院 | 91亚州 | 天天色宗合 | 麻豆传媒视频在线播放 | 国产精品大片免费观看 | 精品国产一区二区三区不卡 | 国产精品久久久久永久免费看 | 香蕉影院在线 | 91高清视频免费 | 久久精品视频网站 | 日韩欧美精品一区二区 | 免费日韩一区 | 91av在线免费播放 | 久在线观看视频 | www.啪啪.com| 在线视频观看亚洲 | 又污又黄的网站 | 999色视频 | 99在线看| 国产精品久久久久久久妇 | 91免费高清视频 | 丁香婷婷综合网 | 久久精品久久99 | 久久精品9 | 久久国产精品久久精品国产演员表 | 成人黄色国产 | 99综合视频| 黄色99视频 | 精品国自产在线观看 | 久久九九视频 | 国产精品嫩草影院9 | 亚洲精品在线电影 | 国产91亚洲 | av中文字幕网址 | 日韩精品视频免费 | 成人久久精品视频 | 天天综合色天天综合 | 色噜噜日韩精品一区二区三区视频 | 欧美日韩免费看 | 欧美日本不卡高清 | 亚洲成a人片在线www | 日本久久久久 | 四虎在线永久免费观看 | 亚洲va在线va天堂va偷拍 | 97超碰国产在线 | 激情视频网页 | 激情综合色综合久久 | 91久久一区二区 | 精品不卡av| 色婷婷av国产精品 | 精品久久久久久久久久久久久久久久久久 | 毛片网站免费在线观看 | 免费h精品视频在线播放 | 亚洲精品字幕在线观看 | 天天综合久久综合 | 日韩欧美在线高清 | 亚洲在线视频播放 | 欧美人操人 | 免费观看性生交大片3 | 中文字幕韩在线第一页 | 在线播放视频一区 | 五月婷婷开心中文字幕 | 久久99偷拍视频 | 精品日韩中文字幕 | 天天干天天操天天干 | 国产精品av免费观看 | 中文字幕高清免费日韩视频在线 | 午夜在线免费观看 | 色婷婷av一区 | 色av网站 | 国产成人精品一区一区一区 | 国产午夜三级一区二区三桃花影视 | 久久国产精品99久久久久久老狼 | 激情欧美xxxx | 五月婷婷欧美视频 | 日日草天天干 | 日韩网站免费观看 | 亚洲国产高清视频 | 在线观看日本高清mv视频 | 国产精品毛片完整版 | 亚洲欧洲xxxx | 三级av免费 | 久草在线视频国产 | 婷婷五情天综123 | 久久精品欧美 | 99精品网站| 国产黄色av网站 | 99久国产| 狠狠插天天干 | 婷五月激情 | 日韩综合视频在线观看 | 9ⅰ精品久久久久久久久中文字幕 | 日日干美女| 国产正在播放 | 日韩电影在线观看一区二区三区 | 久久另类视频 | 亚洲第一久久久 | 国产裸体永久免费视频网站 | 夜夜爽夜夜操 | 国产黄色观看 | 特级西西www44高清大胆图片 | 欧美色精品天天在线观看视频 | 日韩欧美xxx| 久久综合九色欧美综合狠狠 | 二区三区中文字幕 | 999精品视频 | 91社区国产高清 | av激情五月 | 91伊人影院 | 99精品亚洲 | 天天操天天爱天天爽 | 亚洲丁香日韩 | 91免费观看视频网站 | 婷婷深爱 | 波多野结衣网址 | 人人射av | 免费久久99精品国产婷婷六月 | 午夜色影院 | 中文字幕999 | 丁香在线观看完整电影视频 | 一级免费片| 精品1区2区3区 | 久久精品波多野结衣 | 91视频 - x99av | 国产美女视频免费 | 久草视频在线资源 | 成人在线观看你懂的 | av丁香花| 探花视频在线版播放免费观看 | 免费观看黄| 黄色在线观看免费网站 | 欧美日韩不卡一区 | 日本一区二区三区免费观看 | 天天·日日日干 | 99自拍视频在线观看 | 亚洲第一区精品 | 一级片视频在线 | 国产精品免费视频久久久 | 亚洲日本国产精品 | 国产精品成人免费 | 日韩特级片 | 亚洲一一在线 | 少妇性xxx | 久久人人97超碰精品888 | 精品国产成人在线影院 | 一二三区av | 99视频导航 | 日韩久久久久久久久 | 色婷婷亚洲婷婷 | 99自拍视频在线观看 | 激情五月六月婷婷 | 99久免费精品视频在线观看 | 欧美日韩国产三级 | 一区二区三区在线免费 | 亚洲精品久久久久中文字幕二区 | 亚洲女同ⅹxx女同tv | 天堂网一区二区三区 | 欧美日性视频 | 久久手机精品视频 | 操天天操 | 国产精品女同一区二区三区久久夜 | 久久精视频 | 91在线亚洲 | 91桃色免费视频 | 日本久久久久久久久久 | 伊人影院在线观看 | 欧美视频不卡 | 91视频国产免费 | 蜜臀av性久久久久av蜜臀妖精 | 一区二区久久久久 | 久久国产精品一国产精品 | 91视频在线国产 | 久久国产经典 | 综合网婷婷 | 99久久精品免费看国产免费软件 | 国产专区日韩专区 | 人人澡人人澡人人 | www狠狠 | 五月天久久综合网 | 亚洲男男gaygay无套 | 综合激情久久 | 91黄色成人| 久久精品99北条麻妃 | 日韩免费在线 | 色婷婷亚洲婷婷 | 日产乱码一二三区别免费 | 国产一级免费在线观看 | 国产成人精品午夜在线播放 | 精品日韩av | 91精品无人成人www | 久草剧场 | 99久久国产免费,99久久国产免费大片 | 99热这里只有精品免费 | 国产五月色婷婷六月丁香视频 | 成人av电影免费在线观看 | 国产精品久久久久久久久久久杏吧 | 日日操操 | 韩国精品福利一区二区三区 | 日韩精品中文字幕在线播放 | 婷婷五情天综123 | 日韩高清免费在线观看 | 久久在现视频 | 国产精品完整版 | 在线观看va | 在线观看亚洲国产 | 欧美成年性 | 午夜视频不卡 | 精品亚洲免费 | 国产成人综合图片 | 五月激情在线 | 在线观看日韩精品视频 | 天堂v中文| 美女网站色免费 | 色婷婷综合五月 | 99视频免费观看 | 欧美性精品 | 四虎在线免费观看视频 | 亚洲精品国偷拍自产在线观看 | 久久激情小视频 | 国产精品久久久久永久免费观看 | 视频二区在线 | 福利一区在线 | 99热日本 | 国产人成看黄久久久久久久久 | 在线观看中文字幕一区二区 | 91精品国产三级a在线观看 | 在线看一区二区 | 天天摸天天操天天舔 | 中文字幕一区三区 | 成人一区在线观看 | 黄色在线观看免费网站 | 成人影片在线免费观看 | 中文字幕在线第一页 | 国产日韩在线观看一区 | 亚洲欧洲一区二区在线观看 | 欧美一级片播放 | 91精品视频播放 | 久久新视频 | 日韩av在线看 | 日日日操操 | 久久综合成人 | 18国产精品福利片久久婷 | 亚洲国产欧美在线人成大黄瓜 | 久久久99精品免费观看 | 不卡av电影在线 | 成年人黄色大片在线 | 亚洲精品久久久蜜桃 | 欧美色图p | 亚洲精品视频在线播放 | 激情五月色播五月 | 午夜神马福利 | 亚洲aaa级| 国产成人三级 | 久久综合狠狠综合 | 国产电影黄色av | 久久久久久久久精 | 91麻豆国产福利在线观看 | 在线黄频| 91.麻豆视频| 亚洲精品tv久久久久久久久久 | 深爱激情五月婷婷 | 一区二区精品在线 | 亚洲一区二区三区精品在线观看 | 久草在线国产 | 狠狠躁日日躁狂躁夜夜躁av | 久久经典国产视频 | 日躁夜躁狠狠躁2001 | 国产一二区精品 | 天天草视频 | 亚洲精品成人在线 | av成人动漫 | .国产精品成人自产拍在线观看6 | 91精品啪在线观看国产81旧版 | 黄色小说免费观看 | 国产成人在线综合 | 青青河边草手机免费 | 亚洲黄网址 | 毛片黄色一级 | 在线看片91 | 国产精品毛片一区视频播 | 国产va饥渴难耐女保洁员在线观看 | 麻豆视频免费入口 | www天天干com | 亚洲国产美女久久久久 | 国产精品久久中文字幕 | 婷婷视频导航 | 午夜av免费在线观看 | 久久国产精品99国产 | 亚洲人成网站精品片在线观看 | 欧美一级电影在线观看 | www.xxxx变态.com | 欧美激情第28页 | 99电影456麻豆 | 日韩一区二区久久 | av福利免费 | 综合久久网站 | 国产91aaa| 欧美va天堂va视频va在线 | 探花国产在线 | 9992tv成人免费看片 | 狠狠躁日日躁狂躁夜夜躁av | 中文字幕在线观看1 | 国产一区欧美一区 | 国产一区二区精品在线 | 成人xxxx| 国产黄色片在线 | 伊人五月天 | 日韩av二区| 中文区中文字幕免费看 | 欧美一区二区在线刺激视频 | 欧美日本中文字幕 | 欧美福利精品 | 久久久久久久久国产 | 日本久久综合视频 | 在线观看日韩免费视频 | 中文伊人 | 色资源网免费观看视频 | 在线免费黄 | 亚洲97在线 | 日韩av一卡二卡三卡 | 麻豆va一区二区三区久久浪 | 在线直播av| 99久久99久久精品国产片 | 日本三级在线观看中文字 | 99视频在线观看免费 | 日韩在线网址 | 亚洲狠狠丁香婷婷综合久久久 | 精品国偷自产国产一区 | 高清av影院| 国产青春久久久国产毛片 | 欧美视频www| 97国产精品一区二区 | 91在线视频观看免费 | 亚洲欧洲一区二区在线观看 | 欧美成人aa| 久久视频精品在线观看 | 国产福利中文字幕 | 日韩成人黄色 | 91黄色在线视频 | 婷婷色在线观看 | 久久久午夜剧场 | 久久人网 | 91视频三区| 久久久国产精品久久久 | 国产剧情一区二区在线观看 | 黄色软件在线观看 | 免费视频在线观看网站 | 一区二区三区电影大全 | 国产精品一区在线播放 | 69国产成人综合久久精品欧美 | 国产精品18久久久久vr手机版特色 | av黄色在线观看 | 久久精品国产免费看久久精品 | 日本黄色免费大片 | 日本精品久久久一区二区三区 | 久久精品一二三区白丝高潮 | 国产亚洲视频在线免费观看 | 精品国产乱码久久久久 | 91免费版在线观看 | 中文国产在线观看 | 手机看片中文字幕 | av电影av在线 | 婷婷在线免费视频 | 久久久免费播放 | 玖玖视频网| 99久久日韩精品视频免费在线观看 | 天堂在线视频中文网 | 国产精品精品久久久 | av在线电影免费观看 | 国产成人久久 | 在线观看一 | 日韩欧美一区二区在线 | 国产手机在线 | 国产一级淫片免费看 | 国产一级a毛片视频爆浆 | 玖玖在线看 | 国产一区二区在线免费播放 | 一区二区三区韩国免费中文网站 | 99久久精品国产毛片 | 97精品国产一二三产区 | 精品欧美乱码久久久久久 | 亚洲国产精品日韩 | 国产精品美女免费看 | 欧美综合久久 | 色www免费视频 | 69国产在线观看 | 正在播放一区二区 | 久热久草| 狠狠色噜噜狠狠狠合久 | 91在线观看视频网站 | 久久久亚洲麻豆日韩精品一区三区 | 一个色综合网站 | 亚洲精品在线免费观看视频 | 99国产精品一区二区 | 亚洲一区美女视频在线观看免费 | 久久这里只有精品久久 | 日韩欧美国产成人 | 99超碰在线播放 | 91视频免费播放 | 一区二区三区在线观看免费 | 美女久久久久久久久久 | 91综合视频在线观看 | 1024手机基地在线观看 | 黄在线免费观看 | 不卡av免费在线观看 | 久久夜夜操 | 国产色爽 | 国产极品尤物在线 | 国产黄大片在线观看 | 国产日韩欧美在线看 | 天天干天天天 | 黄色网址中文字幕 | av高清免费在线 | 久久久久久久久久久久av | 91亚洲精品国偷拍自产在线观看 | 久久国产精品系列 | 色综合久久88 | 亚洲狠狠丁香婷婷综合久久久 | 在线精品视频免费播放 | 国产精品男女啪啪 | 欧美a级在线免费观看 | 三级毛片视频 | 亚洲免费av片 | av中文字幕在线播放 | 久久久久欧美精品999 | 免费看黄视频 | 国产成人av电影在线观看 | 久久综合欧美精品亚洲一区 | 国产亚洲精品久久久久久 | 日韩动漫免费观看高清完整版在线观看 | 天堂av观看 | 玖玖在线观看视频 | 麻豆视频一区 | 91黄色免费看 | 亚洲精品网站在线 | 96av麻豆蜜桃一区二区 | 麻豆传媒在线免费看 | 国产五月婷婷 | 最近高清中文字幕在线国语5 | 国产美女精品人人做人人爽 | 91亚洲免费 | 天天操天天射天天舔 | 久久国产高清视频 | 免费毛片一区二区三区久久久 | 黄色资源在线观看 | 亚洲精品一区二区三区新线路 | 黄在线免费看 | 久久这里有 | 国产一区av在线 | 日韩精品视频免费看 | 亚洲日本精品视频 | 亚洲 中文 欧美 日韩vr 在线 | 精品国产乱码久久久久久1区2匹 | 99热这里只有精品国产首页 | 六月色丁 | 欧美日韩在线观看视频 | 亚洲日韩欧美视频 | 97视频人人 | 久久久久久久久久久久久国产精品 | 日本在线观看视频一区 | 一区二区视频在线观看免费 | 天天射天天搞 | 五月天天av | 成人久久久精品国产乱码一区二区 | 国产三级视频 | 久久这里只有精品9 | 在线免费观看羞羞视频 | 国产日本三级 | 在线观看片 | 久久国产女人 | 国产一区二区在线免费播放 | 亚洲黄色激情小说 | 国产成人一区二区在线观看 | 免费大片黄在线 | 日韩一级片大全 | 日本久久久久久久久久久 | 亚洲精品黄色片 | 亚洲国产小视频在线观看 | 免费观看版| 精品国产中文字幕 | 在线看成人| 日韩欧美一区二区三区在线 | 亚洲aⅴ久久精品 | 91在线免费播放视频 | 国产精品欧美久久 | 久草免费福利在线观看 | av高清在线观看 | 偷拍精品一区二区三区 | 麻豆传媒一区二区 | 天天操人人干 | 精品福利网 | 黄色app网站在线观看 | 久久成人午夜 | 精品久久久久久综合日本 | 亚洲免费一级电影 | 日韩黄色软件 | 91在线视频在线 | av免费片 | 欧美黑人xxxx猛性大交 | 国产日产精品久久久久快鸭 | 伊人资源站 | 免费观看91 | 在线亚洲人成电影网站色www | 亚洲精品在线视频观看 | 国产剧情一区二区 | 黄色毛片在线看 | 日韩av电影中文字幕在线观看 | 久草电影免费在线观看 | 男女啪啪网站 | 久久国产精品免费观看 | 国产精品久免费的黄网站 | 国内外激情视频 | 亚洲精品xxxx| 色综合久久久久综合99 | 欧美日韩视频在线一区 | 久要激情网 | 日韩精品最新在线观看 | 中文字幕电影一区 | 成人黄在线 | 91视频啊啊啊 | 国产理论一区二区三区 | 岛国av在线不卡 | 成 人 黄 色 免费播放 | 久久国产精品久久久久 | 天堂在线视频免费观看 | 久久久久伦理电影 | 久久久久久免费视频 | 国产精品久久免费看 | 特级大胆西西4444www | 99日韩精品 | 日韩欧美视频在线观看免费 | 在线色亚洲 | 免费国产黄线在线观看视频 | 韩国av一区二区三区在线观看 | 久久污视频 | av线上免费看 | 日韩经典一区二区三区 | 中文字幕中文字幕中文字幕 | 日韩欧美69 | 狠狠狠狠狠干 | 免费av网址在线观看 | 久久丁香网 | 亚洲精品男人天堂 | 亚洲精品久久久久中文字幕m男 | 国产精品理论片 | 国产成人一区二区三区在线观看 | 日本少妇久久久 | 午夜黄色 | 天天操天天操 | 亚洲精品国产欧美在线观看 | 91人人揉日日捏人人看 | 欧美一区二区三区在线视频观看 | 偷拍精偷拍精品欧洲亚洲网站 | 亚洲午夜小视频 | www.av在线播放 | 国产伦精品一区二区三区照片91 | 免费av小说| 四虎影院在线观看av | 91在线看视频 | 日韩电影久久 | 又湿又紧又大又爽a视频国产 | 久久久久久久久免费 | 日韩在线看片 | 五月天六月丁香 | 久久久免费观看完整版 | 日本mv大片欧洲mv大片 | 伊人色**天天综合婷婷 | 日批视频| 日韩三级视频在线看 | 99色在线观看视频 | 欧美精品中文 | 国产午夜三级一区二区三 | 色中文字幕在线观看 | 久久爽久久爽久久av东京爽 | 一区二区三区免费看 | 成人av影视观看 | 九九一级片 | 日韩精品一区二区三区三炮视频 | 九九九热精品免费视频观看网站 | 91超碰在线播放 | 中文有码在线 | 国产精品麻豆三级一区视频 | 综合网天天射 | 亚洲成人黄色 | 99热国产在线 | 久久久91精品国产一区二区精品 | www成人av | 国产美女精品久久久 | 久久九九精品 | 亚洲精品黄色片 | 日韩高清在线不卡 | 国产特级毛片aaaaaa高清 | 午夜影院一级 | 日韩欧美精品一区二区三区经典 | 久久久69| 国产综合在线观看视频 | 色综合中文综合网 | 国产一二三四在线观看视频 | 337p日本大胆噜噜噜噜 | 美女黄视频免费看 | 麻豆传媒在线免费看 | 午夜视频久久久 | 日韩欧美一区二区在线观看 | 欧美国产日韩一区二区三区 | 69绿帽绿奴3pvideos | 五月婷婷中文网 | 国产亚洲精品久久久久5区 成人h电影在线观看 | 色婷婷导航 | 欧美久久久久久久久久久久 | 97在线观看免费观看高清 | 日韩精品字幕 | 免费av网址在线观看 | 国产在线色视频 | 黄色特级一级片 | 天天综合91 | 日韩电影中文字幕在线观看 | 在线成人高清电影 | 亚洲精品一区二区精华 | 久久 一区 | 一级免费片 | 亚洲最新毛片 | 亚洲国产欧美在线人成大黄瓜 | 亚洲天堂激情 | 91资源在线视频 | 91精品免费视频 | 亚洲国产成人高清精品 | 7777xxxx| 国产伦理一区 | 成全在线视频免费观看 | 国产又粗又猛又爽又黄的视频免费 | 伊人永久 | 亚洲精品mv在线观看 | 久久久精品网站 | 中文字幕资源站 | 欧美一级日韩免费不卡 | 国产一二三四在线观看视频 | 一级黄色在线免费观看 | 亚洲激情综合 | 国产一级精品视频 | 国产高清一级 | 久操97| 亚洲精品av中文字幕在线在线 | 亚洲精品免费在线观看 | 波多野结衣在线观看一区 | 日韩三级视频在线观看 | 99精品视频精品精品视频 | 成人91在线 | 不卡视频在线看 | 久久99免费观看 | 婷婷久久国产 | 四虎国产精品免费观看视频优播 | 中文字幕在线观看视频一区 | 日韩在线观看视频一区二区三区 | 欧美久久久久 | 亚洲精品视频在线免费播放 | 国产一区二区在线看 | 国产极品尤物在线 | 国产精品久久久久久麻豆一区 | 久草国产视频 | wwwww.国产| 中文字幕专区高清在线观看 | 精品欧美日韩 | 91色一区二区三区 | 国产最新视频在线 | 国产免码va在线观看免费 | 成年人国产在线观看 | 99久久精品免费看国产四区 | 国产精品久久久久久久av电影 | 久久精品福利视频 | www.福利| 中文不卡视频在线 | 日日爱视频 | 国内揄拍国产精品 | 国产 日韩 在线 亚洲 字幕 中文 | 免费a视频 | 精品国产乱码久久久久久1区二区 | 91av大全| 美女网站视频免费都是黄 | 国产精品久久精品国产 | 一区二区三区在线免费播放 | 久久久www| 久久这里只有精品首页 | 丝袜美腿在线播放 | 日韩电影黄色 | 欧美日韩国产在线精品 | 久久久久www | 久久国产精品免费视频 | 午夜视频在线观看一区 | 97天天综合网 | 精品国产中文字幕 | 99国产精品一区二区 | 成人性生交大片免费看中文网站 | 少妇超碰在线 | 亚洲国产精品成人精品 | 国产精品一区二区三区免费视频 | 欧美精品v国产精品 | 国产91全国探花系列在线播放 | 久久96国产精品久久99漫画 | 黄色www免费 | 亚洲欧美视频网站 | 免费观看性生活大片 | 欧美激情va永久在线播放 | 久操视频在线播放 | 日本黄色一级电影 | 伊人狠狠色丁香婷婷综合 | 成人免费观看完整版电影 | 国产精品久久久久久久av大片 | 一级成人免费视频 | 免费看av片网站 | 日韩在线观看精品 | 九月婷婷人人澡人人添人人爽 | 欧美91av| 91在线影视 | 91九色老| 极品久久久久久久 | 亚洲欧美乱综合图片区小说区 | 国产高清在线免费观看 | 免费观看一区二区 | 国产传媒中文字幕 | 久草在线一免费新视频 | www.久久视频 | 国产色黄网站 | www.久草视频 | 亚洲理论在线观看 | 亚州精品成人 | 91av播放| 黄色av电影| 日韩视频免费在线观看 | 51久久夜色精品国产麻豆 | 久久免费精品 | 高潮久久久久久 | 色资源中文字幕 | 亚洲 欧美 变态 国产 另类 | 人人dvd| 欧美在线观看视频 | 国产精品理论片在线观看 | 中文字幕国语官网在线视频 | 免费一级日韩欧美性大片 | 国产一区二区手机在线观看 | 中文字幕在线看视频 | 在线视频黄 | 日韩中文字幕一区 |