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

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 >

vue中Axios的封装和API接口的管理

發布時間:2023/12/16 29 豆豆
生活随笔 收集整理的這篇文章主要介紹了 vue中Axios的封装和API接口的管理 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

一、axios的封裝

在vue項目中,和后臺交互獲取數據這部分,通常使用的是axios庫,它是基于promise的http庫,可運行在瀏覽器端和node.js中。它有很多優秀的特性,例如攔截請求和響應、取消請求、轉換json、客戶端防御XSRF等。

安裝

npm install axios; // 安裝axios復制代碼

引入

一般在項目的src目錄中,新建一個request文件夾,然后在里面新建一個http.js和一個api.js文件。http.js文件用來封裝我們的axios,api.js用來統一管理我們的接口。

?

環境的切換

項目環境可能有開發環境、測試環境和生產環境。通過node的環境變量來匹配默認的接口url前綴。axios.defaults.baseURL可以設置axios的默認請求地址就不多說了。

?

設置請求超時

通過axios.defaults.timeout設置默認的請求超時時間。例如超過了10s,就會告知用戶當前請求超時,請刷新等。

axios.defaults.timeout = 10000;

post請求頭的設置

post請求的時候,需要加上一個請求頭,所以可以在這里進行一個默認的設置,即設置post的請求頭為application/x-www-form-urlencoded;charset=UTF-8:

axios.defaults.headers.post['Content-Type'] = 'application/x-www-form-urlencoded;charset=UTF-8';

?

請求攔截

在發送請求前可以進行一個請求的攔截,為什么要攔截呢,攔截請求是用來做什么的呢?比如,有些請求是需要用戶登錄之后才能訪問的,或者post請求的時候,需要序列化我們提交的數據。這時候,我們可以在請求被發送之前進行一個攔截,從而進行我們想要的操作。

請求攔截

?

這里說一下token,一般是在登錄完成之后,將用戶的token通過localStorage或者cookie存在本地,然后用戶每次在進入頁面的時候(即在main.js中),會首先從本地存儲中讀取token,如果token存在說明用戶已經登陸過,則更新vuex中的token狀態。然后,在每次請求接口的時候,都會在請求的header中攜帶token,后臺人員就可以根據你攜帶的token來判斷你的登錄是否過期,如果沒有攜帶,則說明沒有登錄過。這時候或許有些小伙伴會有疑問了,就是每個請求都攜帶token,那么要是一個頁面不需要用戶登錄就可以訪問的怎么辦呢?其實,你前端的請求可以攜帶token,但是后臺可以選擇不接收啊!

響應的攔截

?

?

?

?

響應攔截器很好理解,就是服務器返回給我們的數據,在拿到之前可以對他進行一些處理。例如上面的思想:如果后臺返回的狀態碼是200,則正常返回數據,否則的根據錯誤的狀態碼類型進行一些我們需要的錯誤,其實這里主要就是進行了錯誤的統一處理和沒登錄或登錄過期后調整登錄頁的一個操作。

要注意的是,上面的Toast()方法,是我引入的vant庫中的toast輕提示組件,你根據你的ui庫,對應使用你的一個提示組件。

封裝get方法和post方法

常用的ajax請求方法有get、post、put等方法,相信小伙伴都不會陌生。axios對應的也有很多類似的方法。但是為了簡化我們的代碼,還是要對其進行一個簡單的封裝。下面主要封裝兩個方法:get和post。

get方法:

通過定義一個get函數,get函數有兩個參數,第一個參數表示我們要請求的url地址,第二個參數是我們要攜帶的請求參數。get函數返回一個promise對象,當axios其請求成功時resolve服務器返回 值,請求失敗時reject錯誤值。最后通過export拋出get函數。

?

post方法:

原理同get基本一樣,但是要注意的是,post方法必須要使用對提交從參數對象進行序列化的操作,所以這里通過node的qs模塊來序列化我們的參數。這個很重要,如果沒有序列化操作,后臺是拿不到你提交的數據的。這就是文章開頭import QS from 'qs';的原因。

?

這里有個小細節說下,axios.get()方法和axios.post()在提交數據時參數的書寫方式還是有區別的。區別就是,get的第二個參數是一個{},然后這個對象的params屬性值是一個參數對象的。而post的第二個參數就是一個參數對象。兩者略微的區別要留意哦!


axios的封裝基本就完成了,下面再簡單說下api的統一管理。

整齊的api就像電路板一樣,即使再復雜也能很清晰整個線路。上面說了,我們會新建一個api.js,然后在這個文件中存放我們所有的api接口。

首先我們在api.js中引入我們封裝的get和post方法

/**
* api接口統一管理
*/
import { get, post } from './http'

現在,例如我們有這樣一個接口,是一個post請求:

http://www.baiodu.com/api/v1/users/my_address/address_edit_before

我們可以在api.js中這樣封裝:

export const apiAddress = p => post('api/v1/users/my_address/address_edit_before', p);

我們定義了一個apiAddress方法,這個方法有一個參數p,p是我們請求接口時攜帶的參數對象。而后調用了我們封裝的post方法,post方法的第一個參數是我們的接口地址,第二個參數是apiAddress的p參數,即請求接口時攜帶的參數對象。最后通過export導出apiAddress。

然后在我們的頁面中可以這樣調用我們的api接口:

?

其他的api接口,就在pai.js中繼續往下面擴展就可以了。友情提示,為每個接口寫好注釋哦!!!

api接口管理的一個好處就是,我們把api統一集中起來,如果后期需要修改接口,我們就直接在api.js中找到對應的修改就好了,而不用去每一個頁面查找我們的接口然后再修改會很麻煩。關鍵是,萬一修改的量比較大,就規格gg了。還有就是如果直接在我們的業務代碼修改接口,一不小心還容易動到我們的業務代碼造成不必要的麻煩。

最后把完成的axios封裝代碼。

