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

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 前端技术 > vue >内容正文

vue

vue项目token放在哪里_关于vue动态菜单的那点事

發布時間:2023/12/20 vue 42 豆豆
生活随笔 收集整理的這篇文章主要介紹了 vue项目token放在哪里_关于vue动态菜单的那点事 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

vue-element-admin4.0國內節點訪問地址:https://panjiachen.gitee.io/vue-element-admin-site/zh/

本此使用的是https://github.com/PanJiaChen/vue-element-admin/tree/i18n 國際化分支的版本。說是除了國際化其他都一樣。

本文主要介紹前臺動態的使用資源權限。

  • 后臺使用springboot2搭建項目就不說了,百度一下一大堆。
  • 前臺開發前需要安裝一下nodejs,這里注意一下nodejs和npm的版本要相互匹配,否則在編譯的時候會報錯。

打開項目后需要安裝一下依賴的模塊。

npm install

  • 1、全局請求配置的修改。

src/utils/request.js 當然也有用src/utils/request-axios.js的 修改方式大同小異zhe'li

import axios from 'axios'// import { MessageBox, Message } from 'element-ui'import { MessageBox, Message } from 'element-ui'import store from '@/store'import { getToken, removeToken } from '@/utils/auth' const qs = require('querystring') create an axios instanceconst service = axios.create({ baseURL: process.env.VUE_APP_BASE_API, url = base url + request url withCredentials: true, send cookies when cross-domain requests timeout: 5000, request timeout jsonData: false}) request interceptorservice.interceptors.request.use( config => { if (store.getters.token) { let each request carry token ['X-Token'] is a custom headers key please modify it according to the actual situation config.headers['X-Token'] = getToken() } if (config.method.toLowerCase() === 'get') { config.params = config.data } else if (config.method.toLowerCase() === 'post') { if (config.jsonData) { config.headers['Content-Type'] = 'application/json;charset=UTF-8' config.data = JSON.stringify(config.data) } else { config.headers['Content-Type'] = 'application/x-www-form-urlencoded;charset=UTF-8' config.data = qs.stringify(config.data) } } console.log(config) // for debug return config }, error => { // do something with request error console.log(error) // for debug return Promise.reject(error) }) // response interceptorservice.interceptors.response.use( /** * If you want to get http information such as headers or status * Please return response => response */ /** * Determine the request status by custom code * Here is just an example * You can also judge the status by HTTP Status Code */ r esponse => { const res = response.data // code==2000是業務邏輯成功,其他的返回code都是業務邏輯錯誤 if (res.code === 5002) { // to re-login // token過期或者密碼被修改了都需要重新獲取token MessageBox.confirm('You have been logged out, you can cancel to stay on this page, or log in again', 'Confirm logout', { confirmButtonText: 'Re-Login', cancelButtonText: 'Cancel', type: 'warning' }).then(() => { store.dispatch('user/resetToken').then(() => { location.reload() }) }) } else { return res } }, error => { // console.log('err' + error) // for debug Message({ message: error.message, type: 'error', duration: 5 * 1000 }) removeToken() if (error.response && error.response.status === 403) { this.$router.push(`/login?redirect=${this.$route.fullPath}`) } return Promise.reject(error) }) export default service

這個文件修改的主要是get、post請求傳遞參數的設置。

get使用params傳遞參數。post就data

還有就是form數據需要轉化,使用qs.stringify來轉換。轉化成A=1&B=2&c=3這樣的形式。

  • 2、后臺接口路徑的配置。

api請求都放在一個文件下面,這樣以后維護比較方便

至于請求后臺方法每個界面一個方法,例如這樣

頁面調用方法需要引用,類似這種

