日韩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动态菜单的那点事的全部內容,希望文章能夠幫你解決所遇到的問題。

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

国产视频1区2区 | 丁香五月亚洲综合在线 | 免费国产一区二区 | 五月丁香 | 国产在线精品一区二区 | 久久国产二区 | 国产99黄| 九九在线免费视频 | 伊人狠狠| 成人h动漫在线看 | www免费在线观看 | 国产日韩欧美中文 | 国产成人精品一区二 | 欧美性护士| 啪嗒啪嗒免费观看完整版 | 国产成人精品不卡 | 亚洲视频www | 91精品网站在线观看 | 亚洲精品99久久久久中文字幕 | 麻豆国产精品一区二区三区 | 91av成人| 国产精品欧美久久久久无广告 | 成 人 黄 色 视频免费播放 | 看国产黄色大片 | 99视频精品视频高清免费 | 国产在线91精品 | 丝袜美腿在线视频 | 亚洲一区免费在线 | 91亚洲精品在线观看 | 日韩久久久久久久久久久久 | 国产精品视频永久免费播放 | 日韩精品电影在线播放 | 久久久香蕉视频 | 色福利网 | 亚洲国产精品久久久久 | 一级黄色在线视频 | 国产精品久久在线 | 久久午夜国产精品 | 久久人人插 | 91精品久久久久久粉嫩 | 成人av电影免费在线播放 | 在线视频你懂得 | 特黄色大片 | 在线亚洲成人 | 中文字幕欧美日韩va免费视频 | 日韩久久精品一区二区 | 国产色在线,com | 成人一级影视 | 免费在线国产视频 | 91最新地址永久入口 | 久草在线视频看看 | 日韩高清免费电影 | 日日干美女 | av黄色国产 | 99综合视频 | 国产精品成久久久久三级 | 国产精品婷婷午夜在线观看 | 99免费视频 | 香蕉视频免费在线播放 | 精产嫩模国品一二三区 | 日韩视频免费在线观看 | 狠狠躁18三区二区一区ai明星 | 国产精品午夜在线观看 | 免费成人av在线看 | 天天做天天射 | 夜夜操综合网 | av天天干 | 在线免费黄 | 国产在线观看免费 | 99视频在线| 国产免费一区二区三区最新6 | 国色天香永久免费 | 99视频久| 91日韩国产 | 美女视频黄,久久 | 又黄又爽又湿又无遮挡的在线视频 | 日韩在线国产 | 免费成人在线网站 | av中文天堂 | 在线视频观看成人 | 91福利社区在线观看 | 亚洲美女精品 | 久久av网址 | 成人理论电影 | 国产乱对白刺激视频不卡 | 超碰在线观看av | 久草影视在线 | 操处女逼| 国产人成看黄久久久久久久久 | 一区二区不卡视频在线观看 | 免费色视频 | 免费观看一区二区 | 香蕉影院在线播放 | 人人添人人 | 午夜精品久久久久久久99热影院 | 欧美狠狠操 | 国产精品亚洲片夜色在线 | 91福利社在线观看 | 亚洲国产字幕 | 欧美极品少妇xxxxⅹ欧美极品少妇xxxx亚洲精品 | 精品国产三级a∨在线欧美 免费一级片在线观看 | 国产999精品视频 | 久久久综合精品 | 欧美日韩高清在线 | 日韩中文字幕a | 欧美久久99| 精品在线观看一区二区 | 国产91全国探花系列在线播放 | 奇米影视8888 | 精品亚洲成a人在线观看 | 色丁香久久 | 免费看高清毛片 | 91精品少妇偷拍99 | 1000部18岁以下禁看视频 | 中文字幕亚洲综合久久五月天色无吗'' | 欧美va电影 | 午夜国产影院 | av电影中文 | 视频在线观看99 | 成人在线观看影院 | 色在线高清 | 国产破处在线视频 | 天天射天天拍 | 精品国产一区在线观看 | 99色婷婷| 狠狠色丁香婷婷综合久小说久 | 色婷婷国产精品一区在线观看 | 日日干网 | 最近中文字幕高清字幕在线视频 | 亚洲精品成人 | 精品久久久免费 | 日韩成人邪恶影片 | 国产亚洲人成网站在线观看 | 激情图片久久 | 欧美性色黄 | a黄色片| av在线免费播放 | 久久视频国产精品免费视频在线 | 天天干夜夜爱 | 中文字幕av在线电影 | 午夜精品一区二区三区在线播放 | 久久午夜电影 | 91久久影院| 欧美精品乱码久久久久久 | 久久试看| 天天综合网 天天 | 天堂av在线7 | 亚洲精品久久久久久国 | 国产91丝袜在线播放动漫 | 免费黄色在线网站 | 久久伊人婷婷 | 亚洲一区精品二人人爽久久 | 国产精品24小时在线观看 | 在线小视频你懂的 | 日韩欧美在线一区 | 2018亚洲男人天堂 | 国产999精品| 久久免费黄色 | 日韩大片在线播放 | 一区二区三区精品在线视频 | www黄com | 国产又粗又猛又黄又爽的视频 | 91成人精品观看 | 色综合久久综合中文综合网 | 欧美日韩精品在线视频 | 在线观看成人国产 | 丁香高清视频在线看看 | 欧美激情第十页 | 国产成人av电影在线观看 | 国产美女无遮挡永久免费 | 国产一区二区成人 | 久久久资源网 | 天天色天天操综合 | 九月婷婷人人澡人人添人人爽 | 狠狠干天天 | 日日干网址 | 九九视频这里只有精品 | 91成人在线视频 | 91精品视频播放 | 中文一区在线 | 在线观看午夜 | www.亚洲精品视频 | 亚洲理论片在线观看 | 黄色小说免费在线观看 | 91精品国产一区二区在线观看 | 日韩欧美一区二区三区免费观看 | 国产免费资源 | 亚州欧美视频 | 91免费版在线 | 久久久久久久久电影 | 国产高清久久 | 亚洲精品午夜国产va久久成人 | 91精品视频一区二区三区 | 免费在线看v | 99久视频| 久久色中文字幕 | 国产一级在线免费观看 | 婷婷深爱网 | 高潮久久久 | 久久人人爽av | 亚洲精品影院在线观看 | 日韩理论片在线观看 | 1000部国产精品成人观看 | 成人看片 | 国产精品99久久久久久人免费 | 亚洲国产成人久久综合 | 欧美极品少妇xxxxⅹ欧美极品少妇xxxx亚洲精品 | 国产香蕉视频在线观看 | 久久国产美女视频 | 天天操天天操天天操天天操天天操天天操 | 最新av在线播放 | 五月天色网站 | 在线观看亚洲专区 | 91原创在线观看 | 在线看黄色的网站 | 免费视频一级片 | 免费91麻豆精品国产自产在线观看 | 欧美黄色高清 | 91福利试看 | 国产 日韩 在线 亚洲 字幕 中文 | 福利一区二区三区四区 | 精品国产乱码久久久久久三级人 | 久久成人免费视频 | 最近日本mv字幕免费观看 | 成年人在线免费看视频 | 久久国产免 | av免费片| 精品成人国产 | 色激情五月 | 国产一区二区视频在线 | 日日干夜夜干 | 玖玖玖精品 | 美女久久 | 天天插天天| 激情av资源网 | 亚洲最新av在线网站 | 五月激情丁香婷婷 | 中文字幕无吗 | 91视频观看免费 | 高清精品视频 | 国产精品美女毛片真酒店 | 国产在线观看免费观看 | 91免费网址 | 亚洲精品大全 | 五月天开心| 91av九色| 激情久久小说 | 国产精品 国内视频 | 日韩xxxxxxxxx| 99免费在线视频观看 | 九九精品久久 | 午夜在线观看一区 | 在线观看免费成人 | 成人a在线观看高清电影 | 欧美一区二区免费在线观看 | 日韩欧美在线影院 | 麻豆一二三精选视频 | 91成人免费在线视频 | 中文字幕日韩无 | 国语黄色片 | 99热.com| 国产专区精品视频 | 奇米777777 | 日韩在线短视频 | 亚洲一级电影视频 | 日日夜夜中文字幕 | 91福利区一区二区三区 | 91麻豆视频| 国产成人免费av电影 | 亚洲精品视频第一页 | 国产成人精品国内自产拍免费看 | 91精品国产麻豆 | 欧美日韩精品国产 | 日韩电影一区二区三区 | 99综合影院在线 | 免费av网站观看 | av片中文字幕| 色窝资源 | 精品国产亚洲日本 | 国产免费人人看 | 日本xxxxav| 亚洲精品综合一二三区在线观看 | 激情在线网站 | 99久久综合狠狠综合久久 | 成人av影视在线 | 亚洲精品久久久久久久不卡四虎 | 日韩伦理片一区二区三区 | 在线天堂中文www视软件 | av一级在线观看 | 欧美精品一区二区在线观看 | 一级片在线 | 久久久午夜视频 | 激情视频一区二区三区 | a天堂一码二码专区 | 国产精品久久久久久久久久久久午夜 | 久久久久国产精品免费 | 国产精品网红直播 | 精品在线视频一区二区三区 | 最新av中文字幕 | 亚洲国产色一区 | 插久久| 一区二区三区精品久久久 | 在线之家免费在线观看电影 | 四虎在线视频免费观看 | aaa日本高清在线播放免费观看 | 国产在线精品一区二区 | 国产一线天在线观看 | 国产日本高清 | 在线观看视频一区二区 | 超碰97av在线 | a黄色片| 免费国产黄线在线观看视频 | 亚洲精品国产免费 | 国产在线精品一区二区 | 亚洲精品大全 | 91视频91色| 天天色天天艹 | 久久久一本精品99久久精品66 | 黄色在线观看免费网站 | 欧美一级日韩免费不卡 | 日批在线观看 | 国产伦精品一区二区三区高清 | 亚洲小视频在线 | 免费在线观看日韩视频 | 九九热免费精品视频 | 成人h视频在线播放 | 久久综合九色综合久99 | 天天躁日日躁狠狠 | av一级一片| 欧美一区二区免费在线观看 | 色综合天天色综合 | 欧美色黄 | 国产高清视频免费最新在线 | 久久久免费少妇 | 成人黄色av免费在线观看 | 免费高清av在线看 | 99精品国产福利在线观看免费 | 一本一道久久a久久综合蜜桃 | 欧美日韩一区二区久久 | 国产精品久久久久久久久久不蜜月 | 国产一区精品在线 | 香蕉视频在线免费 | jizz18欧美18 | av在线播放国产 | 成年人在线播放视频 | 成人黄色大片在线免费观看 | 免费av在线网站 | 综合天天 | 国产精品s色 | 国产精品久久久久久久久久了 | av电影不卡在线 | 麻豆视频观看 | 91资源在线视频 | 正在播放国产一区 | 五月婷婷激情 | www.国产在线视频 | 成人a免费| 干 操 插| 五月激情久久久 | 日日干天天插 | 在线免费看片 | 日韩精品首页 | 日韩中文字幕a | 在线免费观看黄 | 成人国产精品 | 精品美女久久久久 | 国产精品久久久久久久久毛片 | 久久精品久久99精品久久 | 国产视频1 | 日韩专区在线 | 国产精品一区二区免费视频 | 久久精品国产第一区二区三区 | 五月婷婷在线视频观看 | 91高清一区| 天堂在线视频免费观看 | 久久综合亚洲鲁鲁五月久久 | 黄色一级大片在线免费看产 | 91激情在线视频 | 日韩精品欧美专区 | 丁香激情网 | 日本久久久久久科技有限公司 | 91黄色小视频 | 99热在线国产 | 午夜精品久久久久久久99婷婷 | 精品国产99 | 成人在线免费小视频 | 久久免费看a级毛毛片 | 超碰97公开 | 开心色停停 | 在线视频你懂 | 人人爽人人爽人人爽人人爽 | 日韩免费一区二区在线观看 | 久久人人爽人人爽 | 中文不卡视频 | 中文字幕免费高清在线 | 五月天激情视频 | 一级性av| 成人精品视频 | 日韩xxxx视频 | www.伊人网 | 美女网站视频一区 | 国产精品va视频 | 国产涩涩网站 | 黄色www免费 | 亚洲人成综合 | 国产a级免费 | 国产美女精彩久久 | 久久国产精品免费一区二区三区 | 亚洲国产精品99久久久久久久久 | 亚洲一区二区三区在线看 | 波多野结衣最新 | 91香蕉视频| 亚洲黄色软件 | 亚洲一级二级 | 日韩精品视频免费 | 免费黄色一区 | 蜜臀aⅴ国产精品久久久国产 | 日韩视频三区 | 黄色的视频 | 欧美一级欧美一级 | 亚州黄色一级 | 免费观看v片在线观看 | 天天草天天草 | 日本中文字幕高清 | 色之综合网 | 在线观看国产一区 | 久久精品视频免费播放 | 99精品热| 中文视频在线 | 夜夜澡人模人人添人人看 | 亚洲综合黄色 | 波多野结衣一区二区三区中文字幕 | 麻豆久久久久 | 在线观看色视频 | 国产精品区免费视频 | 日韩一级电影在线观看 | 亚洲精品美女久久久 | 91免费在线看片 | 亚洲一区二区三区毛片 | 三上悠亚一区二区在线观看 | 国产精品你懂的在线观看 | 久久午夜影视 | 久久艹国产| 青草视频在线免费 | 久久的色| 国产精品入口麻豆 | 久久久国产精品免费 | 国产精品美女999 | 天天躁天天操 | 久久一区二区三区国产精品 | 国产精品亚洲综合久久 | 中文字幕第一 | 日韩欧美视频免费观看 | 天堂素人在线 | 亚洲成av人电影 | 9ⅰ精品久久久久久久久中文字幕 | 88av视频 | 日日噜噜噜噜夜夜爽亚洲精品 | 色资源网免费观看视频 | 亚洲精品99久久久久中文字幕 | 国产精品ⅴa有声小说 | 久草www | 99免费在线 | 久久伊人精品一区二区三区 | 人人射网站 | 青青河边草观看完整版高清 | 综合天堂av久久久久久久 | 91精品国产网站 | 久久久久激情 | 又色又爽又激情的59视频 | av免费观看高清 | 天天干天天插伊人网 | 天天干天天搞天天射 | 五月婷香 | 久久影视网 | 欧美久久九九 | 天天干夜夜爽 | 日韩av在线资源 | 久日精品 | 国内精品久久久久久久久 | 久久午夜免费视频 | 欧美激情综合五月色丁香小说 | 中文字幕一区二区三区乱码在线 | 天天射天天干天天插 | 国产精品免费人成网站 | 国产在线播放观看 | 国产一二区在线观看 | 亚洲精品乱码久久久久久写真 | 国产女做a爱免费视频 | 国产色爽 | 亚洲精品影院在线观看 | av免费网站观看 | 久久国产女人 | 爱干视频 | 中文字幕色婷婷在线视频 | 97超碰伊人 | 91久久久久久久一区二区 | 国产精品高潮呻吟久久av无 | 中日韩在线视频 | 在线观看中文字幕亚洲 | 国产四虎在线 | 久久精品国产成人精品 | 麻豆视频在线播放 | 久久国产精品一二三区 | 97视频播放| 波多野结衣在线观看一区二区三区 | 久久久久久不卡 | 久久精品国产免费 | 久久精品4| 欧美日韩网址 | 国产精品亚洲视频 | 国产在线资源 | 91丨九色丨高潮丰满 | 超碰在线94 | 成年人黄色免费网站 | av软件在线观看 | 亚洲日本三级 | 免费高清看电视网站 | 91最新在线视频 | 久久精品中文字幕一区二区三区 | 亚洲小视频在线观看 | 视频国产在线 | 在线观看完整版 | bbbbb女女女女女bbbbb国产 | 精品一二三四五区 | 久插视频 | 亚洲日本色 | 欧美嫩草影院 | 国产精品久久久久久模特 | 欧美精品三级在线观看 | av片子在线观看 | 精品久久久久久综合日本 | 日韩国产在线观看 | 国产成人精品午夜在线播放 | 最近中文字幕高清字幕免费mv | 成人av免费看 | 超碰在线色 | 欧美成人亚洲成人 | 欧美va日韩va | 在线黄色毛片 | 超碰av在线播放 | 国产在线a不卡 | 综合五月婷婷 | 在线观看中文字幕一区二区 | 国产九九九精品视频 | av观看免费在线 | 国产美女精品人人做人人爽 | 97av视频在线| 日日摸日日| 岛国大片免费视频 | 日韩av在线一区二区 | 日韩成人xxxx | 国产黄色精品 | www.人人干 | 999久久久久 | 97超视频在线观看 | 在线日韩三级 | 99精品国产一区二区三区不卡 | 99在线视频观看 | 国产视频美女 | 在线亚州| 8x成人在线| 成人97视频一区二区 | 国产精品久久久久国产精品日日 | 国产色视频123区 | 久久久久精| 中文在线a∨在线 | 国产又粗又硬又长又爽的视频 | 热久久电影 | 操操操日日日 | 免费涩涩网站 | 伊人色**天天综合婷婷 | 久久在线免费视频 | 中文字幕 国产精品 | 日本久久久久久久久久久 | 精品一区二区在线看 | 婷婷在线免费视频 | 五月天天天操 | 久久一区二区三区超碰国产精品 | 久久久久免费 | www狠狠| 亚洲干 | 亚洲永久国产精品 | 天堂av观看 | 亚洲欧美视频 | 亚洲区精品视频 | 2000xxx影视| 亚洲 欧美日韩 国产 中文 | 亚洲综合情 | 亚洲最大的av网站 | 91久久奴性调教 | 国产在线精品福利 | 天天操人| av丝袜在线 | 国产综合久久 | 日日夜夜操操操操 | 91欧美视频网站 | av夜夜操| 久久久久| 久久亚洲福利 | 久久久免费毛片 | 你操综合 | 国产精品一区二区中文字幕 | 日韩大片在线 | 日日天天狠狠 | 欧美精品三级 | 国产成人精品在线观看 | 国产精彩在线视频 | av免费在线看网站 | 亚洲不卡123 | www.香蕉视频在线观看 | 美女视频久久 | 久久精品99国产精品亚洲最刺激 | 免费人成在线观看网站 | 亚洲免费公开视频 | 日韩免费三级 | 精品免费视频. | 欧美精品免费在线 | 亚洲精品一区二区精华 | 国产精品青青 | 久久成人精品电影 | 欧美亚洲国产精品久久高清浪潮 | 狠狠色婷婷丁香六月 | 国产69久久久 | 国产成人久久精品77777综合 | 免费看的毛片 | 美女黄视频免费 | 香蕉蜜桃视频 | 成人黄色小说视频 | .国产精品成人自产拍在线观看6 | sesese图片| 久久国产午夜精品理论片最新版本 | 国产精品成人免费精品自在线观看 | 久久资源在线 | 色在线亚洲 | 婷婷久久五月 | 91中文字幕在线视频 | 一级欧美黄 | 欧洲精品二区 | 国产夫妻性生活自拍 | 久久国产一区二区 | 久久福利在线 | 成人高清在线 | 国产精品99久久久久 | 三级视频国产 | 国产免费作爱视频 | 午夜12点 | 久久99久久久久久 | 正在播放国产精品 | 国产在线观看av | 中文字幕亚洲精品在线观看 | 免费在线观看黄网站 | 国产精品热视频 | 久久国产精品二国产精品中国洋人 | 91理论片午午伦夜理片久久 | 欧美a级片免费看 | 国产成视频在线观看 | 狠狠色丁香婷婷综合久久片 | 91精品欧美| 777视频在线观看 | 久久中文字幕导航 | 精品久久久久免费极品大片 | 久久久国产精品一区二区三区 | 成人激情开心网 | 91看片在线看片 | 久久成人资源 | 欧美日韩在线视频一区二区 | 日本中文字幕系列 | avwww在线观看 | 91pony九色丨交换 | 国产国语在线 | 人人爱人人添 | 日日爽天天 | 西西www4444大胆视频 | 日韩在线国产精品 | 中文字幕精品视频 | 久久国产精品一二三区 | 91精品国产自产在线观看永久 | 碰超在线| 亚洲欧美日韩在线一区二区 | 三级黄色欧美 | 日本免费久久高清视频 | 亚洲 精品在线视频 | 国产涩涩网站 | 国产一级一片免费播放放 | 国产专区一 | 天天射天天操天天色 | 中文字幕一区二区三区在线视频 | 日b黄色片 | 婷婷九月丁香 | 色噜噜色噜噜 | 欧美另类色图 | 天天做天天射 | 在线观看免费版高清版 | 欧美精品久久久久a | 国产伦理一区 | 人人澡超碰碰97碰碰碰软件 | 性色xxxxhd | 91最新地址永久入口 | 国产黄色观看 | 欧美久久九九 | 欧美午夜精品久久久久 | 久久视频网 | a在线播放 | 成人免费视频网 | 91免费高清观看 | 在线观看激情av | 婷婷色综合| 国产精品国内免费一区二区三区 | 国内精品99 | 亚洲成色777777在线观看影院 | 久久国产高清 | 香蕉网在线 | 国产福利免费看 | 亚洲高清在线观看视频 | 国产免费三级在线观看 | 久久久久激情 | av中文字幕在线播放 | 西西444www大胆高清视频 | 日韩免费视频网站 | 日韩色av色资源 | www.夜夜爱| 国产精品国产三级国产aⅴ入口 | 亚洲精品一区二区三区高潮 | 一区二区三区久久精品 | 视频三区在线 | 免费在线观看午夜视频 | 日b视频国产 | 国产在线视频导航 | japanese黑人亚洲人4k | 天天操夜操 | 国产麻豆成人传媒免费观看 | 99视频在线观看一区三区 | 亚洲精品一区二区三区在线观看 | 中文字幕人成乱码在线观看 | 在线视频你懂得 | 亚洲精品久久久久久中文传媒 | 蜜臀精品久久久久久蜜臀 | 欧美成人中文字幕 | 91成人看片 | 91九色性视频 | av黄网站 | 91九色精品国产 | 国产成人久久77777精品 | 国产亚洲精品v | 日韩精品免费一区 | 久久99日韩| 精品国产1区2区3区 国产欧美精品在线观看 | 四虎影视成人精品 | 精品日韩在线 | 国产一级大片在线观看 | 91免费试看 | 国产91精品一区二区麻豆亚洲 | 日韩成人精品在线观看 | 亚洲伦理一区二区 | 免费观看黄色av | 日韩在线观看的 | 天堂av在线免费观看 | 婷婷午夜天 | 日韩精品免费专区 | 少妇av网 | 亚洲黄色av| 久草在线观看资源 | 一区二区三区四区五区在线 | 国产视频高清 | 国产999久久久 | 99精品免费在线 | 午夜性福利| 久久老司机精品视频 | 久久99电影 | 亚洲高清视频在线播放 | 成人久久免费视频 | 国产乱码精品一区二区蜜臀 | 免费 在线 中文 日本 | www最近高清中文国语在线观看 | 91精品一区二区在线观看 | 免费黄色看片 | 日日射天天射 | 91精品国产麻豆国产自产影视 | 国产成人av在线影院 | 亚洲成人免费在线 | 人人看人人草 | 人人爽网站 | 伊人黄色网 | 国产男女爽爽爽免费视频 | 中文字幕在线有码 | 天天射射天天 | 久久一线 | 在线小视频你懂得 | 久久公开视频 | 探花视频在线版播放免费观看 | 91在线看黄 | 午夜三级影院 | 亚洲精品国产成人av在线 | 精品久久久久久综合日本 | 国产精品ⅴa有声小说 | 国产精品mv | 婷婷深爱 | 狠狠综合 | 日本久久久久久久久久 | 成人avav | 成人免费观看a | 国产日韩精品在线观看 | 欧美午夜激情网 | 国产视频久久久 | a天堂一码二码专区 | 热久久99这里有精品 | 亚洲视频在线免费看 | 97超碰在线久草超碰在线观看 | 在线观看日韩视频 | 成年人电影毛片 | 免费在线观看a v | 欧美一级免费 | 中文字幕 婷婷 | a在线观看视频 | 中文字幕永久 | 97爱| 亚洲少妇久久 | 激情网五月婷婷 | 九九久久国产精品 | 国产精品中文字幕在线观看 | 国产精品福利无圣光在线一区 | 国产亚洲视频系列 | 欧美坐爱视频 | 另类五月激情 | 精品播放 | 欧美性色综合网站 | 91最新国产 | 日韩免费一区 | 亚洲欧美经典 | 久久久蜜桃 | 国产97视频在线 | 国产激情免费 | 最近2019年日本中文免费字幕 | 粉嫩av一区二区三区四区在线观看 | 国产一级黄色片免费看 | 91私密视频 | 久久国产精品99久久久久久丝袜 | 国产97碰免费视频 | 日日夜夜免费精品视频 | 91午夜精品| 成人免费在线播放视频 | 成年人免费看片网站 | www久久久 | 精品在线观看一区二区 | 免费观看成人网 | 91成人网在线观看 | 一区二区免费不卡在线 | 国产精品免费观看久久 | 中文字幕在线视频一区二区 | a视频免费 | 国产一级黄 | 91av99| 激情视频网页 | 青青草国产精品视频 | 久久久在线观看 | 在线国产黄色 | 亚洲欧洲av在线 | 免费网站观看www在线观看 | 欧美成年网站 | 久久综合狠狠综合久久狠狠色综合 | 日本黄色免费看 | 国产精品24小时在线观看 | 国产一级电影免费观看 | www.888.av| 亚洲欧美国产精品18p | 91九色pron| 精品国产免费久久 | 亚洲国产精品500在线观看 | 青青河边草免费视频 | 中日韩在线视频 | 色婷婷电影| 国产精品九九久久久久久久 | 国产第一页在线播放 | 欧美美女激情18p | 亚洲精品456在线播放 | 99热高清| 黄色三级视频片 | 亚洲在线国产 | 国产精品中文久久久久久久 | 国产黄色一级片 | 97**国产露脸精品国产 | mm1313亚洲精品国产 | 亚洲片在线观看 | 亚洲最新毛片 | 不卡av电影在线 | 天天综合网 天天 | 欧美精品一区在线 | 免费看精品久久片 | 中文字幕 二区 | 免费日韩一区二区 | 九九九九九九精品任你躁 | 久久精品视频播放 | 久久综合久色欧美综合狠狠 | 2019免费中文字幕 | 免费a级黄色毛片 | 亚洲精品在线二区 | 日韩视频在线不卡 | 久久精品久久99精品久久 | 久久99国产一区二区三区 | 久久久久草 | 国产在线欧美 | 在线中文字幕网站 | 97在线视频观看 | 日韩视频免费观看高清完整版在线 | 久久国产精品色av免费看 | 亚洲免费a| 中文字幕 欧美性 | 香蕉久草在线 | 欧美精品久久天天躁 | 成人全视频免费观看在线看 | 国产色视频网站 | 久久99国产一区二区三区 | 国产精品理论片在线播放 | 日本久久成人中文字幕电影 | 日韩免费视频播放 | 操操操日日日干干干 | 中文字幕电影在线 | 久久久综合精品 | 激情小说久久 | 天堂麻豆| 狠狠色丁香婷婷综合 | 国产一在线精品一区在线观看 | 日日夜夜天天 | 操一草| 伊人成人久久 | 天天鲁一鲁摸一摸爽一爽 | 日韩视频中文字幕 | 91久久久久久久一区二区 | 欧美成人视| 亚洲免费观看在线视频 | 成人免费观看av | 成人高清在线 | 国内免费久久久久久久久久久 | 在线观看一级视频 | 国产精品入口a级 | 国产精品综合av一区二区国产馆 | 九九热免费在线观看 | www.国产在线视频 | 日韩91精品 | 中文字幕精品久久 | 日本精品久久久久中文字幕5 | 亚洲精品久久激情国产片 | 男女视频91 | 97国产大学生情侣酒店的特点 | 亚洲视频免费在线观看 | 国内精品亚洲 | 亚洲国产欧美一区二区三区丁香婷 | 日韩av不卡在线播放 | 天堂网一区二区三区 | 日韩视频一区二区在线观看 | 欧美精品一区二区在线观看 | 涩涩在线 | 99久久精品免费看国产 | 一区二区三区在线免费观看 | 久久艹精品 | 综合网成人 | 国产美女无遮挡永久免费 | aaa毛片视频 | 黄色小说免费在线观看 | av在线成人| 精品国产欧美 | 欧美日韩在线看 | 五月婷婷六月综合 | 又黄又刺激又爽的视频 | 久久精品a | 狠狠的操你 | 狠狠黄 | 亚洲国产成人高清精品 | 狠狠干在线播放 | 亚洲va天堂va欧美ⅴa在线 | 久久国产精品视频观看 | 国产在线更新 | 欧美日韩国产在线精品 | 美女免费视频网站 | 在线观看免费国产小视频 | 久久1区| 一本一道久久a久久精品 | 成人在线视频论坛 | 五月综合激情网 | 日韩v在线91成人自拍 | 国产色黄网站 | 亚洲无人区小视频 | 特级毛片aaa | 亚洲精品午夜久久久久久久 | 丁香资源影视免费观看 | 日韩理论影院 | 国产美女精品在线 | 91视频免费 | 成人午夜网址 | 国产精品mm | 日韩欧美网站 | 黄色av成人在线 | 国产精品成人免费精品自在线观看 | 在线观看中文字幕一区 | 国产精品入口a级 | 亚洲九九精品 | 色婷婷av国产精品 |