/**axios封裝
* 請求攔截、相應攔截、錯誤統一處理
*/
import axios from 'axios';import QS from 'qs';
import { Toast } from 'vant';
import store from '../store/index'
// 環境的切換
if (process.env.NODE_ENV == 'development') {
axios.defaults.baseURL = '/api';
} else if (process.env.NODE_ENV == 'debug') {
axios.defaults.baseURL = '';
} else if (process.env.NODE_ENV == 'production') {
axios.defaults.baseURL = 'http://api.123dailu.com/';
}
// 請求超時時間
axios.defaults.timeout = 10000;
// post請求頭
axios.defaults.headers.post['Content-Type'] = 'application/x-www-form-urlencoded;charset=UTF-8';
// 請求攔截器
axios.interceptors.request.use(
config => {
// 每次發送請求之前判斷是否存在token,如果存在,則統一在http請求的header都加上token,不用每次請求都手動添加了
// 即使本地存在token,也有可能token是過期的,所以在響應攔截器中要對返回狀態進行判斷
const token = store.state.token;
token && (config.headers.Authorization = token);
return config;
},
error => {
return Promise.error(error);
})
// 響應攔截器
axios.interceptors.response.use(
response => {
if (response.status === 200) {
return Promise.resolve(response);
} else {
return Promise.reject(response);
}
},
// 服務器狀態碼不是200的情況
error => {
if (error.response.status) {
switch (error.response.status) {
// 401: 未登錄
// 未登錄則跳轉登錄頁面,并攜帶當前頁面的路徑
// 在登錄成功后返回當前頁面,這一步需要在登錄頁操作。
case 401:
router.replace({
path: '/login',
query: { redirect: router.currentRoute.fullPath }
});
break;
// 403 token過期
// 登錄過期對用戶進行提示
// 清除本地token和清空vuex中token對象
// 跳轉登錄頁面
case 403:
Toast({
message: '登錄過期,請重新登錄',
duration: 1000,
forbidClick: true
});
// 清除token
localStorage.removeItem('token');
store.commit('loginSuccess', null);
// 跳轉登錄頁面,并將要瀏覽的頁面fullPath傳過去,登錄成功后跳轉需要訪問的頁面
setTimeout(() => {
router.replace({
path: '/login',
query: {
redirect: router.currentRoute.fullPath
}
});
}, 1000);
break;
// 404請求不存在
case 404:
Toast({
message: '網絡請求不存在',
duration: 1500,
forbidClick: true
});
break;
// 其他錯誤,直接拋出錯誤提示
default:
Toast({
message: error.response.data.message,
duration: 1500,
forbidClick: true
});
}
return Promise.reject(error.response);
}
}
);
/**
* get方法,對應get請求
* @param {String} url [請求的url地址]
* @param {Object} params [請求時攜帶的參數]
*/
export function get(url, params){
return new Promise((resolve, reject) =>{
axios.get(url, {
params: params
})
.then(res => {
resolve(res.data);
})
.catch(err => {
reject(err.data)
})
});
}
/**
* post方法,對應post請求
* @param {String} url [請求的url地址]
* @param {Object} params [請求時攜帶的參數]
*/
export function post(url, params) {
return new Promise((resolve, reject) => {
axios.post(url, QS.stringify(params))
.then(res => {
resolve(res.data);
})
.catch(err => {
reject(err.data)
})
});
}


axios的封裝根據需求的不同而不同。這里非常感謝評論里一些很中肯的建議,我也對此進行了思考和針對不同需求的改善。主要有以下改變:

1.優化axios封裝,去掉之前的get和post

2.斷網情況處理

3.更加模塊化的api管理

4.接口域名有多個的情況

5.api掛載到vue.prototype上省去引入的步驟

http.js中axios封裝的優化,先直接貼代碼:

/**
* axios封裝
* 請求攔截、響應攔截、錯誤統一處理
*/
import axios from 'axios';
import router from '../router';
import store from '../store/index';
import { Toast } from 'vant';
/**
* 提示函數
* 禁止點擊蒙層、顯示一秒后關閉
*/
const tip = msg => {
Toast({
message: msg,
duration: 1000,
forbidClick: true
});
}
/**
* 跳轉登錄頁
* 攜帶當前頁面路由,以期在登錄頁面完成登錄后返回當前頁面
*/
const toLogin = () => {
router.replace({
path: '/login',
query: {
redirect: router.currentRoute.fullPath
}
});
}
/**
* 請求失敗后的錯誤統一處理
* @param {Number} status 請求失敗的狀態碼
*/
const errorHandle = (status, other) => {
// 狀態碼判斷
switch (status) {
// 401: 未登錄狀態,跳轉登錄頁
case 401:
toLogin();
break;
// 403 token過期
// 清除token并跳轉登錄頁
case 403:
tip('登錄過期,請重新登錄');
localStorage.removeItem('token');
store.commit('loginSuccess', null);
setTimeout(() => {
toLogin();
}, 1000);
break;
// 404請求不存在
case 404:
tip('請求的資源不存在');
break;
default:
console.log(other);
}}
// 創建axios實例
var instance = axios.create({ timeout: 1000 * 12});
// 設置post請求頭
instance.defaults.headers.post['Content-Type'] = 'application/x-www-form-urlencoded';
/**
* 請求攔截器
* 每次請求前,如果存在token則在請求頭中攜帶token
*/
instance.interceptors.request.use(
config => {
// 登錄流程控制中,根據本地是否存在token判斷用戶的登錄情況
// 但是即使token存在,也有可能token是過期的,所以在每次的請求頭中攜帶token
// 后臺根據攜帶的token判斷用戶的登錄情況,并返回給我們對應的狀態碼
// 而后我們可以在響應攔截器中,根據狀態碼進行一些統一的操作。
const token = store.state.token;
token && (config.headers.Authorization = token);
return config;
},
error => Promise.error(error))
// 響應攔截器
instance.interceptors.response.use(
// 請求成功
res => res.status === 200 ? Promise.resolve(res) : Promise.reject(res),
// 請求失敗
error => {
const { response } = error;
if (response) {
// 請求已發出,但是不在2xx的范圍
errorHandle(response.status, response.data.message);
return Promise.reject(response);
} else {
// 處理斷網的情況
// eg:請求超時或斷網時,更新state的network狀態
// network狀態在app.vue中控制著一個全局的斷網提示組件的顯示隱藏
// 關于斷網組件中的刷新重新獲取數據,會在斷網組件中說明
store.commit('changeNetwork', false);
}
});
export default instance;