export default { name: 'user-list', components: { Pagination }, directives: { waves }, filters: { statusFilter(status) { const statusMap = { published: 'success', draft: 'info', deleted: 'danger' } return statusMap[status] }, typeFilter(type) { return calendarTypeKeyValue[type] } }, data() { return { tableKey: 0, list: null, total: 0, listLoading: true, listQuery: { page: 1, limit: 20, importance: undefined, title: undefined, type: undefined, username: undefined, deptname: undefined, rolename: undefined }, calendarTypeOptions, showReviewer: false, temp: { id: undefined, remark: '', username: '', rolename: '', deptid: '', roleid: '', password: '' }, dialogFormVisible: false, dialogCzmmVisible: false, dialogStatus: '', textMap: { update: '修改用戶', create: '新增用戶' }, pvData: [], rules: { username: [{ required: true, message: '必填項', trigger: 'change' }], loginname: [{ required: true, message: '必填項', trigger: 'change' }], deptid: [{ required: true, message: '必選項', trigger: 'change' }], roleid: [{ required: true, message: '必選項', trigger: 'change' }], password: [{ required: true, message: '必選項', trigger: 'change' }, { min: 6, max: 30, message: '長度在 6 到 30 個字符', trigger: 'change' }] }, downloadLoading: false, deptOptions: [], roleOptions: [] } }, created() { this.getList() }, methods: { getList() { this.listLoading = true fetchList(this.listQuery).then(response => { debugger this.list = response.attributes.list.list this.total = response.attributes.list.total this.listLoading = false }) }, handleFilter() { this.listQuery.page = 1 this.getList() }, resetTemp() { this.temp = { id: undefined, remark: '', username: '', rolename: '', deptid: '', roleid: '', password: '' } }, handleCreate() { this.resetTemp() this.dialogStatus = 'create' this.dialogFormVisible = true this.$nextTick(() => { this.$refs['dataForm'].clearValidate() }) fetchRoleOptions().then(response => { this.roleOptions = response.attributes.list }) var aa = { code: 'dept' } fetchDicePropOptions(aa).then(response => { this.deptOptions = response.attributes.list }) }, createData() { this.$refs['dataForm'].validate((valid) => { if (valid) { const tempData = Object.assign({}, this.temp) saveSysUser(qs.stringify(tempData)).then(() => { this.dialogFormVisible = false this.$notify({ title: '提示', message: '保存成功!', type: 'success', duration: 2000 }) this.getList() }) } }) }, handleUpdate(row) { this.temp = Object.assign({}, row) // copy obj this.temp.roleid = Number(this.temp.roleid) this.temp.deptid = Number(this.temp.deptid) this.dialogStatus = 'update' this.dialogFormVisible = true this.$nextTick(() => { this.$refs['dataForm'].clearValidate() }) fetchRoleOptions().then(response => { this.roleOptions = response.attributes.list }) var aa = { code: 'dept' } fetchDicePropOptions(aa).then(response => { this.deptOptions = response.attributes.list }) }, updateData() { this.$refs['dataForm'].validate((valid) => { if (valid) { const tempData = Object.assign({}, this.temp) updateSysUser(qs.stringify(tempData)).then(() => { this.dialogFormVisible = false this.$notify({ title: '提示', message: '保存成功!', type: 'success', duration: 2000 }) this.getList() }) } }) }, handleDelete(row, index) { deleteSysUser(row.id).then(response => { this.dialogFormVisible = false this.$notify({ title: '提示', message: '刪除成功!', type: 'success', duration: 2000 }) this.getList() }) }, handleReloadPassword() { if (this.temp.password === '') { this.$notify({ title: '提示', message: '密碼不能為空!', type: 'error', duration: 2000 }) return } var date = { id: this.temp.id, password: this.temp.password } reloadPassword(date).then(response => { if (response.code > 0) { this.dialogCzmmVisible = false this.$notify({ title: '提示', message: '重置密碼成功!', type: 'success', duration: 2000 }) } }) }, handleRefresh() { this.listQuery.username = '' this.listQuery.rolename = '' this.listQuery.deptname = '' }, formatJson(filterVal) { return this.list.map(v => filterVal.map(j => { if (j === 'timestamp') { return parseTime(v[j]) } else { return v[j] } })) }, indexMethod(index) { return index + 1 }, handleCz(row) { this.resetTemp() this.dialogCzmmVisible = true this.temp.id = row.id this.$nextTick(() => { this.$refs['dataFormCx'].clearValidate() }) } }}import qs from 'qs'

方法調用就像這種這么做就可以

3 、 登錄設置角色信息、過濾路由(根據角色動態的生成菜單)

  • store/user.js
import { loginByPwd, logout, getLoginUserInfo } from '@/api/user'import { getToken, setToken, removeToken } from '@/utils/auth'import router, { resetRouter } from '@/router' const state = { token: getToken(), name: '', avatar: '', introduction: '', roles: []} c onst mutations = { SET_TOKEN: (state, token) => { state.token = token }, SET_INTRODUCTION: (state, introduction) => { state.introduction = introduction }, SET_NAME: (state, name) => { state.name = name }, SET_AVATAR: (state, avatar) => { state.avatar = avatar }, SET_ROLES: (state, roles) => { state.roles = roles }} const actions = { // user login loginByPwd({ commit }, userInfo) { const { userName, passWord } = userInfo return new Promise((resolve, reject) => { loginByPwd({ userName: userName.trim(), passWord: passWord }).then(response => { if (response.code === 2000) { commit('SET_TOKEN', response.data) setToken(response.data) } resolve(response) }).catch(error => { reject(error) }) }) }, // get user info getLoginUserInfo({ commit, state }) { return new Promise((resolve, reject) => { getLoginUserInfo(state.token).then(response => { // const { data } = response // console.log('getLoginUserInfo', response) if (!response) { reject('Verification failed, please Login again.') } if (response.resultFlag) { commit('SET_ROLES', response.data.roleList) commit('SET_NAME', response.data.likeName) commit('SET_AVATAR', response.data.imgUrl) commit('SET_INTRODUCTION', '我是一個超級管理員哦') // 一個用戶可能有多個角色,這里返回的是角色的集合信息 // let allRole = response.data.roleList resolve(response) } else { console.error('獲取當前登錄用戶信息出錯了') } }).catch(error => { reject(error) }) }) }, // user logout logout({ commit, state }) { return new Promise((resolve, reject) => { logout(state.token).then(() => { commit('SET_TOKEN', '') commit('SET_ROLES', []) removeToken() resetRouter() resolve() location.reload() }).catch(error => { reject(error) }) }) }, // remove token resetToken({ commit }) { return new Promise(resolve => { commit('SET_TOKEN', '') commit('SET_ROLES', []) removeToken() resolve() }) }, // dynamically modify permissions changeRoles({ commit, dispatch }, role) { return new Promise(async resolve => { const token = role + '-token' commit('SET_TOKEN', token) setToken(token) const { roles } = await dispatch('getInfo') resetRouter() // generate accessible routes map based on roles const accessRoutes = await dispatch('permission/generateRoutes', roles, { root: true }) // dynamically add accessible routes router.addRoutes(accessRoutes) // reset visited views and cached views dispatch('tagsView/delAllViews', null, { root: true }) resolve() }) }} export default { // namespaced: true, state, mutations, actions}

這個文件就是登錄,成功后獲取當前用戶擁有的資源信息。

當然下載下來的這個文件菜單權限是寫死的是直接使用roles來做的判斷,就是在router.js文件中直接把菜單需要的角色設置在里邊。

缺點是添加了角色就要修改代碼打包發布。這簡直是災難。

所以這里面將原系統修改了一下實現動態菜單讀取,就好多了

vue-element-admin-mastersrcouterindex.jsimport Vue from 'vue'import Router from 'vue-router'Vue.use(Router)/* Layout */import Layout from '@/layout'/* Router Modules */// import componentsRouter from './modules/components'// import chartsRouter from './modules/charts'// import tableRouter from './modules/table'// import nestedRouter from './modules/nested'export const constantRoutes = [ { path: '/redirect', component: Layout, hidden: true, children: [ { path: '/redirect/:path*', component: () => import('@/views/redirect/index') } ] }, { path: '/login', component: () => import('@/views/login/index'), hidden: true }, { path: '/auth-redirect', component: () => import('@/views/login/auth-redirect'), hidden: true }, { path: '/', component: Layout, redirect: '/dashboard', children: [ { path: 'dashboard', component: () => import('@/views/dashboard/index'), name: 'Dashboard', meta: { title: 'dashboard', icon: 'dashboard', affix: true } } ] }]/** * asyncRoutes * the routes that need to be dynamically loaded based on user roles */export const asyncRoutes = [ /** when your routing map is too long, you can split it into small modules **/ // componentsRouter, // chartsRouter, // nestedRouter, // tableRouter, // 404 page must be placed at the end !!!]const createRouter = () => new Router({ // mode: 'history', // require service support mode: 'hash', scrollBehavior: () => ({ y: 0 }), routes: constantRoutes})const router = createRouter()// Detail see: https://github.com/vuejs/vue-router/issues/1234#issuecomment-357941465export function resetRouter() { const newRouter = createRouter() router.matcher = newRouter.matcher // reset router}export default router

首先先將靜態路由調好,一些常用的不需要權限的先加上

然后找到srcpermission.js

import router, { resetRouter } from '@/router'import store from './store'import { Message } from 'element-ui'import NProgress from 'nprogress' // progress barimport 'nprogress/nprogress.css' // progress bar styleimport { getToken } from '@/utils/auth' // get token from cookieimport getPageTitle from '@/utils/get-page-title'NProgress.configure({ showSpinner: false }) // NProgress Configurationconst whiteList = ['/login', '/auth-redirect'] // no redirect whitelistlet add1 = falseconst matched1 = falserouter.beforeEach(async(to, from, next) => { // start progress bar NProgress.start() // set page title document.title = getPageTitle(to.meta.title) // determine whether the user has logged in const hasToken = getToken() if (hasToken) { if (to.path === '/login') { // if is logged in, redirect to the home page next({ path: '/' }) NProgress.done() } else { // determine whether the user has obtained his permission roles through getInfo const hasRoles = store.getters.roles && store.getters.roles.length > 0 if (hasRoles) { next() } else { try { // get user info // note: roles must be a object array! such as: ['admin'] or ,['developer','editor'] // const { roles } = await store.dispatch('user/getInfo') // generate accessible routes map based on roles debugger // const fromPath = GetUrlRelativePath(window.location.href) if (!add1) { //注意在這里,將后臺拼裝好的功能菜單添加到當前路由中,切記一定要加變量控制 //不然會死循環,如果誰有好的解決辦法請回復我謝謝 // router.resetRouter() let accessRoutes = [] accessRoutes = await store.dispatch('permission/getAuthMenu') router.addRoutes(accessRoutes) add1 = true // hack method to ensure that addRoutes is complete // set the replace: true, so the navigation will not leave a history record next({ ...to, replace: true }) } else { // debugger // if (to.matched.length === 0) { // router.resetRouter() // let accessRoutes = [] // accessRoutes = await store.dispatch('permission/getAuthMenu') // router.addRoutes(accessRoutes) // next({ ...to, replace: true }) // } else { next() // } } } catch (error) { // remove token and go to login page to re-login await store.dispatch('user/resetToken') Message.error(error || 'Has Error') next(`/login?redirect=${to.path}`) NProgress.done() } } } } else { /* has no token*/ if (whiteList.indexOf(to.path) !== -1) { // in the free login whitelist, go directly next() } else { // other pages that do not have permission to access are redirected to the login page. next(`/login?redirect=${to.path}`) NProgress.done() } }})export function GetUrlRelativePath(url) { var arrUrl = url.split('//') var start = arrUrl[1].indexOf('/') var relUrl = arrUrl[1].substring(start) if (relUrl.indexOf('?') !== -1) { relUrl = relUrl.split('?')[0] } return relUrl}router.afterEach(() => { // finish progress bar NProgress.done()})import { asyncRoutes, constantRoutes } from '@/router'const state = { routes: [], roles: [], username: '', addRoutes: [], isChange: false}const mutations = { isChange: (state, isChanged) => { state.isChange = isChanged }, SET_USER: (state, username) => { state.username = username }, SET_ROLES: (state, roles) => { state.roles = roles }, SET_ROUTES: (state, routes) => { state.addRoutes = routes state.routes = constantRoutes.concat(routes) }}export function formatMenus(routes, data) { data.forEach(item => { const menu = {} menu.path = '/' + item.path menu.name = item.name menu.component = Layout menu.redirect = '/' menu.meta = { title: item.title, icon: 'excel', noCache: false } if (item.children.length > 0) { menu.children = [] item.children.forEach(item1 => { if (item1.name === 'examinationInfo') { const menu1 = {} menu1.path = 'detail' menu1.component = resolve => require(['@/views/' + item1.component + '/' + item1.path + '.vue'], resolve) menu1.name = 'examinationInfo' menu1.meta = { title: item1.title, noCache: false, activeMenu: '@/views/Examination/examination' } menu1.hidden = true menu.children.push(menu1) } else { const menu1 = {} menu1.path = item1.path menu1.component = resolve => require(['@/views/' + item1.component + '/' + item1.path + '.vue'], resolve) menu1.name = item1.name menu1.meta = { title: item1.title } menu.children.push(menu1) } }) } debugger routes.push(menu) })}const actions = { getAuthMenu({ commit }) { return new Promise(resolve => { getAuthMenu({}).then(response => { const data = response.attributes.menus const roles = response.attributes.rolesgetAuthMenu const username = response.attributes.username formatMenus(asyncRoutes, data) commit('SET_ROUTES', asyncRoutes) commit('SET_ROLES', roles) commit('SET_USER', username) // const isChanged = true // commit('isChange', isChanged) asyncRoutes.push({ path: '*', redirect: '/404', hidden: true }) //注意404界面一定要加載最后,不然會報錯 resolve(asyncRoutes) }) }) }}export default { namespaced: true, state, mutations, actions}import Layout from '@/layout'import { getAuthMenu } from '@/api/user'

在請求頭部如果需要添加cookie

總結

以上是生活随笔為你收集整理的vue项目token放在哪里_关于vue动态菜单的那点事的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

色视频在线免费观看 | 中文字幕一区二区三区精华液 | 欧美成年人在线观看 | 国产精彩在线视频 | 麻豆成人精品 | 五月天婷婷在线视频 | 国产精品一区二区三区四 | 国产区在线 | 超碰999 | 亚洲第一区在线观看 | 欧美日韩一区二区三区不卡 | 亚洲视频 在线观看 | 99热这里只有精品免费 | 五月综合色 | 日韩免费电影网站 | 日韩超碰 | 亚洲视屏| 日日夜夜综合 | av亚洲产国偷v产偷v自拍小说 | av免费网站在线观看 | 天天色天天射综合网 | av高清在线观看 | 日韩在线观看精品 | 亚洲人成免费网站 | av超碰免费在线 | 午夜久久久久久久久 | 黄色特级毛片 | 精品亚洲va在线va天堂资源站 | 99热999| 日韩在线电影观看 | 丝袜+亚洲+另类+欧美+变态 | 成 人 黄 色视频免费播放 | 亚洲精品综合一二三区在线观看 | 99色亚洲 | 国产精品亚 | 中文字幕av全部资源www中文字幕在线观看 | 中文字幕激情 | 精品嫩模福利一区二区蜜臀 | 91日韩在线播放 | 夜夜夜| 欧美日韩中字 | 色在线中文字幕 | 日韩高清免费在线 | 日本中文一级片 | 国产精品久久嫩一区二区免费 | 国产美女网 | 欧美精品乱码久久久久久按摩 | 美女视频一区 | av网站播放 | 一级理论片在线观看 | 九九日九九操 | 中文字幕人成乱码在线观看 | 欧洲一区二区在线观看 | 色综合久久久久综合体桃花网 | 久久黄色影视 | 国产高清久久久 | 婷婷在线免费 | 欧美激情精品久久久久 | 五月天亚洲综合 | 日日操天天操夜夜操 | 国产中文字幕亚洲 | 人人插人人搞 | 成人av免费在线 | 中文字幕丰满人伦在线 | 精品视频专区 | 成人免费在线观看av | 又爽又黄又刺激的视频 | 成年人看片网站 | 亚洲免费av片| 欧美国产一区在线 | 国产精品18久久久久久首页狼 | 免费在线观看污网站 | 日韩在线视频精品 | 在线观看日韩免费视频 | 亚洲黄色在线观看 | 玖玖视频精品 | 国产精品毛片久久久久久 | 手机色站| 国产一级片免费播放 | 国内精品在线一区 | 亚洲精品乱码久久久久久按摩 | 在线成人观看 | 1000部国产精品成人观看 | 九草在线观看 | 欧美在线观看视频一区二区三区 | 免费看片黄色 | 久久久久久综合 | 欧美在线日韩在线 | av高清免费 | 在线免费看片 | 国产亚洲综合精品 | 黄色不卡av | 国产精品久久久久永久免费看 | 丁香婷婷激情五月 | 亚洲二区精品 | 天堂资源在线观看视频 | 久久精品牌麻豆国产大山 | 亚洲视频久久久久 | 91九色视频网站 | 香蕉视频在线播放 | 国产亚洲精品女人久久久久久 | 2019精品手机国产品在线 | 在线观看日韩精品 | 97在线视频免费观看 | 成人一区二区三区在线 | 亚洲成人av电影在线 | 97国产精品 | 日本精a在线观看 | 免费看黄色毛片 | 在线电影播放 | 欧美精品久久久 | www.天天干.com | 精品国产电影 | 四虎影视成人永久免费观看视频 | 精品国产一区二区三区四 | 久久精品亚洲 | 国产精品免费视频网站 | 亚洲人人射 | 国产精品久久久久久999 | 91丨九色丨高潮 | 91亚洲欧美激情 | 国产自产高清不卡 | 天天天操天天天干 | 亚洲精品黄网站 | 日韩av高潮| 草久在线视频 | 免费观看的黄色片 | 天堂av在线网站 | 91电影福利| 久久久久久久18 | 日韩在线观看视频一区二区三区 | 色射爱| www.久久久com| 99r国产精品 | 美女av免费 | 日韩丝袜视频 | 婷婷色在线观看 | 一区二区三区在线免费播放 | 四虎永久免费在线观看 | 久久激情五月丁香伊人 | 国产精品久久久久久久久久久久久 | 国产欧美精品一区aⅴ影院 99视频国产精品免费观看 | 视频一区视频二区在线观看 | 成人av一区二区在线观看 | 精品国产成人在线 | 国内成人精品2018免费看 | 成人18视频 | 最近中文字幕在线 | 91片在线观看 | 久久久久成人精品亚洲国产 | 最新av网址在线观看 | 成人中文字幕+乱码+中文字幕 | 色综合激情网 | 色视频在线免费观看 | 五月婷婷视频在线 | 欧美日韩国产在线精品 | 91福利试看| 色婷婷在线观看视频 | 日韩在线观看电影 | 免费在线观看视频a | 黄色av高清 | 久日视频| av免费在线播放 | 91在线小视频 | 夜色在线资源 | 久草视频中文 | 久久国产电影 | 国内外激情视频 | 亚洲在线视频观看 | 91亚色视频| 日韩在线一区二区免费 | 中国一级片在线观看 | 免费网站v| 久久久国产在线视频 | 亚洲无吗视频在线 | 黄在线| 中文字幕欧美日韩va免费视频 | 欧美9999| 国产精品免费一区二区三区 | 国产一级二级三级视频 | 超碰97人人爱 | 国产精品一区二区三区四 | 亚洲成av人影片在线观看 | 在线观看视频一区二区三区 | 亚洲伊人天堂 | 国产黄色理论片 | 国产传媒一区在线 | 久久久激情视频 | 亚洲资源在线网 | av日韩av| 96亚洲精品久久 | 在线日韩三级 | 欧美日本在线观看视频 | 丁香视频免费观看 | 日本婷婷色| 超碰av免费| 欧美日韩国产在线一区 | 不卡的av在线播放 | 午夜精品久久久久久久99热影院 | 久久伦理网 | 91精品国产91久久久久福利 | 又色又爽又黄 | 狠狠躁夜夜躁人人爽超碰91 | 亚洲第一区在线播放 | 久久亚洲在线 | 国产精品爽爽爽 | 五月激情片 | 亚洲美女视频在线观看 | 精品自拍网 | 99精品视频在线观看 | 狠狠色丁香九九婷婷综合五月 | 7799av| 9ⅰ精品久久久久久久久中文字幕 | 操久久免费视频 | 国产精品美女网站 | 欧美日韩不卡在线视频 | 亚洲网站在线看 | 一区精品久久 | 国产69精品久久久久99 | 日韩二区在线播放 | 久久,天天综合 | 在线观看mv的中文字幕网站 | 亚洲理论电影网 | 成人网在线免费视频 | 四虎在线免费观看 | 亚洲少妇自拍 | 国产精品中文 | 国产精品麻豆欧美日韩ww | 激情深爱 | 日韩欧美精品一区二区三区经典 | 在线免费精品视频 | 成人动漫一区二区 | av高清一区 | 又紧又大又爽精品一区二区 | 日韩免费在线一区 | 成人免费视频网站在线观看 | 中文字幕 二区 | 日本一区二区免费在线观看 | 免费成人av| 91高清完整版在线观看 | 国产日韩精品一区二区 | 国产一级大片免费看 | 日韩成人免费在线电影 | 久久99精品国产 | 国产精品女教师 | 午夜视频在线观看网站 | 国产精品久久久久久久久久久免费看 | 午夜精品视频一区二区三区在线看 | av在线日韩 | 五月婷婷黄色网 | 久久视频国产精品免费视频在线 | 久久中文精品视频 | 欧美黄色高清 | 成 人 黄 色 视频播放1 | 最近更新中文字幕 | 在线精品在线 | 日韩成人av在线 | 在线亚洲免费视频 | 中文字幕专区高清在线观看 | 麻豆91在线 | 欧美亚洲国产一卡 | 国产精品99久久久久久久久久久久 | 欧美日韩三级 | 国产精品99久久久精品免费观看 | 最新国产中文字幕 | 色之综合网 | 日韩精品大片 | 国产美女免费观看 | 性色xxxxhd| 日韩1页| 在线观看免费视频你懂的 | 日韩综合在线观看 | 精品在线观看国产 | 婷婷综合久久 | 久久综合久色欧美综合狠狠 | av高清不卡 | 色综合天天做天天爱 | 国产精品高清免费在线观看 | 一本一本久久a久久精品综合小说 | 国产999视频在线观看 | 久久久久国产精品www | 成人a级黄色片 | 亚洲激情在线观看 | 在线色亚洲 | 亚洲免费观看在线视频 | 国产成人免费高清 | 国产亚洲永久域名 | 99精品久久久久久久久久综合 | 日韩av黄 | 日韩欧美一区二区不卡 | 免费在线视频一区二区 | 成人黄色大片在线免费观看 | 一级成人在线 | 又黄又爽的视频在线观看网站 | 国产精品一区二区久久久 | 国产一区精品在线观看 | 看污网站| 国产精品成久久久久 | 国产亚洲成av片在线观看 | 欧美日韩一区二区三区免费视频 | 国产亚洲日 | 久久久久www | 久久久久久久久久久久久国产精品 | 九九热精品在线 | 91精品亚洲影视在线观看 | 超碰免费久久 | 免费看亚洲毛片 | 天天操夜夜操天天射 | 久久综合五月天 | 久久高清免费观看 | 在线国产专区 | 国产精品一区二区在线免费观看 | 成人动漫一区二区 | 99久久久国产精品免费99 | 亚洲伊人婷婷 | 男女精品久久 | 久久久91精品国产 | 一区中文字幕在线观看 | 丁香激情综合久久伊人久久 | 麻豆视频免费在线 | 久久国内精品 | 久久电影国产免费久久电影 | av在线播放国产 | 日韩精品一区二区三区视频播放 | 国产一区在线免费观看 | 亚洲国产中文在线 | 激情综合狠狠 | 日韩免费av网址 | 日韩在线视频二区 | 激情五月婷婷综合 | 久久精品aaa| 久久精品欧美一区二区三区麻豆 | 最新影院 | 91在线免费公开视频 | 国产精品美女久久久久久久 | 亚洲欧洲日韩 | 一本一本久久a久久精品牛牛影视 | 日韩一区二区三区高清免费看看 | 国产精品中文 | 久久久久久久久久久免费视频 | 天天射天天舔天天干 | 91在线观看视频网站 | 欧美在线视频不卡 | 狠狠干婷婷色 | 国产剧情亚洲 | 欧美激情视频一二三区 | 91视视频在线直接观看在线看网页在线看 | 天天天插| 亚洲一级电影在线观看 | 日韩欧美高清在线 | 欧美在线不卡一区 | 夜夜看av | 久久精品国产精品亚洲精品 | 国产综合小视频 | 一区在线免费观看 | 亚洲精品国产第一综合99久久 | www国产亚洲精品久久网站 | 久久视频这里有久久精品视频11 | 丁香激情综合 | 日韩欧美综合精品 | 国产美女在线免费观看 | 欧美一区二区三区免费观看 | 国产一级电影网 | 亚洲人成人天堂h久久 | 一区二区三区中文字幕在线 | 在线国产视频一区 | 久草网站 | 国产一区视频导航 | 国产精品久久久久婷婷 | 在线免费观看的av网站 | 国产一级视屏 | 久久久精品国产一区二区三区 | 久久综合中文色婷婷 | 国产午夜三级一区二区三 | 99av国产精品欲麻豆 | 久久婷婷一区二区三区 | 五月婷婷操 | 亚洲精品字幕在线观看 | 国产国语在线 | 黄色三级免费网址 | 91福利视频一区 | 成人免费一级 | av在线等 | 天天干天天干天天操 | av在线精品 | 国产亚洲资源 | 久久九九影视网 | 亚洲春色成人 | 日韩毛片精品 | 在线观看亚洲国产 | 99热99热| 欧美精品做受xxx性少妇 | 欧美日韩国产mv | 亚洲精品高清视频 | 天天操天天射天天 | 伊人久久一区 | 成人观看| 色大片免费看 | 国产精品久久人 | 精品国产1区二区 | 欧美一级激情 | 国产成人精品午夜在线播放 | 久久久久久久久久网 | 天天操天天干天天爱 | 国产成人精品女人久久久 | 色综合婷婷久久 | 91爱爱免费观看 | 国产福利av在线 | 天天天天综合 | 韩国av永久免费 | 成人免费在线网 | 亚洲另类久久 | 四虎在线视频 | 黄色av观看 | 国产一区二区久久精品 | 免费看一级特黄a大片 | 国产成人在线播放 | 国产精品18久久久久白浆 | 麻豆视频在线观看免费 | 日韩中文字幕在线不卡 | 亚洲欧美在线观看视频 | 日韩中文字幕免费在线播放 | 麻豆视频在线免费 | 亚洲免费一级电影 | 久久久久亚洲最大xxxx | 国产分类视频 | 国产中文字幕亚洲 | 久久国语| 国产九色91 | 亚洲在线不卡 | 午夜久久久久久久久久久 | 日日夜夜狠狠干 | www黄色| 国产不卡在线观看 | 国产99久久久精品 | 国产成视频在线观看 | 亚洲欧美一区二区三区孕妇写真 | 国产视频一区在线播放 | 亚洲黄色片一级 | av888.com| 国产成人亚洲在线电影 | 免费在线观看污 | 久久精品首页 | 婷婷精品在线视频 | 成人av一区二区在线观看 | 精品女同一区二区三区在线观看 | 天堂网在线视频 | 在线观看黄色的网站 | 精品国产精品国产偷麻豆 | 国产精品h在线观看 | 成人国产综合 | 91av视屏| 国产aa免费视频 | 99精品免费网 | 久久新视频| 黄色国产大片 | 色天天久久 | 一区二区三区高清在线观看 | 亚洲激情婷婷 | 亚洲精品在 | 在线观看深夜福利 | 中文在线字幕免费观看 | 日本黄色免费大片 | 精品久久一区二区 | 91福利视频久久久久 | 中文字幕激情 | 毛片黄色一级 | 国产明星视频三级a三级点| 欧美日韩不卡在线观看 | 国产成人精品久 | 亚洲国产中文字幕在线观看 | 天天干天天看 | 国产高清成人 | 91精品一区二区三区蜜桃 | 天天干天天想 | av黄色免费看 | 欧洲精品久久久久毛片完整版 | 九色在线视频 | 久久视频在线观看中文字幕 | 美女性爽视频国产免费app | 久热av| 九九久久久久久久久激情 | 91中文在线观看 | 国产精品免费久久久久久久久久中文 | 奇米影视四色8888 | 欧美亚洲国产日韩 | 欧美视屏一区二区 | 美女黄久久 | 久久综合五月天婷婷伊人 | 久久久高清一区二区三区 | 丁香六月久久综合狠狠色 | a色网站| 国产午夜三级一区二区三桃花影视 | 国产手机视频在线 | 韩日三级在线 | 国产在线观看二区 | 欧美亚洲国产一卡 | 亚洲性xxxx| 欧美日韩在线看 | 久久久久久伊人 | 午夜av一区二区三区 | 亚洲h在线播放在线观看h | 久久午夜电影网 | av看片网 | 国产成年人av | 精品国内自产拍在线观看视频 | 亚洲 欧美 综合 在线 精品 | 午夜精品久久久久久久久久 | 欧美日本国产在线观看 | 人人cao| 欧美一级视频在线观看 | 国产精品第一页在线 | 成在线播放 | 久久在线视频精品 | 福利区在线观看 | 天天干com | 久久欧美在线电影 | 97在线影院| 成人免费在线电影 | av久久久久久| 波多野结衣电影一区 | 国内精品久久久久影院日本资源 | 国产一区欧美日韩 | 国产精品免费在线视频 | 亚洲国产视频在线 | 麻豆果冻剧传媒在线播放 | 国产精品网在线观看 | 欧美极品裸体 | 狠狠色丁香久久婷婷综 | 久草剧场| 毛片网免费 | 欧美国产精品一区二区 | 一区二区三区电影大全 | sesese图片 | 日韩a在线 | 国产999| 超碰人人在 | 99久久精品国产一区二区成人 | 综合激情婷婷 | 在线观看视频国产一区 | 在线三级av | 久草视频在线看 | 国产xxxxx在线观看 | 一级大片在线观看 | 黄色av网站在线观看免费 | 亚洲综合一区二区精品导航 | 日韩不卡高清视频 | 一级黄视频 | 超碰人人射 | 成人一区二区在线观看 | 日韩有码在线观看视频 | 久久综合国产伦精品免费 | 九九在线精品视频 | 五月天av在线 | 91九色蝌蚪视频在线 | 91九色在线视频 | 欧美乱码精品一区 | 9999精品| 国产成人综合精品 | 精品亚洲欧美一区 | 毛片网站观看 | 久久精品中文 | 天天天干天天射天天天操 | 色伊人网 | 国产成人久久精品77777综合 | 日韩天堂在线观看 | 99久久99久久综合 | 天天射天天艹 | 丁香视频 | 成人免费观看视频网站 | 国产片免费在线观看视频 | 国产精品色婷婷视频 | 超碰97免费观看 | 国产你懂的在线 | 日韩va欧美va亚洲va久久 | 日韩欧美高清在线观看 | 欧美坐爱视频 | 国产精品久久伊人 | 看av在线| 欧美成人一区二区 | 日韩精品不卡在线 | 久久福利 | 免费久久网 | 91插插视频| 日韩av三区 | 久久观看免费视频 | 激情婷婷久久 | 五月天婷亚洲天综合网精品偷 | 亚洲资源一区 | 色片网站在线观看 | 91成人精品国产刺激国语对白 | 日韩美女黄色片 | 在线日本看片免费人成视久网 | 国产精品高潮久久av | 欧美一区二区在线免费看 | 97精品视频在线 | 日韩免费专区 | 久久精品8 | 日韩欧美一区二区三区黑寡妇 | 成年人电影免费看 | 国产不卡精品 | 国产精品女同一区二区三区久久夜 | 亚洲性视频 | 久久黄色网页 | 免费看av在线 | 精品国产成人在线 | 精品久久久久久久久久久久久 | 久久久久久国产精品亚洲78 | 久久激情视频 久久 | 人人干干人人 | 正在播放久久 | 一本一本久久a久久 | 日韩精品短视频 | 天天噜天天色 | 国产日韩精品一区二区三区在线 | 国产精品在线看 | 日韩午夜电影网 | 久久看看 | 欧美整片sss | 奇米影视777影音先锋 | 欧美淫视频 | 日韩高清成人 | 狠狠狠综合| 亚洲在线a | 在线观看不卡视频 | 欧美午夜精品久久久久久孕妇 | 亚洲狠狠婷婷综合久久久 | 亚洲综合色视频在线观看 | 国产视频1区2区 | 最近最新mv字幕免费观看 | 青草视频网 | 亚洲激情综合网 | 国产福利在线免费观看 | 91精品视频网站 | 国产婷婷 | 狠狠激情中文字幕 | 91最新视频 | av三级av| 国产午夜小视频 | 国产精品不卡一区 | 91.精品高清在线观看 | 午夜.dj高清免费观看视频 | 天天干天天干天天操 | 天天爽夜夜爽精品视频婷婷 | 91av在线免费看 | 欧美999 | 国产精品高清一区二区三区 | 成年人电影免费看 | 日韩电影一区二区三区在线观看 | 在线观看国产麻豆 | 国产资源免费在线观看 | 日韩videos高潮hd | 最新日韩精品 | 午夜精品福利影院 | 亚洲精品综合在线观看 | 成人h视频 | 日韩视频在线一区 | 91黄在线看 | 91福利区一区二区三区 | 国产精品久久久久久久久久久久午夜 | 中文不卡视频 | 久草在线欧美 | 亚洲毛片在线观看. | 成人影片在线播放 | 国产高清免费av | 黄色91在线 | 一区二区精品久久 | 狠狠干夜夜 | 亚洲精品一区二区三区高潮 | 久久中文字幕在线视频 | 四虎影视久久久 | 久久亚洲二区 | www日韩在线| 日韩久久片| 久久伊人精品天天 | 久久这里只精品 | 在线观看黄色小视频 | av免费网站在线观看 | 午夜美女视频 | 亚洲动漫在线观看 | 色爱区综合激月婷婷 | 欧日韩在线| 一区二区av| 免费国产在线精品 | 黄色国产精品 | 色老板在线 | 六月婷色 | 国产美女永久免费 | 国产在线第三页 | 精品久久久久久亚洲 | 99久热精品| 97夜夜澡人人双人人人喊 | 在线a视频免费观看 | 三级黄色大片在线观看 | 中文字幕激情 | 丁香六月天婷婷 | 91超碰在线播放 | 国产高清久久久久 | 少妇bbw撒尿 | 亚洲理论片| 欧美一区二区三区在线 | 日韩在线观看网站 | 五月天最新网址 | 精品国产综合区久久久久久 | 国产精品免费在线观看视频 | 中文字幕亚洲精品在线观看 | 久久久久久麻豆 | 欧美另类美少妇69xxxx | 麻豆一区二区 | 人人插人人爱 | 亚洲成人黄色在线 | 亚洲一区网站 | 91在线视频免费 | 日韩理论电影网 | 国产在线观看av | 午夜视频不卡 | 成人av在线一区二区 | 亚洲精品a区 | 欧美精品一区二区在线播放 | 国产精品国产三级国产不产一地 | 在线观看播放av | 国产精品福利一区 | 91在线播放视频 | 中文字幕免费不卡视频 | 高清一区二区三区 | 国产精品18久久久久久不卡孕妇 | 国产原创在线视频 | 夜夜骑日日操 | 又湿又紧又大又爽a视频国产 | 欧美精品亚州精品 | 国产剧情一区在线 | 精品一区二区影视 | 国产成人a亚洲精品 | 2018精品视频| 国产又粗又猛又色 | 国产原创91| 国产高清视频免费 | 日韩中文三级 | 国内精品久久久久久中文字幕 | 深夜激情影院 | 丁香六月婷婷综合 | 一区二区三区精品在线 | 99久高清在线观看视频99精品热在线观看视频 | 综合色婷婷 | 免费在线播放视频 | av电影免费在线播放 | 999成人免费视频 | 日韩视频免费 | 黄色片网站免费 | 免费观看的黄色片 | 国产亚洲精品综合一区91 | 久久综合中文字幕 | 精品a级片 | 精品在线观 | 国产综合久久 | 国产69精品久久久久9999apgf | 精品国产一区二区三区四区vr | 香蕉视频色 | 亚洲乱码国产乱码精品天美传媒 | 蜜臀av性久久久久蜜臀av | 亚洲国产黄色片 | 日本久久免费电影 | 欧美在线aa | 久久av中文字幕片 | 五月天亚洲激情 | 亚洲国产欧洲综合997久久, | 日韩小视频网站 | 欧美成人视| 精品一区91 | 美女视频黄色免费 | 亚洲国产97在线精品一区 | 天天躁天天躁天天躁婷 | 婷婷色综合网 | av视屏在线| 99久久精品免费看国产 | 中文字幕久久网 | 中文字幕免费不卡视频 | 国产玖玖在线 | 奇米影视777四色米奇影院 | 色视频在线观看免费 | 久久久久久久久免费视频 | 国内视频1区 | 欧洲精品视频一区 | 日韩一区二区三免费高清在线观看 | 久久久久久久久久久久国产精品 | 91女神的呻吟细腰翘臀美女 | 国产黄色免费观看 | 日韩黄色免费电影 | 五月天色婷婷丁香 | 偷拍区另类综合在线 | av黄色成人 | 在线观看香蕉视频 | 狠狠色噜噜狠狠狠狠2021天天 | 成人全视频免费观看在线看 | 综合在线观看色 | 中文字幕在线观看视频一区 | 视频99爱| 国产精品高清一区二区三区 | 精品欧美小视频在线观看 | 91网站观看 | av电影在线观看 | 91精品办公室少妇高潮对白 | 中文字幕欧美日韩va免费视频 | 色姑娘综合网 | 国产精品久久久久久久久免费 | 久久亚洲成人网 | 久久久久久久久久久久国产精品 | 免费在线观看的av网站 | 亚洲自拍自偷 | 欧美黑吊大战白妞欧美 | 日韩精品中文字幕一区二区 | 日日干夜夜干 | 亚洲a资源| 97色狠狠 | 又黄又爽又色无遮挡免费 | 国产精品va最新国产精品视频 | 亚洲精品66| 色综合久久五月 | 精品国产精品一区二区夜夜嗨 | 五月婷婷视频在线观看 | 国产精品麻豆三级一区视频 | 午夜精品久久久久久久99 | 色999精品 | 69国产盗摄一区二区三区五区 | 国产黄色片久久久 | 欧美在线视频精品 | 免费一级日韩欧美性大片 | 成人wwwxxx视频| 国产精品久久久久久久久费观看 | 日韩免费视频网站 | 成人黄大片视频在线观看 | 日韩免费一级电影 | 69视频在线播放 | 国产做aⅴ在线视频播放 | 99精品观看 | 国产在线a不卡 | 国产午夜精品一区二区三区四区 | 成人av电影在线播放 | 国内99视频 | 西西人体4444www高清视频 | 国产精品久久久久9999吃药 | 免费看污污视频的网站 | 一区免费视频 | 久久超 | 欧美性免费 | 成人av网页 | 粉嫩一区二区三区粉嫩91 | 久草爱 | 久操视频在线 | 中文字幕在线影视资源 | 日韩高清无线码2023 | 丁香5月婷婷 | 成人在线观看免费 | 国产精品电影一区 | 中文字幕av一区二区三区四区 | 精品国产乱码久久久久久1区2匹 | 中文字幕 成人 | 一区二区理论片 | 波多野结衣电影久久 | 婷婷六月天天 | 亚洲免费视频在线观看 | 欧美视频在线观看免费网址 | 欧美va电影 | 婷婷久久网 | 成人免费网站在线观看 | 三级av小说| 久久爱导航 | 久久天堂网站 | 五月天久久婷婷 | adc在线观看 | 亚洲精品免费播放 | 99视频在线观看免费 | 亚洲专区在线播放 | 2020天天干夜夜爽 | 亚洲,国产成人av | 亚洲欧美日韩中文在线 | 亚洲乱亚洲乱亚洲 | 久久精品99国产国产 | 亚洲天天综合 | 中文 一区二区 | 天天操天天玩 | 五月开心网 | 国产福利电影网址 | 中文字幕欧美三区 | 综合黄色网 | 成人在线电影观看 | 婷婷丁香狠狠爱 | 99久久毛片 | 一区二区三区在线观看中文字幕 | 最新av网站在线观看 | 最新日韩在线观看 | 日韩欧美在线高清 | 超碰人在线 | 久久夜视频 | 久久成人高清视频 | 国产在线色站 | 成人高清在线 | 欧美日韩伦理在线 | 国产日韩精品欧美 | 不卡中文字幕在线 | 久草免费新视频 | 中文国产字幕 | 波多野结衣在线观看视频 | 五月激情姐姐 | 国产成人精品一区二区在线 | 国产视频亚洲精品 | 亚洲国产一区二区精品专区 | 天天天天爱天天躁 | 国产最顶级的黄色片在线免费观看 | 国产在线中文 | 久久精品一二三区白丝高潮 | 97超碰资源总站 | 97国产人人 | 日韩资源在线播放 | 看全黄大色黄大片 | 天天碰天天操 | 91九色蝌蚪国产 | 天天色综合三 | 日韩高清一 | 久久久久久久久亚洲精品 | 在线观av| 欧美久久久久久久久久久久 | 黄色1级毛片 | 国际精品网| 久久夜视频 | 日本最新高清不卡中文字幕 | 在线看国产视频 | 青青河边草观看完整版高清 | 久久精品一二区 | 亚洲狠狠操 | 免费在线观看av不卡 | 精品免费视频. | 成人av网站在线观看 | 免费日韩一区二区三区 | 国产精品ⅴa有声小说 | 国产99黄| 免费h漫在线观看 | 亚洲中字幕 | 碰超人人 | 99性视频| 丝袜美腿亚洲综合 | 夜色资源站国产www在线视频 | 丰满少妇在线观看资源站 | 日韩毛片久久久 | 国产成人精品久久久久蜜臀 | 成人黄色大片网站 | 久久99久久99精品免费看小说 | 国产精品一级视频 | www.天天草 | 亚洲欧美日韩在线看 | 曰韩精品| 免费在线观看黄网站 | 天天玩天天操天天射 | 欧美日韩视频观看 | 天天色天天色 | 国产成人黄色 | 麻豆国产视频下载 | 色婷婷激情电影 | 色小说在线 | 久久久久久久国产精品影院 | 免费网站在线观看人 | 国产精品毛片一区 | 91av网址| www.夜夜爱| 在线免费视频你懂的 | 中文字幕在线观看1 | 精品视频免费播放 | 亚洲美女免费视频 | 精品主播网红福利资源观看 | 久草视频中文 | 友田真希x88av | 久久少妇| 欧美日韩二三区 | 亚洲毛片视频 | 丝袜少妇在线 | 国产精品 国产精品 | 黄色成人av | 香蕉一区 | 岛国大片免费视频 | 高清av在线 | 欧美日韩在线播放一区 | 国产免费观看视频 | 国产乱码精品一区二区三区介绍 | 国产精品免费久久久久久 | 国产拍揄自揄精品视频麻豆 | 国产手机视频精品 | 一级黄色片在线观看 | 免费国产一区二区视频 | av官网在线 | 91麻豆精品国产自产在线游戏 | 亚洲在线看 | 免费在线观看一区二区三区 | 国产中文字幕视频在线观看 | aaa亚洲精品一二三区 | 91九色丨porny丨丰满6 | 国产夫妻性生活自拍 | 99 精品 在线| 欧美日韩性|