這個axios和之前的大同小異,做了如下幾點改變:

1.去掉了之前get和post方法的封裝,通過創建一個axios實例然后export default方法導出,這樣使用起來更靈活一些。

2.去掉了通過環境變量控制baseUrl的值。考慮到接口會有多個不同域名的情況,所以準備通過js變量來控制接口域名。這點具體在api里會介紹。

3.增加了請求超時,即斷網狀態的處理。說下思路,當斷網時,通過更新vuex中network的狀態來控制斷網提示組件的顯示隱藏。斷網提示一般會有重新加載數據的操作,這步會在后面對應的地方介紹。

4.公用函數進行抽出,簡化代碼,盡量保證單一職責原則。


下面說下api這塊,考慮到一下需求:

1.更加模塊化

2.更方便多人開發,有效減少解決命名沖突

3.處理接口域名有多個情況

這里這里呢新建了一個api文件夾,里面有一個index.js和一個base.js,以及多個根據模塊劃分的接口js文件。index.js是一個api的出口,base.js管理接口域名,其他js則用來管理各個模塊的接口。

先放index.js代碼:

/**
* api接口的統一出口
*/
// 文章模塊接口
import article from '@/api/article';
// 其他模塊的接口……
// 導出接口
export default {
article,
// ……
}

index.js是一個api接口的出口,這樣就可以把api接口根據功能劃分為多個模塊,利于多人協作開發,比如一個人只負責一個模塊的開發等,還能方便每個模塊中接口的命名哦。

base.js:

/**
* 接口域名的管理
*/
const base = {
sq: 'https://xxxx111111.com/api/v1',
bd: 'http://xxxxx22222.com/api'
}
export default base;

通過base.js來管理我們的接口域名,不管有多少個都可以通過這里進行接口的定義。即使修改起來,也是很方便的。

最后就是接口模塊的說明,例如上面的article.js:

/**
* article模塊接口列表
*/
import base from './base'; // 導入接口域名列表
import axios from '@/utils/http'; // 導入http中創建的axios實例
import qs from 'qs'; // 根據需求是否導入qs模塊
const article = {
// 新聞列表
articleList () {
return axios.get(`${base.sq}/topics`);
},
// 新聞詳情,演示
articleDetail (id, params) {
return axios.get(`${base.sq}/topic/${id}`, {
params: params
});
},
// post提交
login (params) {
return axios.post(`${base.sq}/accesstoken`, qs.stringify(params));
}
// 其他接口…………
}
export default article;

1.通過直接引入我們封裝好的axios實例,然后定義接口、調用axios實例并返回,可以更靈活的使用axios,比如你可以對post請求時提交的數據進行一個qs序列化的處理等。

2.請求的配置更靈活,你可以針對某個需求進行一個不同的配置。關于配置的優先級,axios文檔說的很清楚,這個順序是:在 lib/defaults.js 找到的庫的默認值,然后是實例的 defaults 屬性,最后是請求的 config 參數。后者將優先于前者。

3.restful風格的接口,也可以通過這種方式靈活的設置api接口地址。

最后,為了方便api的調用,我們需要將其掛載到vue的原型上。在main.js中:

import Vue from 'vue'
import App from './App'
import router from './router' // 導入路由文件
import store from './store' // 導入vuex文件
import api from './api' // 導入api接口
Vue.prototype.$api = api; // 將api掛載到vue的原型上

然后我們可以在頁面中這樣調用接口,eg:

methods: {
onLoad(id) {
this.$api.article.articleDetail(id, {
api: 123
}).then(res=> {
// 執行某些操作
})
}
}

再提一下斷網的處理,這里只做一個簡單的示例:

<template>
<div id="app">
<div v-if="!network">
<h3>我沒網了</h3>
<div @click="onRefresh">刷新</div>
</div>
<router-view/>
</div>
</template>
<script>
import { mapState } from 'vuex';
export default {
name: 'App',
computed: {
...mapState(['network'])
},
methods: {
// 通過跳轉一個空頁面再返回的方式來實現刷新當前頁面數據的目的
onRefresh () {
this.$router.replace('/refresh')
}
}
}
</script>

這是app.vue,這里簡單演示一下斷網。在http.js中介紹了,我們會在斷網的時候,來更新vue中network的狀態,那么這里我們根據network的狀態來判斷是否需要加載這個斷網組件。斷網情況下,加載斷網組件,不加載對應頁面的組件。當點擊刷新的時候,我們通過跳轉refesh頁面然后立即返回的方式來實現重新獲取數據的操作。因此我們需要新建一個refresh.vue頁面,并在其beforeRouteEnter鉤子中再返回當前頁面。

// refresh.vue
beforeRouteEnter (to, from, next) {
next(vm => {
vm.$router.replace(from.fullPath)
})
}

這是一種全局通用的斷網提示,當然了,也可以根據自己的項目需求操作。

轉載于:https://www.cnblogs.com/snowhite/p/10794139.html

總結

以上是生活随笔為你收集整理的vue中Axios的封装和API接口的管理的全部內容,希望文章能夠幫你解決所遇到的問題。

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

91av蜜桃| 激情欧美一区二区三区免费看 | 特黄一级毛片 | 西西444www| 99精品免费久久久久久久久 | 一区二区电影在线观看 | 久久久久久久久久久综合 | 欧美大片第1页 | 五月导航| 亚洲va天堂va欧美ⅴa在线 | 91亚洲精品乱码久久久久久蜜桃 | 日韩在线观看免费 | 久久人人爽视频 | 亚洲一区精品人人爽人人躁 | 午夜精品99久久免费 | 日免费视频 | 亚洲高清91 | 91成人久久 | 日韩精选在线 | 国产精品 国产精品 | 91传媒免费观看 | 婷婷丁香激情综合 | 免费看国产黄色 | 免费精品国产 | 日本护士三级少妇三级999 | 精品一二三四视频 | 欧美一级艳片视频免费观看 | 99热在线这里只有精品 | 久久免费视频1 | 99在线精品视频在线观看 | 中文字幕在线观看免费高清电影 | 色视频在线看 | 久久视精品 | 五月婷婷久草 | 成 人 黄 色 视频播放1 | 亚洲精品一区二区三区新线路 | 草久草久| 久久成 | 麻豆91小视频 | 91免费国产在线观看 | 久久精品欧美视频 | 日韩精品一区二区三区第95 | 久久久久久久综合色一本 | 国产精品国产三级国产aⅴ入口 | 免费三级网 | 国产精品免费不卡 | 999成人网 | 青青河边草观看完整版高清 | 最新日韩电影 | 狠狠综合久久av | 久久久久成 | 天天综合天天综合 | 久久精品女人毛片国产 | 一本一本久久a久久 | 亚洲综合国产精品 | 欧美精品久久久久久久久久丰满 | 国产亚洲情侣一区二区无 | av福利在线看 | 91视频黄色 | 最近中文字幕 | 亚洲高清资源 | 国产精品久久久久久久久久新婚 | 丝袜美腿亚洲 | 中文字幕激情 | 免费看污污视频的网站 | 日韩av一区二区在线 | 国产免费影院 | 91在线网站 | 国产一区二区电影在线观看 | 91视频电影 | 在线电影91 | 国产小视频福利在线 | 97精品免费视频 | 一区二区三区免费看 | 免费日韩一区二区三区 | 中文字幕在线日 | 国产97视频在线 | 91九色国产在线 | 国产精品免费一区二区三区 | 久久久 精品| 国产男女爽爽爽免费视频 | 99在线精品观看 | 在线观看激情av | 亚洲 欧美 精品 | 激情一区二区三区欧美 | 最新日韩中文字幕 | 黄色片网站免费 | av免费观看网址 | 久久精品欧美日韩精品 | 国内外成人在线视频 | 在线看污网站 | 久久久久女教师免费一区 | 亚洲欧美成人综合 | 香蕉视频久久久 | 国产黄色片免费看 | 久久久综合 | 免费日韩在线 | 91桃色在线观看视频 | 深夜免费福利视频 | 天天操天天射天天 | 日韩在线观看精品 | 日日干日日 | 中文视频在线 | 欧美91片 | 成人四虎 | 久久夜色精品国产欧美一区麻豆 | 97超碰在线免费观看 | 国产精品99久久免费黑人 | 婷婷中文在线 | 美女视频黄免费的久久 | 手机成人av| 中文字幕91在线 | 天天干天天做天天爱 | 日韩va在线观看 | 99久久激情视频 | 久久精品视频网 | 亚洲 欧美 国产 va在线影院 | 国产手机av在线 | 99免费在线视频 | 成年人app网址| 99精品福利视频 | 国产精品欧美日韩在线观看 | 99视频这里有精品 | 日韩在线观看a | 97热视频| 国产系列在线观看 | 热re99久久精品国产99热 | 免费视频成人 | 91在线亚洲 | www.狠狠| 免费成人黄色 | 日韩理论在线 | 91麻豆精品国产91久久久使用方法 | 亚洲福利精品 | 婷婷色在线视频 | 日韩在线免费 | 免费在线观看a v | 51久久夜色精品国产麻豆 | 国产精品1024 | 三级在线视频播放 | 日本三级久久 | 天堂久色| 国产精品12 | 在线观看一区二区精品 | 日韩a欧美 | 精品1区2区| .国产精品成人自产拍在线观看6 | 亚洲精品免费看 | 日本三级不卡 | 黄色a一级片| 欧美在线视频一区二区三区 | 亚洲理论片在线观看 | 亚洲精品国产成人 | 日日干 天天干 | 久热超碰| 亚洲涩涩涩 | 国产精品中文久久久久久久 | 99热官网 | 婷婷丁香激情 | 欧美激情综合五月色丁香小说 | 手机在线看a| 国产精品久久久久久久久久久久冷 | 亚洲欧美视频一区二区三区 | 久久久96 | 色综合久久久久网 | 人成电影网 | 亚洲视频在线视频 | av成人免费在线看 | 免费99精品国产自在在线 | 在线观看视频色 | 亚洲国产经典视频 | 九九久久精品视频 | 久久综合婷婷综合 | 天天操夜夜操夜夜操 | 亚洲aⅴ在线观看 | 亚洲欧美一区二区三区孕妇写真 | 免费看久久| 国产一区二区三区久久久 | 国产区久久 | 四虎最新入口 | 国产亚洲精品久久19p | 91超级碰碰 | 欧美精品久久久久久久 | 日韩精品一区二区三区第95 | 超碰日韩在线 | 日韩av网站在线播放 | 91丨九色丨91啦蝌蚪老版 | 免费三级骚 | 成年一级片 | 中文网丁香综合网 | 91高清完整版在线观看 | 97超碰在线久草超碰在线观看 | av网站手机在线观看 | 午夜在线看 | 波多野结衣在线中文字幕 | 91自拍视频在线 | 人人爽人人爽人人爽 | 丁香婷婷综合激情 | 超碰免费97 | 日韩经典一区二区三区 | 欧美久久九九 | 婷婷激情五月综合 | 国内免费久久久久久久久久久 | 国产vs久久 | 亚洲视频h | 一区二区在线影院 | 五月天国产精品 | 亚洲精品视频免费在线观看 | 2018亚洲男人天堂 | 久久草网站 | 国产中文字幕在线播放 | 色综合久久天天 | 97精品国产91久久久久久 | 国产精品无av码在线观看 | 精品免费在线视频 | 欧美日韩精品在线一区二区 | 国产精品激情在线观看 | 麻豆久久久 | 在线国产视频观看 | 国产成人黄色片 | 亚洲精品国偷拍自产在线观看蜜桃 | 精品成人久久 | 免费观看视频黄 | 808电影免费观看三年 | 欧美午夜寂寞影院 | 成人黄大片 | 国产不卡视频在线播放 | 99色免费| www.久热| 人人插人人看 | 99久久婷婷国产 | 日日夜夜国产 | 国产艹b视频 | 日韩在线短视频 | 在线观看亚洲视频 | 国产精品一区二区在线播放 | 丁香六月av | 不卡电影一区二区三区 | 国产视频每日更新 | 久久精品99精品国产香蕉 | 免费黄色看片 | 亚洲成色| 亚洲精品美女在线观看播放 | 欧美精品色 | 91成品视频 | 久久理论片 | 美州a亚洲一视本频v色道 | 欧美成人精品xxx | 伊人天堂网| 国产中文欧美日韩在线 | 午夜视频一区二区三区 | 成人aⅴ视频 | 国产午夜精品久久久久久久久久 | 黄污网站在线 | 亚洲美女精品区人人人人 | 精品一区 精品二区 | 不卡电影免费在线播放一区 | www.com操| 99精品久久久久 | 日本一区二区三区免费看 | 精品久久久久久久久久久久久久久久久久 | av电影 一区二区 | 天堂中文在线视频 | 激情xxxx| 手机成人在线 | 黄色视屏在线免费观看 | 6699私人影院 | 国产黄影院色大全免费 | 麻豆观看 | 波多野结衣久久资源 | 久久精品视频播放 | 蜜臀av网址 | 97在线观看视频 | 伊人五月天 | 国产婷婷vvvv激情久 | 精品久久久久国产免费第一页 | 国产一级免费电影 | 一本—道久久a久久精品蜜桃 | 六月丁香在线观看 | 精品国产电影一区 | 少妇搡bbbb搡bbb搡69 | 日日草夜夜操 | 一区二区视频在线看 | 国产黄色片在线免费观看 | 国产精品 欧美 日韩 | 免费视频久久久 | 国产你懂的在线 | 96亚洲精品久久久蜜桃 | 黄色av一级片 | 国产精品久久影院 | 99热这里只有精品久久 | 国产日产欧美在线观看 | 亚洲天天在线日亚洲洲精 | www.五月婷| 中文字幕免费在线 | 日本aaa在线观看 | 韩国一区二区三区视频 | 91手机视频| 黄色成人免费电影 | 婷婷伊人五月 | 蜜桃视频精品 | 亚洲精品在线免费观看视频 | 久久久性 | 国产丝袜制服在线 | 丁香花五月 | 99久久久久久久 | 综合国产在线观看 | 天天操天天干天天玩 | 国产成人一区二区三区在线观看 | 久久国产乱 | 亚洲一区美女视频在线观看免费 | 色婷婷狠狠操 | 天堂在线视频免费观看 | 最近最新中文字幕视频 | 国产99在线播放 | 天天做天天爱天天综合网 | www.黄色在线| 女人高潮一级片 | 国产人成在线视频 | 国产视频一区二区在线观看 | 午夜av网站 | 亚洲在线高清 | 国产韩国日本高清视频 | 免费av小说| 五月综合激情婷婷 | 日韩欧美高清在线 | av九九| 99精品视频在线观看播放 | 一区二精品 | 婷婷丁香九月 | 黄色三级网站在线观看 | 国产高清无av久久 | 97香蕉超级碰碰久久免费软件 | 制服丝袜一区二区 | 久久精品国产成人精品 | 一区二区三区免费在线播放 | 久久黄色网 | 91欧美在线| 丁香视频五月 | 久久国产精品免费看 | 天天插狠狠插 | 一区二区欧美激情 | 91成年人在线观看 | 欧美日韩一级视频 | 欧美激情视频一区二区三区免费 | 91手机在线看片 | 91中文字幕视频 | 久久香蕉国产精品麻豆粉嫩av | 人人舔人人爽 | 久久精品一区二区三区中文字幕 | 中文字幕日韩国产 | 最近中文字幕在线中文高清版 | 国产精品黄色影片导航在线观看 | 久久噜噜少妇网站 | 好看av在线 | 免费看片亚洲 | 91视频免费国产 | 国产精品久久久久久超碰 | 日本三级香港三级人妇99 | 欧美日韩激情视频8区 | 国产一区二区三区免费在线 | 女人18毛片a级毛片一区二区 | 丁香婷婷综合激情五月色 | 日本三级中文字幕在线观看 | 国产成人一区二区三区影院在线 | 久久国产精品免费观看 | 国产在线不卡 | 午夜精品一二三区 | 亚洲三级在线免费观看 | 国产在线久草 | 激情影音先锋 | 亚洲欧美精品一区 | 国产高清黄色 | 日韩中文久久 | 日日干av| 国产最顶级的黄色片在线免费观看 | 亚洲激情在线观看 | 在线成人欧美 | 亚洲最大激情中文字幕 | 精品福利在线观看 | 五月婷婷六月丁香 | 青青河边草观看完整版高清 | 国产一区免费观看 | 在线观看91视频 | 91成人免费观看视频 | 国产精品成人av久久 | 日日操网 | 97香蕉久久超级碰碰高清版 | 色婷婷久久一区二区 | 欧美人交a欧美精品 | 欧美综合干| 亚洲精品合集 | 国产精品九九热 | 91最新国产 | 亚洲一区精品人人爽人人躁 | 久久免费观看视频 | 麻豆91小视频 | 亚洲欧美国产精品久久久久 | 亚洲人在线视频 | 中文字幕久久精品亚洲乱码 | 国产九九精品视频 | 美女久久一区 | 丁香婷婷综合五月 | 91传媒在线 | 美女福利视频一区二区 | 欧美色精品天天在线观看视频 | 欧美成人精品欧美一级乱 | av播放在线 | 国产一线二线三线性视频 | 欧美a性 | 99热国产精品 | 毛片网在线播放 | 亚洲天堂网在线视频观看 | 黄色大全免费观看 | 91精品日韩| 久射网| 国内视频在线 | 亚洲成av| 99久久精品一区二区成人 | 久久国产高清视频 | 99视频+国产日韩欧美 | 久久免费视频7 | 天堂av中文字幕 | 五月婷婷在线播放 | 国产91精品在线播放 | 中文字幕一区二区三区四区视频 | 日韩一区二区三区不卡 | 精品国产a | 在线成人高清电影 | 国产香蕉在线 | 日韩簧片在线观看 | 激情五月伊人 | 精品国产乱码久久久久久浪潮 | 奇米影视8888在线观看大全免费 | 久久久免费精品视频 | 麻豆网站免费观看 | 成人羞羞视频在线观看免费 | 日韩欧三级| 激情五月激情综合网 | 久久综合久久伊人 | 欧美日韩国产成人 | 黄www在线观看| 日韩精品一区二区三区免费观看视频 | 日日夜夜精品免费视频 | 97国产在线观看 | 婷婷六月天在线 | 亚洲韩国一区二区三区 | 亚色视频在线观看 | 色婷婷综合在线 | 国产资源网站 | 美国人与动物xxxx | 一区二区三区在线观看 | 国产精品成人品 | 精品一二三区视频 | 九九九热精品 | 久久草精品 | 免费精品国产va自在自线 | 天天操天天谢 | 欧美一级小视频 | 久久人操 | 国产第一页在线播放 | 99精品国产在热久久 | 日韩欧美视频在线免费观看 | 亚洲国产大片 | 日本黄色大片儿 | 日韩精品一区二区免费视频 | 91av超碰 | 国产精品国产三级国产专区53 | 91久久在线观看 | 九九色视频 | 狠狠干网址 | 又黄又爽又湿又无遮挡的在线视频 | 天天干天天天 | 久久图| www.天天干| 国产午夜三级一区二区三桃花影视 | 中文字幕在线看人 | 成人中心免费视频 | 91色国产 | 日韩av资源在线观看 | 国产免费又黄又爽 | 免费成人在线视频网站 | 天天色图| 亚洲黄电影 | 激情五月在线 | 免费视频你懂得 | 日韩视频免费看 | 婷婷在线五月 | 丁香婷婷在线观看 | 久久夜色精品国产亚洲aⅴ 91chinesexxx | 99自拍视频在线观看 | 国内外成人在线视频 | 6080yy午夜一二三区久久 | 在线观看亚洲免费视频 | 久久久久久久久久久综合 | av成人在线看 | 国产精品对白一区二区三区 | 91av福利视频 | 久久久久成人精品免费播放动漫 | 四月婷婷在线观看 | 特级毛片在线观看 | 国产男男gay做爰 | 国产精品久久久久久久久久久久久久 | 久久精品资源 | 国内精品久久久精品电影院 | 久久综合爱 | 天天综合网久久 | av在线免费在线观看 | 久草精品视频在线播放 | 狠狠狠狠狠色综合 | 爱色婷婷 | 亚洲va在线va天堂va偷拍 | 夜夜躁狠狠躁日日躁 | 国产区网址| 亚洲国产精品传媒在线观看 | av在线亚洲天堂 | 日韩成人在线一区二区 | 中文字幕网站视频在线 | 国产精品一区二区久久 | 欧美国产91 | 亚洲精品国产精品国自产在线 | 午夜av网站| 超碰在线观看av.com | 99精品视频在线观看视频 | 久久久久久久久精 | 国产高清视频在线免费观看 | 国产精品三级视频 | 婷婷国产在线 | 6080yy午夜一二三区久久 | 国产精品av免费观看 | 在线观看电影av | 午夜aaaa| 国产涩涩在线观看 | 一区二区av| 久久色网站 | 最新日韩视频在线观看 | 日韩中文字幕第一页 | 日韩中文字幕在线看 | 视频福利在线 | 黄色毛片在线 | 日韩av有码在线 | 五月天中文字幕 | 国产在线观看av | 久草资源在线 | 91亚洲精品视频 | 欧美色综合天天久久综合精品 | 日韩免费一区二区三区 | 国产96在线 | 中文字幕 二区 | 福利一区二区 | 国产精品久久久久一区二区三区 | 欧美淫aaa免费观看 日韩激情免费视频 | 国产黄色精品在线 | 国产精品中文久久久久久久 | 国产成人av综合色 | 成人黄色小说视频 | 中文字幕日韩在线播放 | 五月天久久精品 | 日韩天天干 | 国产在线国偷精品产拍 | 色综合五月 | 狂野欧美激情性xxxx | 麻豆av电影| 特级毛片在线免费观看 | 午夜精品福利一区二区三区蜜桃 | 久久99影院 | 亚洲免费资源 | 久久开心激情 | 久久高清精品 | 中文字幕精品视频 | 精品自拍sae8—视频 | 99久久99久久精品国产片果冰 | 夜添久久精品亚洲国产精品 | 韩国在线视频一区 | 中国一级特黄毛片大片久久 | 91精品视频在线观看免费 | 久草在线这里只有精品 | www狠狠操| 麻豆传媒视频在线免费观看 | 91污污| 色999在线| 国产美女免费看 | 国产一区二区免费 | 欧美aaa级片 | 色资源网在线观看 | 美女黄濒 | 91视频麻豆视频 | 亚洲理论在线观看电影 | 色香蕉视频| 亚洲精品女人久久久 | 日韩一区二区免费在线观看 | 国产精品久久久久久久久久不蜜月 | 女女av在线 | 人人爱人人做人人爽 | 欧美一级黄色视屏 | 九七人人干 | 激情导航 | 亚洲在线网址 | 国产精品一区二区三区视频免费 | 国产国语在线 | 国产视频一区在线 | 国产原创91| 天操夜夜操 | 在线播放一区二区三区 | 91香蕉视频 | 久久97久久97精品免视看 | 婷婷亚洲激情 | 日韩在线观看影院 | 日韩在线视频播放 | 中文字幕av免费 | 国产二区视频在线观看 | 久久这里只有精品23 | 日韩av高清 | 亚洲h在线播放在线观看h | 日韩电影一区二区三区 | 97在线视频免费播放 | 成人av在线直播 | 久久99精品久久久久久清纯直播 | 91在线看 | 日日操天天操夜夜操 | 天天操天天干天天爽 | 狠狠色狠狠综合久久 | 999日韩 | av一区二区三区在线 | 日韩视频在线不卡 | 久久久久久国产精品亚洲78 | 99久久婷婷国产 | 激情综合婷婷 | 综合色狠狠 | 成人av中文字幕在线观看 | av日韩精品| 久久久久久久久久久久久影院 | 综合亚洲视频 | 久草在线免费资源站 | 日本中文字幕网站 | 亚洲三级黄 | 一区二区三区www | 五月花丁香婷婷 | 久久福利综合 | 久久在线视频精品 | 国产黄色av网站 | 色av色av色av| 久久精彩视频 | 日韩电影一区二区在线 | 日韩高清免费无专码区 | 六月丁香综合网 | 亚洲精品中文字幕视频 | 97精品久久人人爽人人爽 | 超级碰碰碰碰 | 久久久久久久免费看 | 久久九九九九 | 日本精品久久久久中文字幕 | 久草精品视频在线观看 | 久久久污 | 国产午夜三级一区二区三 | 国产又黄又爽无遮挡 | 国产精品日韩欧美一区二区 | 一区电影 | 免费av网址大全 | 在线看日韩 | 精品a视频 | 在线影视 一区 二区 三区 | 国产无遮挡又黄又爽在线观看 | 婷婷激情5月天 | 国产成人精品久久二区二区 | 国产成人精品久久久久蜜臀 | 四虎永久视频 | 久久久久久久久久久久久国产精品 | 久久午夜精品视频 | 在线视频a | 久草| 亚洲有 在线 | 精品字幕 | 亚一亚二国产专区 | 亚洲午夜久久久久 | 主播av在线| 免费高清在线观看成人 | 亚洲伊人成综合网 | 少妇视频一区 | 日韩久久午夜一级啪啪 | 91中文字幕永久在线 | 中文字幕在线视频网站 | 久草在线国产 | 成年人国产视频 | 99精品视频在线看 | www.夜夜操.com | 国产精品色在线 | 亚洲国产影院 | 一区二区免费不卡在线 | 久久经典国产视频 | 五月婷婷综合网 | 91欧美精品| 在线免费观看羞羞视频 | 免费a视频| 欧美aⅴ在线观看 | 久久激情小说 | 成人黄色短片 | www.狠狠操.com | 婷婷亚洲综合 | 国产一级性生活视频 | 国产黄色网 | 日韩免费视频播放 | 黄色www在线观看 | 国产在线观看99 | 久久国产精品免费一区 | 亚洲h视频在线 | 97香蕉久久超级碰碰高清版 | 五月婷在线 | 天天躁日日躁狠狠躁av麻豆 | 日韩综合一区二区 | 日韩精品中文字幕在线播放 | 亚洲综合在线视频 | 婷婷五综合 | 久久综合久久综合久久综合 | 国产视频在线一区二区 | 日本三级吹潮在线 | 精品国产伦一区二区三区观看说明 | 国产老熟 | 成年美女黄网站色大片免费看 | 国产精品美女 | 西西444www高清大胆 | 天天操夜夜操天天射 | 免费亚洲精品 | 国产精品久久久久久五月尺 | 西西444www大胆高清视频 | 人人干在线观看 | 狠狠色丁香久久婷婷综合_中 | 精品理论片 | 久久天天躁狠狠躁亚洲综合公司 | 国产原创在线 | 国产精品一区免费观看 | 成人免费看片98欧美 | 99精品国产在热久久下载 | 天天综合亚洲 | 精品国产片 | 久久久久国产精品免费 | 中文国产在线观看 | 激情在线网 | 国产精品va在线观看入 | 久久深夜福利免费观看 | 992tv人人草 黄色国产区 | 久久久久国产精品免费免费搜索 | 久久久久五月天 | 欧美精品一区二区免费 | 91完整版在线观看 | 成人免费xxx在线观看 | 亚洲 综合 国产 精品 | 国产成人精品国内自产拍免费看 | 欧美日韩不卡在线视频 | 97在线超碰 | 五月香视频在线观看 | 天天操人 | 亚洲精品免费在线视频 | 狠狠色噜噜狠狠狠狠2021天天 | 国产91九色视频 | 亚洲精品ww | 日本最新高清不卡中文字幕 | 欧美性高跟鞋xxxxhd | 国产精品黄色 | 黄色一级大片在线免费看产 | 日韩欧美高清免费 | 在线国产观看 | www.成人久久| 亚洲成熟女人毛片在线 | 免费看久久久 | 成年免费在线视频 | 天天草网站 | 国产精品久久久久久久免费大片 | 成人羞羞免费 | 国产91丝袜在线播放动漫 | 国产精品乱看 | 亚洲电影图片小说 | 日韩成人精品一区二区 | 国产视 | 国产精品系列在线观看 | 久视频在线播放 | 久久久久久久久久影视 | 免费观看版| 亚洲精品456在线播放 | 亚洲欧美日韩国产一区二区三区 | 国产视频久久久久 | 五月婷婷丁香色 | 国产成人高清在线 | 久久综合干 | 1024手机在线看| 免费特级黄色片 | 亚洲欧美国产精品久久久久 | 久久久久久欧美二区电影网 | 久久久久成人精品免费播放动漫 | 国产99黄| 午夜精品一区二区三区视频免费看 | 四虎在线永久免费观看 | 成片人卡1卡2卡3手机免费看 | 国产一级免费视频 | 亚洲作爱 | 中文字幕第一页在线 | 国产第一二区 | 久久九九久久精品 | 免费欧美精品 | 日日干天天爽 | 精品1区2区3区 | 国产艹b视频 | 久久不射网站 | 中文区中文字幕免费看 | 久久观看最新视频 | 成人精品国产 | 九色琪琪久久综合网天天 | 色综合久久久久综合 | 在线观看av大片 | 久久久久久久久影视 | 超级碰视频 | 天天艹日日干 | 国产欧美在线一区二区三区 | 国产精品久久久久永久免费 | 99热99热| 欧洲精品一区二区 | 99精品国产99久久久久久福利 | 久久不射影院 | 亚洲一区视频免费观看 | 九草视频在线观看 | 黄色日本片 | 91精品久久久久久 | 探花视频在线版播放免费观看 | 日韩欧三级 | 美女视频是黄的免费观看 | 狠狠狠色丁香综合久久天下网 | 久久狠狠干 | 亚洲国产精品一区二区尤物区 | 狠狠狠色丁香婷婷综合久久88 | av电影在线不卡 | 黄色一区二区在线观看 | 精品一二三四视频 | 99精品免费久久久久久久久 | 国产免费资源 | 777xxx欧美 | 国产一区视频在线 | 久久天天操 | 黄色av影视| www.午夜视频 | 亚洲精品在线免费看 | 在线观看网站你懂的 | 午夜精品久久久久久久爽 | 色丁香综合 | 搡bbbb搡bbb视频 | 亚洲激情在线 | 在线亚洲午夜片av大片 | 日韩av资源在线观看 | www.久热| 国产精品自产拍在线观看中文 | 国语黄色片 | 亚洲精品欧美精品 | 麻豆传媒电影在线观看 | 深爱五月激情五月 | 色婷婷狠 | 国产亚洲精品中文字幕 | 久久电影国产免费久久电影 | 97成人资源站 | 91九色视频导航 | 人人爱天天操 | 国产精品一区二区三区四区在线观看 | 久久99精品久久久久久秒播蜜臀 | 91视频3p| 日韩久久久久久久久久久久 | av高清在线 | 日本色小说视频 | 欧美激情另类 | 久久99精品国产麻豆宅宅 | 国产一卡二卡在线 | 国产在线观看 | 国产亚洲视频系列 | 久久精品国产99国产 | 久久99国产精品免费 | 伊人天天综合 | 91成人天堂久久成人 | 夜夜爽天天爽 | 97电影院在线观看 | 嫩草伊人久久精品少妇av | 日韩欧美一区二区三区视频 | 成人国产精品免费 | 中文字幕在线免费 | a级国产乱理论片在线观看 特级毛片在线观看 | 亚洲精区二区三区四区麻豆 | 精品一区二三区 | 国产视频一区二区在线观看 | 国产人成看黄久久久久久久久 | 欧美二区视频 | 777奇米四色| 天天操福利视频 | 9ⅰ精品久久久久久久久中文字幕 | 综合精品久久久 | 中文字幕亚洲五码 | 国产小视频免费在线网址 | 日韩午夜小视频 | av品善网| 在线国产视频一区 | 日韩免费av片 | 精品在线观看一区二区 | 国产在线资源 | 午夜av激情 | 天天夜夜操 | 欧美一级片免费在线观看 | 国产精品9999 | 中文av资源站 | 久久人人精品 | 国产成人在线播放 | 日韩一级理论片 | 久久久久亚洲精品国产 | 国产久草在线观看 | 国产精品18久久久久vr手机版特色 | 人人玩人人添人人澡超碰 | 亚洲电影第一页av | 亚洲男男gaygay无套同网址 | 三级视频日韩 | 国产精品欧美一区二区 | 夜夜干天天操 | 性色av免费在线观看 | 热久久影视 | 欧洲在线免费视频 | 精品国产伦一区二区三区观看方式 | 久草香蕉在线 | 中文字幕视频 | 一本一道久久a久久精品蜜桃 | www.狠狠色.com | 亚洲综合成人专区片 | 97视频网站| 天天摸天天干天天操天天射 | 久久手机在线视频 | av在线电影网站 | 亚洲国产免费网站 | 91热这里只有精品 | av中文字幕网站 | 国产成人在线一区 | 在线免费观看一区二区三区 | 欧美日韩三级在线观看 | 久久免费av电影 | 999视频在线播放 | 男女视频国产 | 热re99久久精品国产99热 | 国产精品区在线观看 | 超碰午夜 | 一区二区 不卡 | 亚洲成人免费 | 日韩电影在线视频 | 久久精品欧美一区 | 97精品一区二区三区 | 久久久久久久久久久免费视频 | 久草免费看 | 97电院网手机版 | 国产 一区二区三区 在线 | 二区三区视频 | 五月激情综合婷婷 | 中文字幕视频免费观看 | 久久特级毛片 | 91黄视频在线| 亚洲精品中文字幕视频 | www好男人| 天堂资源在线观看视频 | 91麻豆国产福利在线观看 | 欧产日产国产69 | 人人插人人 | 免费日韩 精品中文字幕视频在线 | 亚洲精品乱码久久久久久9色 | 国产成人在线综合 | 九九国产精品视频 | 国产日韩在线看 | va视频在线观看 | 亚洲天堂精品视频在线观看 | 17婷婷久久www | 日韩av一区二区三区四区 | 欧美极度另类性三渗透 | 久久婷婷五月综合色丁香 | 日韩视频一区二区 | 久久人人精品 | 一区二区三区在线观看 | 国产一级视频在线 | 蜜桃视频日本 | 波多野结衣在线播放一区 | 国产亚洲综合性久久久影院 | 国产成本人视频在线观看 | 免费国产在线视频 | 亚洲黄色三级 | 91av手机在线 | 欧美a视频 | 婷婷在线观看视频 | 亚洲狠狠 | 人人干人人干人人干 | 亚洲黄色激情小说 | 天天射天天干天天 | 国产日韩欧美视频在线观看 | 日本三级全黄少妇三2023 | 视频在线播放国产 | 亚洲精品综合在线 | 精品久久网站 | 五月婷婷婷婷婷 | 欧洲av在线 | 最新一区二区三区 | 亚洲综合色av | 国产午夜精品一区二区三区嫩草 |