久久精品国产精品国产精品污,男人扒开添女人下部免费视频,一级国产69式性姿势免费视频,夜鲁夜鲁很鲁在线视频 视频,欧美丰满少妇一区二区三区,国产偷国产偷亚洲高清人乐享,中文 在线 日韩 亚洲 欧美,熟妇人妻无乱码中文字幕真矢织江,一区二区三区人妻制服国产

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

java+ElementUI前后端分离旅游项目第三天 预约管理

發布時間:2023/12/14 编程问答 34 豆豆
生活随笔 收集整理的這篇文章主要介紹了 java+ElementUI前后端分离旅游项目第三天 预约管理 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

預約管理-套餐管理

學習目標:

1:了解常見的圖片存儲方案

2:掌握新增套餐實現過程

3:掌握套餐分頁查詢實現過程

4:掌握Quartz使用方式

1. 第一章. 圖片存儲方案

【目標】

美年旅游項目,圖片存儲方案

【路徑】

1:介紹

(1)文件上傳功能介紹

2:七牛云存儲

(1)注冊

(2)新建存儲空間

(3)查看存儲空間信息

(4)開發者中心

  • 文件上傳
  • 文件刪除

(5)鑒權

(6)Java SDK操作七牛云

(7)封裝工具類

【講解】

1.1. 介紹

在實際開發中,我們會有很多處理不同功能的服務器。例如:

應用服務器:負責部署我們的應用

數據庫服務器:運行我們的數據庫

文件服務器:負責存儲用戶上傳文件的服務器

分服務器處理的目的是讓服務器各司其職,從而提高我們項目的運行效率。

常見的圖片存儲方案:

方案一:使用nginx搭建圖片服務器

方案二:使用開源的分布式文件存儲系統,例如Fastdfs、HDFS等

方案三:使用云存儲,例如阿里云、七牛云等

1.2. 七牛云存儲

七牛云(隸屬于上海七牛信息技術有限公司)是國內領先的以視覺智能和數據智能為核心的企業級云計算服務商,同時也是國內知名智能視頻云服務商,累計為 70 多萬家企業提供服務,覆蓋了國內80%網民。圍繞富媒體場景推出了對象存儲、融合 CDN 加速、容器云、大數據平臺、深度學習平臺等產品、并提供一站式智能視頻云解決方案。為各行業及應用提供可持續發展的智能視頻云生態,幫助企業快速上云,創造更廣闊的商業價值。

官網:https://www.qiniu.com/

通過七牛云官網介紹我們可以知道其提供了多種服務,我們主要使用的是七牛云提供的對象存儲服務來存儲圖片。

1.2.1. 注冊、登錄

要使用七牛云的服務,首先需要注冊成為會員。地址:https://portal.qiniu.com/signup

注冊完成后就可以使用剛剛注冊的郵箱和密碼登錄到七牛云:

登錄成功后點擊頁面右上角管理控制臺:

注意:登錄成功后還需要進行實名認證才能進行相關操作。

1.2.2. 新建存儲空間

要進行圖片存儲,我們需要在七牛云管理控制臺新建存儲空間。點擊管理控制臺首頁對象存儲下的立即添加按鈕,頁面跳轉到新建存儲空間頁面:

可以創建多個存儲空間,各個存儲空間是相互獨立的。

1.2.3. 查看存儲空間信息

存儲空間創建后,會在左側的存儲空間列表菜單中展示創建的存儲空間名稱,點擊存儲空間名稱可以查看當前存儲空間的相關信息

課程中重點關注【內容管理】中的信息。

1.2.4. 開發者中心

可以通過七牛云提供的開發者中心學習如何操作七牛云服務,地址:https://developer.qiniu.com/

點擊對象存儲,跳轉到對象存儲開發頁面,地址:https://developer.qiniu.com/kodo

操作步驟:

第一步:導入jar包:

第二步:鑒權

點擊“管理控制臺”,點擊右上圖標

可根據文檔中提供的上傳文件和刪除文件進行測試:

在 meinian_common 中測試

1.2.4.1.文件上傳

package com.atguigu;import com.google.gson.Gson; import com.qiniu.common.Zone; import com.qiniu.http.Response; import com.qiniu.storage.Configuration; import com.qiniu.storage.UploadManager; import com.qiniu.storage.model.DefaultPutRet; import com.qiniu.util.Auth; import org.junit.Test;public class TestQiniu {// 上傳本地文件@Testpublic void uploadFile(){//構造一個帶指定Zone對象的配置類Configuration cfg = new Configuration(Zone.zone2());//...其他參數參考類注釋UploadManager uploadManager = new UploadManager(cfg);//...生成上傳憑證,然后準備上傳String accessKey = "dzpXBDSa3musX6U7Nq8v0fzv921stt-NnRLGhACK";String secretKey = "AB90WSgUo32gY87jOyOW2zVH97fz9wT9JWCpKEm-";String bucket = "maweiqi";//如果是Windows情況下,格式是 D:\\qiniu\\test.png,可支持中文String localFilePath = "D:/2.jpg";//默認不指定key的情況下,以文件內容的hash值作為文件名String key = null;Auth auth = Auth.create(accessKey, secretKey);String upToken = auth.uploadToken(bucket);try {Response response = uploadManager.put(localFilePath, key, upToken);//解析上傳成功的結果DefaultPutRet putRet = new Gson().fromJson(response.bodyString(), DefaultPutRet.class);System.out.println(putRet.key);System.out.println(putRet.hash);} catch (QiniuException ex) {Response r = ex.response;System.err.println(r.toString());try {System.err.println(r.bodyString());} catch (QiniuException ex2) {//ignore}}} }

1.2.4.2.文件刪除

// 刪除空間中的文件@Testpublic void deleteFile(){//構造一個帶指定Zone對象的配置類Configuration cfg = new Configuration(Zone.zone0());//...其他參數參考類注釋String accessKey = "dzpXBDSa3musX6U7Nq8v0fzv921stt-NnRLGhACK";String secretKey = "AB90WSgUo32gY87jOyOW2zVH97fz9wT9JWCpKEm-";String bucket = "maweiqi";String key = "Fu3Ic6TV6wIbJt793yaGeBmCkzTX";Auth auth = Auth.create(accessKey, secretKey);BucketManager bucketManager = new BucketManager(auth, cfg);try {bucketManager.delete(bucket, key);} catch (QiniuException ex) {//如果遇到異常,說明刪除失敗System.err.println(ex.code());System.err.println(ex.response.toString());}}

七牛云提供了多種方式操作對象存儲服務,本項目采用Java SDK方式,地址:https://developer.qiniu.com/kodo/sdk/1239/java

使用Java SDK操作七牛云需要導入如下maven坐標:(項目已經引入)

<dependency><groupId>com.qiniu</groupId><artifactId>qiniu-java-sdk</artifactId><version>7.2.0</version> </dependency>

1.2.5. 鑒權

Java SDK的所有的功能,都需要合法的授權。授權憑證的簽算需要七牛賬號下的一對有效的Access Key和Secret Key,這對密鑰可以在七牛云管理控制臺的個人中心(https://portal.qiniu.com/user/key)獲得,如下圖:

1.2.6. Java SDK操作七牛云

本章節我們就需要使用七牛云提供的Java SDK完成圖片上傳和刪除,我們可以參考官方提供的例子。

上傳文件:

//構造一個帶指定Zone對象的配置類,zone0表示華東地區(默認) Configuration cfg = new Configuration(Zone.zone0()); //...其他參數參考類注釋UploadManager uploadManager = new UploadManager(cfg); //...生成上傳憑證,然后準備上傳 String accessKey = "your access key"; String secretKey = "your secret key"; String bucket = "your bucket name";//默認不指定key的情況下,以文件內容的hash值作為文件名 String key = null;try {byte[] uploadBytes = "hello qiniu cloud".getBytes("utf-8");ByteArrayInputStream byteInputStream=new ByteArrayInputStream(uploadBytes);Auth auth = Auth.create(accessKey, secretKey);String upToken = auth.uploadToken(bucket);try {Response response = uploadManager.put(byteInputStream,key,upToken,null, null);//解析上傳成功的結果DefaultPutRet putRet = new Gson().fromJson(response.bodyString(), DefaultPutRet.class);System.out.println(putRet.key);System.out.println(putRet.hash);} catch (QiniuException ex) {Response r = ex.response;System.err.println(r.toString());try {System.err.println(r.bodyString());} catch (QiniuException ex2) {//ignore}} } catch (UnsupportedEncodingException ex) {//ignore }

刪除文件:

//構造一個帶指定Zone對象的配置類,zone0表示華東地區(默認) Configuration cfg = new Configuration(Zone.zone0()); //...其他參數參考類注釋String accessKey = "your access key"; String secretKey = "your secret key";String bucket = "your bucket name"; String key = "your file key";Auth auth = Auth.create(accessKey, secretKey); BucketManager bucketManager = new BucketManager(auth, cfg); try {bucketManager.delete(bucket, key); } catch (QiniuException ex) {//如果遇到異常,說明刪除失敗System.err.println(ex.code());System.err.println(ex.response.toString()); }

1.2.7. 封裝工具類

為了方便操作七牛云存儲服務,我們可以將官方提供的案例簡單改造成一個工具類,在我們的項目中直接使用此工具類來操作就可以:

package com.atguigu.utils;import com.google.gson.Gson; import com.qiniu.common.QiniuException; import com.qiniu.common.Zone; import com.qiniu.http.Response; import com.qiniu.storage.BucketManager; import com.qiniu.storage.Configuration; import com.qiniu.storage.UploadManager; import com.qiniu.storage.model.DefaultPutRet; import com.qiniu.util.Auth; import java.io.File; import java.io.FileInputStream; import java.io.InputStream;/*** 七牛云工具類*/ public class QiniuUtils {public static String accessKey = "dzpXBDSa3musX6U7Nq8v0fzv921stt-NnRLGhACK";public static String secretKey = "AB90WSgUo32gY87jOyOW2zVH97fz9wT9JWCpKEm-";public static String bucket = "maweiqi";public static void upload2Qiniu(String filePath,String fileName){//構造一個帶指定Zone對象的配置類Configuration cfg = new Configuration(Zone.zone2());UploadManager uploadManager = new UploadManager(cfg);Auth auth = Auth.create(accessKey, secretKey);String upToken = auth.uploadToken(bucket);try {Response response = uploadManager.put(filePath, fileName, upToken);//解析上傳成功的結果DefaultPutRet putRet = new Gson().fromJson(response.bodyString(), DefaultPutRet.class);} catch (QiniuException ex) {Response r = ex.response;try {System.err.println(r.bodyString());} catch (QiniuException ex2) {//ignore}}}//上傳文件public static void upload2Qiniu(byte[] bytes, String fileName){//構造一個帶指定Zone對象的配置類Configuration cfg = new Configuration(Zone.zone2());//...其他參數參考類注釋UploadManager uploadManager = new UploadManager(cfg);//默認不指定key的情況下,以文件內容的hash值作為文件名String key = fileName;Auth auth = Auth.create(accessKey, secretKey);String upToken = auth.uploadToken(bucket);try {Response response = uploadManager.put(bytes, key, upToken);//解析上傳成功的結果DefaultPutRet putRet = new Gson().fromJson(response.bodyString(), DefaultPutRet.class);System.out.println(putRet.key);System.out.println(putRet.hash);} catch (QiniuException ex) {Response r = ex.response;System.err.println(r.toString());try {System.err.println(r.bodyString());} catch (QiniuException ex2) {//ignore}}}//刪除文件public static void deleteFileFromQiniu(String fileName){//構造一個帶指定Zone對象的配置類Configuration cfg = new Configuration(Zone.zone2());String key = fileName;Auth auth = Auth.create(accessKey, secretKey);BucketManager bucketManager = new BucketManager(auth, cfg);try {bucketManager.delete(bucket, key);} catch (QiniuException ex) {//如果遇到異常,說明刪除失敗System.err.println(ex.code());System.err.println(ex.response.toString());}} }

將此工具類放在 meinian_common 工程中,后續會使用到。

【小結】

1:介紹

(1)文件上傳功能介紹

2:七牛云存儲

(1)注冊

(2)新建存儲空間

(3)查看存儲空間信息

(4)開發者中心

(5)鑒權

(6)Java SDK操作七牛云

(7)封裝工具類

2. 第二章. 新增套餐

【目標】

新增套餐

【路徑】

1:需求分析

2:前臺代碼

(1)彈出新增窗口

(2)動態展示跟團游列表

(3)圖片上傳并預覽

  • 使用七牛云存儲圖片

(4)提交請求

  • 使用數據庫存儲圖片名稱
  • 使用springmvc的文件上傳技術

3:后臺代碼

業務:

  • 新增套餐

(1)SetmealController.java(Controller)

(2)SetmealService.java(服務接口)

(3)SetmealServiceImpl.java(服務實現類)

(4)SetmealDao.java(Dao接口)

(5)SetmealDao.xml(Mapper映射文件)

4:完善文件上傳,Redis存儲圖片名稱(一會說)

【接口文檔】

請求方式 get請求

請求地址

/travelgroup/findAll.do

返回方result子成員:

名稱類型必要說明
tableDataobject表單數據

tableData子成員如下:

創建表

DROP TABLE IF EXISTS `t_setmeal`; CREATE TABLE `t_setmeal` (`id` int(11) NOT NULL AUTO_INCREMENT,`name` varchar(1000) DEFAULT NULL,`code` varchar(8) DEFAULT NULL,`helpCode` varchar(16) DEFAULT NULL,`sex` char(1) DEFAULT NULL,`age` varchar(32) DEFAULT NULL,`price` float DEFAULT NULL,`remark` varchar(3000) DEFAULT NULL,`attention` varchar(128) DEFAULT NULL,`img` varchar(128) DEFAULT NULL,PRIMARY KEY (`id`) ) ENGINE=InnoDB AUTO_INCREMENT=16 DEFAULT CHARSET=utf8;DROP TABLE IF EXISTS `t_setmeal_travelgroup`; CREATE TABLE `t_setmeal_travelgroup` (`setmeal_id` int(11) NOT NULL DEFAULT '0',`travelgroup_id` int(11) NOT NULL DEFAULT '0',PRIMARY KEY (`setmeal_id`,`travelgroup_id`),KEY `travelgroup_key` (`travelgroup_id`),CONSTRAINT `travelgroup_key` FOREIGN KEY (`travelgroup_id`) REFERENCES `t_travelgroup` (`id`),CONSTRAINT `setmeal_key` FOREIGN KEY (`setmeal_id`) REFERENCES `t_setmeal` (`id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8;

【講解】

2.1. 需求分析

套餐其實就是跟團游的集合,例如有一個套餐為“北京深圳雙飛套餐”,這個套餐可以包括多個跟團游。

所以在添加套餐時需要選擇這個套餐包括的跟團游。

套餐對應的實體類為Setmeal,

public class Setmeal implements Serializable {private Integer id;private String name;private String code;private String helpCode;private String sex;//套餐適用性別:0不限 1男 2女private String age;//套餐適用年齡private Float price;//套餐價格private String remark;private String attention;private String img;//套餐對應圖片存儲路徑(用于存放七牛云上的圖片名稱)private List<TravelGroup> travelGroups;//體檢套餐對應的跟團游,多對多關系 }

其中img字段表示套餐對應圖片存儲路徑(用于存放七牛云上的圖片名稱)

對應的數據表為 t_setmeal。套餐和跟團游為多對多關系,所以需要中間表 t_setmeal_travelgroup 進行關聯。

t_setmeal 表

t_setmeal_travelgroup 表

2.2. 前臺代碼

套餐管理頁面對應的是 setmeal.html 頁面,根據產品設計的原型已經完成了頁面基本結構的編寫,現在需要完善頁面動態效果。

2.2.1. 彈出新增窗口

頁面中已經提供了新增窗口,只是出于隱藏狀態。只需要將控制展示狀態的屬性 dialogFormVisible 改為true接口顯示出新增窗口。點擊新建按鈕時綁定的方法為 handleCreate ,所以在 handleCreate 方法中修改dialogFormVisible 屬性的值為true即可。同時為了增加用戶體驗度,需要每次點擊新建按鈕時清空表單輸入項。

由于新增套餐時還需要選擇此套餐包含的跟團游,所以新增套餐窗口分為兩部分信息:基本信息和跟團游信息,如下圖:

(1):新建按鈕綁定單擊事件,對應的處理函數為handleCreate

<el-button type="primary" class="butT" @click="handleCreate()">新建</el-button>

(2):handleCreate()方法:

// 重置表單 resetForm() {// 清空套餐基本信息this.formData = {};// 選項卡設置成第一個this.activeName='first';// 重置跟團游的復選框this.travelgroupIds = [];// 重置上傳的圖片路徑this.imageUrl = null; }, // 彈出添加窗口 handleCreate() {this.dialogFormVisible = true;this.resetForm(); },

2.2.2. 動態展示跟團游列表

現在雖然已經完成了新增窗口的彈出,但是在跟團游信息標簽頁中需要動態展示所有的跟團游信息列表數據,并且可以進行勾選。具體操作步驟如下:

(1)定義模型數據

1 2 tableData:[],//添加表單窗口中跟團游列表數據 travelgroupIds:[],//添加表單窗口中跟團游復選框對應id

(2)動態展示跟團游列表數據,數據來源于上面定義的tableData模型數據

<el-tab-pane label="跟團游信息" name="second"> <div class="checkScrol"><table class="datatable"><thead><tr><th>選擇</th><th>項目編碼</th><th>項目名稱</th><th>項目說明</th></tr></thead><tbody><!--循環遍歷tableData--><tr v-for="c in tableData"><td><!--復選框綁定travelgroupIds,存放到值是id--><input :id="c.id" v-model="travelgroupIds" type="checkbox" :value="c.id"></td><td><label :for="c.id">{{c.code}}</label></td><td><label :for="c.id">{{c.name}}</label></td><td><label :for="c.id">{{c.remark}}</label></td></tr></tbody></table> </div> </el-tab-pane>

其中:v-model=“travelgroupIds”,用于回顯復選框。

(3)完善 handleCreate 方法,發送ajax請求查詢所有跟團游數據并將結果賦值給tableData模型數據用于頁面表格展示

// 彈出添加窗口 handleCreate() {this.dialogFormVisible = true;this.resetForm();axios.get("/travelgroup/findAll.do").then((res)=> {if(res.data.flag){this.tableData = res.data.data;}else{this.$message.error(res.data.message);}}); },

(4)分別在 TravelGroupController 、TravelGroupService 、TravelGroupServiceImpl 、TravelGroupDao 、TravelGroupDao.xml 中擴展方法查詢所有跟團游數據

1:TravelGroupController:

package com.atguigu.controller;import com.alibaba.dubbo.config.annotation.Reference; import com.atguigu.constant.MessageConstant; import com.atguigu.entity.PageResult; import com.atguigu.entity.QueryPageBean; import com.atguigu.entity.Result; import com.atguigu.pojo.TravelGroup; import com.atguigu.pojo.TravelItem; import com.atguigu.service.TravelGroupService; import org.springframework.web.bind.annotation.RequestBody; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RestController;import java.util.List;/*** TravelGroupController** @Author: 馬偉奇* @Description:*/ @RequestMapping("/travelgroup") @RestController public class TravelGroupController {@Referenceprivate TravelGroupService travelGroupService;//查詢所有@RequestMapping("/findAll")public Result findAll(){// 查詢所有的跟團游List<TravelGroup> travelGroupList = travelGroupService.findAll();if(travelGroupList != null && travelGroupList.size() > 0){Result result = new Result(true, MessageConstant.QUERY_SETMEAL_SUCCESS,travelGroupList);return result;}return new Result(false,MessageConstant.QUERY_SETMEAL_FAIL);}

2:TravelGroupService:

package com.atguigu.service;import com.atguigu.entity.PageResult; import com.atguigu.pojo.TravelGroup; import com.atguigu.pojo.TravelItem;import java.util.List;/*** TravelGroupService** @Author: 馬偉奇* @Description:*/ public interface TravelGroupService {List<TravelGroup> findAll();

3:TravelGroupServiceImpl:

package com.atguigu.service.impl;import com.alibaba.dubbo.config.annotation.Service; import com.atguigu.dao.TravelGroupDao; import com.atguigu.entity.PageResult; import com.atguigu.pojo.TravelGroup; import com.atguigu.pojo.TravelItem; import com.atguigu.service.TravelGroupService; import com.github.pagehelper.Page; import com.github.pagehelper.PageHelper; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.transaction.annotation.Transactional;import java.util.HashMap; import java.util.List; import java.util.Map;/*** TravelGroupServiceImpl** @Author: 馬偉奇* @Description:*/ @Service(interfaceClass = TravelGroupService.class) @Transactional public class TravelGroupServiceImpl implements TravelGroupService {@Autowiredprivate TravelGroupDao travelGroupDao;@Overridepublic List<TravelGroup> findAll() {return travelGroupDao.findAll();}

4:TravelGroupDao:

package com.atguigu.dao;import com.atguigu.pojo.TravelGroup; import com.atguigu.pojo.TravelItem; import com.github.pagehelper.Page;import java.util.List; import java.util.Map;/*** TravelGroupDao** @Author: 馬偉奇* @Description:*/ public interface TravelGroupDao {List<TravelGroup> findAll();

5:TravelGroupDao.xml:

<?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN""http://mybatis.org/dtd/mybatis-3-mapper.dtd" > <mapper namespace="com.atguigu.dao.TravelGroupDao"><select id="findAll" resultType="travelGroup">select * from t_travelgroup</select> </mapper>

運行程序 http://localhost:82/pages/main.html

2.2.3. 圖片上傳并預覽

此處使用的是ElementUI提供的上傳組件el-upload,提供了多種不同的上傳效果,上傳成功后可以進行預覽。

實現步驟:

(1)定義模型數據,用于后面上傳文件的圖片預覽:

imageUrl:null,//模型數據,用于上傳圖片完成后圖片預覽

(2)定義上傳組件:

<!--el-upload:上傳組件action:上傳的提交地址(七牛云服務器)auto-upload:選中文件后是否自動上傳name:上傳文件的名稱,服務端可以根據名稱獲得上傳的文件對象show-file-list:是否顯示已上傳文件列表on-success:文件上傳成功時的鉤子before-upload:上傳文件之前的鉤子 --> <el-uploadclass="avatar-uploader"action="/setmeal/upload.do":auto-upload="autoUpload"name="imgFile":show-file-list="false":on-success="handleAvatarSuccess":before-upload="beforeAvatarUpload"><!--用于上傳圖片預覽--><img v-if="imageUrl" :src="imageUrl" class="avatar"><!--用于展示上傳圖標--><i v-else class="el-icon-plus avatar-uploader-icon"></i> </el-upload>

(3)定義對應的鉤子函數:

// 注意axios執行url的時候,響應是通過resposne.data實現 // 注意elementUI執行url的時候,響應是通過resposne實現 //文件上傳成功后的鉤子,response為服務端返回的值,file為當前上傳的文件封裝成的js對象 handleAvatarSuccess(response, file) {// 對imageUrl賦值,將圖片顯示到文件上傳的框中,進行瀏覽this.imageUrl = "http://q2t6dfukt.bkt.clouddn.com/"+response.data; // 用于顯示this.$message({message: response.message,type: response.flag ? 'success' : 'error'});//設置模型數據(圖片名稱),后續提交ajax請求時會提交到后臺最終保存到數據庫this.formData.img = response.data; // 用于保存 }, //上傳圖片之前執行 beforeAvatarUpload(file) {const isJPG = file.type === 'image/jpeg';const isLt2M = file.size / 1024 / 1024 < 2;if (!isJPG) {this.$message.error('上傳套餐圖片只能是 JPG 格式!');}if (!isLt2M) {this.$message.error('上傳套餐圖片大小不能超過 2MB!');}return isJPG && isLt2M; },

(4)創建SetmealController,接收上傳的文件

package com.atguigu.controller;import com.alibaba.dubbo.config.annotation.Reference; import com.atguigu.constant.MessageConstant; import com.atguigu.entity.Result; import com.atguigu.service.SetmealService; import com.atguigu.utils.QiniuUtils; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RestController; import org.springframework.web.multipart.MultipartFile;import java.io.IOException; import java.util.UUID;/*** SetmealController** @Author: 馬偉奇* @Description:*/ @RestController @RequestMapping("/setmeal") public class SetmealController {@Referenceprivate SetmealService setmealService;// imgFile:需要跟頁面el-upload里面的name保持一致@RequestMapping("/upload")public Result upload(MultipartFile imgFile) {try {//獲取原始文件名String originalFilename = imgFile.getOriginalFilename();// 找到.最后出現的位置int lastIndexOf = originalFilename.lastIndexOf(".");//獲取文件后綴String suffix = originalFilename.substring(lastIndexOf);//使用UUID隨機產生文件名稱,防止同名文件覆蓋String fileName = UUID.randomUUID().toString() + suffix;QiniuUtils.upload2Qiniu(imgFile.getBytes(),fileName);//圖片上傳成功Result result = new Result(true, MessageConstant.PIC_UPLOAD_SUCCESS, fileName);return result;} catch (IOException e) {e.printStackTrace();}return new Result(false,MessageConstant.PIC_UPLOAD_FAIL);} }

注意:別忘了在spring配置文件中配置文件上傳組件

已在springmvc.xml中配置

<!--文件上傳組件--> <bean id="multipartResolver"class="org.springframework.web.multipart.commons.CommonsMultipartResolver"><property name="maxUploadSize" value="104857600" /><!--最大上傳文件大小--><property name="maxInMemorySize" value="4096" /><property name="defaultEncoding" value="UTF-8"/> </bean>

錯誤

解決方案

地區設置錯誤

// Zone.zone2():表示華南,設置對應的地區 Configuration cfg = new Configuration(Zone.zone2());

2.2.4. 提交請求

請求方式 post

調用地址

/setmeal/add.do

調用方requestparams子成員:

名稱類型必要說明
travelgroupIdsint跟團游id
formDataobject表單數據

formData子成員如下:

名稱類型必要說明
nameString名稱
codeString編碼
helpCodeString助記碼
sexString套餐適用性別:0不限 1男 2女
ageString套餐適用年齡
priceFloat套餐價格
remarkString評論
attentionString注意
imgString套餐對應圖片存儲路徑

當用戶點擊新增窗口中的確定按鈕時發送 ajax請求將數據提交到后臺進行數據庫操作。提交到后臺的數據分為兩部分:套餐基本信息(對應的模型數據為 formData)和跟團游 id數組(對應的模型數據為travelgroupIds)。

(1)為確定按鈕綁定單擊事件,對應的處理函數為handleAdd

<div slot="footer" class="dialog-footer"><el-button @click="dialogFormVisible = false">取消</el-button><el-button type="primary" @click="handleAdd()">確定</el-button> </div>

(2)完善handleAdd方法

//添加 handleAdd () {axios.post("/setmeal/add.do?travelgroupIds=" + this.travelgroupIds,this.formData).then((response)=> {this.dialogFormVisible = false;if(response.data.flag){this.$message({message: response.data.message,type: 'success'});}else{this.$message.error(response.data.message);}}).finally(()=> {this.findPage();}); },

2.3. 后臺代碼

2.3.1. Controller

在SetmealController中增加方法

package com.atguigu.controller;import com.alibaba.dubbo.config.annotation.Reference; import com.atguigu.constant.MessageConstant; import com.atguigu.entity.Result; import com.atguigu.pojo.Setmeal; import com.atguigu.service.SetmealService; import com.atguigu.utils.QiniuUtils; import org.springframework.web.bind.annotation.RequestBody; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RestController; import org.springframework.web.multipart.MultipartFile;import java.io.IOException; import java.util.UUID;/*** SetmealController** @Author: 馬偉奇* @Description:*/ @RestController @RequestMapping("/setmeal") public class SetmealController {@Referenceprivate SetmealService setmealService;//新增@RequestMapping("/add")public Result add(@RequestBody Setmeal setmeal, Integer[] travelgroupIds){try {setmealService.add(setmeal,travelgroupIds);}catch (Exception e){//新增套餐失敗return new Result(false,MessageConstant.ADD_SETMEAL_FAIL);}//新增套餐成功return new Result(true,MessageConstant.ADD_SETMEAL_SUCCESS);}

2.3.2. 服務接口

創建 SetmealService 接口并提供新增方法

package com.atguigu.service;import com.atguigu.pojo.Setmeal;/*** SetmealService** @Author: 馬偉奇* @Description:*/ public interface SetmealService {public void add(Setmeal setmeal, Integer[] travelgroupIds); }

2.3.3. 服務實現類

創建 SetmealServiceImpl 服務實現類并實現新增方法

package com.atguigu.service.impl;import com.alibaba.dubbo.config.annotation.Service; import com.atguigu.dao.SetmealDao; import com.atguigu.pojo.Setmeal; import com.atguigu.service.SetmealService; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.transaction.annotation.Transactional;import java.util.HashMap; import java.util.Map;/*** SetmealServiceImpl** @Author: 馬偉奇* @Description:*/ @Service(interfaceClass = SetmealService.class) @Transactional public class SetmealServiceImpl implements SetmealService {@Autowiredprivate SetmealDao setmealDao;@Overridepublic void add(Setmeal setmeal,Integer[] travelgroupId) {// 新增套餐setmealDao.add(setmeal);// 2:向套餐和跟團游的中間表中插入數據if(travelgroupId != null && travelgroupId.length > 0){//綁定套餐和跟團游的多對多關系setSetmealAndTravelGroup(setmeal.getId(),travelgroupId);}}//綁定套餐和跟團游的多對多關系private void setSetmealAndTravelGroup(Integer id, Integer[] travelgroupId) {for (Integer checkgroupId : travelgroupId) {Map<String, Integer> map = new HashMap<>();map.put("travelgroup_id",checkgroupId);map.put("setmeal_id",id);setmealDao.setSetmealAndTravelGroup(map);}} }

2.3.4. Dao接口

創建 SetmealDao 接口并提供相關方法

package com.atguigu.dao;import com.atguigu.pojo.Setmeal;import java.util.Map;/*** SetmealDao** @Author: 馬偉奇* @Description:*/ public interface SetmealDao {void add(Setmeal setmeal);void setSetmealAndTravelGroup(Map<String, Integer> map);}

2.3.5. Mapper映射文件

創建 SetmealDao.xml 文件并定義相關SQL語句

<?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN""http://mybatis.org/dtd/mybatis-3-mapper.dtd" > <mapper namespace="com.atguigu.dao.SetmealDao"><!--新增--><insert id="add" parameterType="setmeal"><selectKey resultType="int" order="AFTER" keyProperty="id">SELECT LAST_INSERT_ID()</selectKey>insert into t_setmeal(name,code,helpCode,sex,age,price,remark,attention,img) values (#{name},#{code},#{helpCode},#{sex},#{age},#{price},#{remark},#{attention},#{img})</insert><!--綁定套餐和跟團游多對多關系--><insert id="setSetmealAndTravelGroup" parameterType="map">insert intot_setmeal_travelgroup(setmeal_id,travelgroup_id)values (#{setmeal_id},#{travelgroup_id})</insert></mapper>

運行程序 http://localhost:82/pages/main.html

2.4. 完善文件上傳,Redis存儲圖片名稱(一會說)

前面我們已經完成了文件上傳,將圖片存儲在了七牛云服務器中。但是這個過程存在一個問題,就是如果用戶只上傳了圖片而沒有最終保存套餐信息到我們的數據庫,這時我們上傳的圖片就變為了垃圾圖片。對于這些垃圾圖片我們需要定時清理來釋放磁盤空間。這就需要我們能夠區分出來哪些是垃圾圖片,哪些不是垃圾圖片。如何實現呢?

方案就是利用redis來保存圖片名稱,具體做法為:

1、當用戶上傳圖片后,將圖片名稱保存到redis的一個Set集合中,例如集合名稱為 setmealPicResources

2、當用戶添加套餐后,將圖片名稱保存到redis的另一個Set集合中,例如集合名稱為setmealPicDbResources

3、計算 setmealPicResources集合與 setmealPicDbResources集合的差值,結果就是垃圾圖片的名稱集合,清理這些圖片即可

本小節我們先來完成前面2個環節,第3個環節(清理圖片環節)在后面會通過定時任務再實現。

實現步驟:

(1)在 meinian_web 項目中提供Spring配置文件 spring-redis.xml

<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xmlns:p="http://www.springframework.org/schema/p"xmlns:context="http://www.springframework.org/schema/context"xmlns:dubbo="http://code.alibabatech.com/schema/dubbo"xmlns:mvc="http://www.springframework.org/schema/mvc"xsi:schemaLocation="http://www.springframework.org/schema/beanshttp://www.springframework.org/schema/beans/spring-beans.xsdhttp://www.springframework.org/schema/mvchttp://www.springframework.org/schema/mvc/spring-mvc.xsdhttp://code.alibabatech.com/schema/dubbohttp://code.alibabatech.com/schema/dubbo/dubbo.xsdhttp://www.springframework.org/schema/contexthttp://www.springframework.org/schema/context/spring-context.xsd"><!--Jedis連接池的相關配置--><bean id="jedisPoolConfig" class="redis.clients.jedis.JedisPoolConfig"><!--最大連接數, 默認8個--><property name="maxTotal" value="100"></property><!--最大空閑連接數, 默認8個--><property name="maxIdle" value="50"></property><!--允許借調 在獲取連接的時候檢查有效性, 默認false--><property name="testOnBorrow" value="true"/><!--允許歸還 在return給pool時,是否提前進行validate操作--><property name="testOnReturn" value="true"/></bean><bean id="jedisPool" class="redis.clients.jedis.JedisPool"><constructor-arg name="poolConfig" ref="jedisPoolConfig" /><constructor-arg name="host" value="127.0.0.1" /><constructor-arg name="port" value="6379" type="int" /><constructor-arg name="timeout" value="30000" type="int" /></bean> </beans>

同時在springmvc.xml中使用 標簽引入

<import resource="classpath:spring-redis.xml"></import>

(2)在 meinian_common工程中提供Redis常量類

package com.atguigu.constant;/*** RedisConstant** @Author: 馬偉奇* @Description:*/ public class RedisConstant {//套餐圖片所有圖片名稱(七牛)public static final String SETMEAL_PIC_RESOURCES = "setmealPicResources";//套餐圖片保存在數據庫中的圖片名稱(數據庫)public static final String SETMEAL_PIC_DB_RESOURCES = "setmealPicDbResources"; }

(3)完善SetmealController,在文件上傳成功后將圖片名稱保存到 redis 集合中

@Autowired private JedisPool jedisPool;//圖片上傳 @RequestMapping("/upload") public Result upload(@RequestParam("imgFile")MultipartFile imgFile){try{//獲取原始文件名String originalFilename = imgFile.getOriginalFilename();int lastIndexOf = originalFilename.lastIndexOf(".");//獲取文件后綴String suffix = originalFilename.substring(lastIndexOf);//使用UUID隨機產生文件名稱,防止同名文件覆蓋String fileName = UUID.randomUUID().toString() + suffix;QiniuUtils.upload2Qiniu(imgFile.getBytes(),fileName);//圖片上傳成功Result result = new Result(true, MessageConstant.PIC_UPLOAD_SUCCESS,fileName);//將上傳圖片名稱存入Redis,基于Redis的Set集合存儲jedisPool.getResource().sadd(RedisConstant.SETMEAL_PIC_RESOURCES,fileName);return result;}catch (Exception e){e.printStackTrace();//圖片上傳失敗return new Result(false,MessageConstant.PIC_UPLOAD_FAIL);} }

添加:

//將上傳圖片名稱存入Redis,基于Redis的Set集合存儲 jedisPool.getResource().sadd(RedisConstant.SETMEAL_PIC_RESOURCES,fileName);

(4)在 meinian_service項目中提供Spring配置文件 applicationContext-redis.xml

meinian_service 里面的啟動方式在 web.xml 如下:所以可以直接加載 redis 配置文件

<context-param><param-name>contextConfigLocation</param-name><param-value>classpath*:applicationContext*.xml</param-value></context-param>

applicationContext-redis.xml 配置文件如下

<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xmlns:p="http://www.springframework.org/schema/p"xmlns:context="http://www.springframework.org/schema/context"xmlns:dubbo="http://code.alibabatech.com/schema/dubbo"xmlns:mvc="http://www.springframework.org/schema/mvc"xsi:schemaLocation="http://www.springframework.org/schema/beanshttp://www.springframework.org/schema/beans/spring-beans.xsdhttp://www.springframework.org/schema/mvchttp://www.springframework.org/schema/mvc/spring-mvc.xsdhttp://code.alibabatech.com/schema/dubbohttp://code.alibabatech.com/schema/dubbo/dubbo.xsdhttp://www.springframework.org/schema/contexthttp://www.springframework.org/schema/context/spring-context.xsd"><!--Jedis連接池的相關配置--><bean id="jedisPoolConfig" class="redis.clients.jedis.JedisPoolConfig"><property name="maxTotal"><value>200</value></property><property name="maxIdle"><value>50</value></property><property name="testOnBorrow" value="true"/><property name="testOnReturn" value="true"/></bean><bean id="jedisPool" class="redis.clients.jedis.JedisPool"><constructor-arg name="poolConfig" ref="jedisPoolConfig" /><constructor-arg name="host" value="127.0.0.1" /><constructor-arg name="port" value="6379" type="int" /><constructor-arg name="timeout" value="30000" type="int" /></bean> </beans>

(5)完善 SetmealServiceImpl 服務類,在保存完成套餐信息后將圖片名稱存儲到 redis 集合中

@Autowired private JedisPool jedisPool;//新增套餐 public void add(Setmeal setmeal, Integer[] travelgroupIds) {setmealDao.add(setmeal);if(travelgroupIds != null && travelgroupIds.length > 0){//綁定套餐和跟團游的多對多關系setSetmealAndTravelGroup(setmeal.getId(),travelgroupIds);}//將圖片名稱保存到RedissavePic2Redis(setmeal.getImg()); } //將圖片名稱保存到Redis private void savePic2Redis(String pic){jedisPool.getResource().sadd(RedisConstant.SETMEAL_PIC_DB_RESOURCES,pic); }

測試:

【小結】

1:需求分析

2:前臺代碼

(1)彈出新增窗口

(2)動態展示跟團游列表

(3)圖片上傳并預覽

  • 使用七牛云存儲圖片

(4)提交請求

  • 使用數據庫存儲圖片名稱
  • 使用springmvc的文件上傳技術

第一步:頁面定義上傳組件:

html<!--el-upload:上傳組件action:上傳的提交地址(七牛云服務器)auto-upload:選中文件后是否自動上傳name:上傳文件的名稱,服務端可以根據名稱獲得上傳的文件對象show-file-list:是否顯示已上傳文件列表on-success:文件上傳成功時的鉤子before-upload:上傳文件之前的鉤子--><el-uploadclass="avatar-uploader"action="/setmeal/upload.do":auto-upload="autoUpload"name="imgFile":show-file-list="false":on-success="handleAvatarSuccess":before-upload="beforeAvatarUpload"><!--用于上傳圖片預覽--><img v-if="imageUrl" :src="imageUrl" class="avatar"><!--用于展示上傳圖標--><i v-else class="el-icon-plus avatar-uploader-icon"></i></el-upload>

第二步:使用springmvc跳轉Controller,接收文件參數

java@RequestMapping("/upload")public Result upload(@RequestParam("imgFile")MultipartFile imgFile){}

第三步:配置springmvc.xml

xml<!--文件上傳組件--><bean id="multipartResolver"class="org.springframework.web.multipart.commons.CommonsMultipartResolver"><property name="maxUploadSize" value="104857600" /><!--最大上傳文件大小--><property name="maxInMemorySize" value="4096" /><property name="defaultEncoding" value="UTF-8"/></bean>

3:后臺代碼

業務:

  • 新增套餐

(1)SetmealController.java(Controller)

(1)SetmealService.java(服務接口)

(1)SetmealServiceImpl.java(服務實現類)

(1)SetmealDao.java(Dao接口)

(1)SetmealDao.xml(Mapper映射文件)

4:完善文件上傳,Redis存儲圖片名稱(一會說)

3. 第三章. 旅游套餐分頁

【目標】

旅游套餐列表分頁

【路徑】

1:前臺代碼

(1)定義分頁相關模型數據

(2)定義分頁方法

(3)完善分頁方法執行時機

2:后臺代碼

業務:

  • 旅游套餐分頁列表展示

(1)SetmealController.java(Controller)

(2)SetmealService.java(服務接口)

(3)SetmealServiceImpl.java(服務實現類)

(4)SetmealDao.java(Dao接口)

(5)SetmealDao.xml(Mapper映射文件)

導入分頁數據

INSERT INTO `t_setmeal` VALUES ('12', '公司年度旅游套餐(男女通用)', '0001', 'RZTJ', '0', '18-60', '300', '公司年度旅游套餐', null, 'a5e8e729-74ce-4939-bf36-9cdc02fb2ae51.jpg'); INSERT INTO `t_setmeal` VALUES ('13', '廣州長隆酒店+珠海長隆企鵝酒店雙飛5日自由行套餐', '0002', 'FHZA', '2', '18-60', '1200', '長隆酒店(廣州長隆野生動物世界店)位于廣州長隆旅游度假區中心地段,毗鄰長隆歡樂世界、長隆水上樂園、長隆野生動物世界、長隆飛鳥樂園和長隆國際大馬戲等主題樂園。交通便捷,多條園區穿梭巴往返長隆酒店和各大園區之間。珠海園區、機場快線、香港直通巴匯集其中,廣州地鐵3號線/7號線讓您的度假娛樂更快捷方便。 長隆酒店作為大型的生態主題酒店,主要以熱帶區域的人文文化風情為主基調。客房的擺設裝修以客為主,溫馨舒適,并有多種客房和套房類型選擇。酒店綠植圍繞,種類繁多,動物島置身于酒店之中,珍稀動物隨處可見。 酒店內配套多間風味各異的餐廳,讓你足不出戶品嘗環球美食。酒店配套室外泳池、室內四季恒溫泳池、健身房、童趣樂園、康體中心等,都是您商旅或者度假的上佳消遣地方。 國際會展中心更有可容納3,000人的6,000平方米宴會廳,擁有12米無柱高樓頂,配備LED屏幕,及大型內置8米升降舞臺、先進的多媒體視聽、通訊系統等商務會議設施。39個不同規格的豪華多功能會議廳。專業的銷售、服務團隊和完善的會議設施設備隨時準備為您提供一流的會議、展覽和宴會服務,打造一流的商務會議品牌。', null, 'd7114f3d-35bd-4e52-b0b5-9dfc83d54af72.jpg'); INSERT INTO `t_setmeal` VALUES ('14', '廈門+鼓浪嶼雙飛5日自由行套餐', '0003', 'YGBM', '0', '55-100', '1400', '鼓浪嶼的生活,是慵懶而優雅的,像極了歐洲某個古老的城市,不張揚,卻有著致命的吸引力——溫柔的陽光,蔚藍的大海,美妙的琴聲,靜靜矗立的老建筑,悠然自得的貓咪,所有的一切,總讓人忍不住想好好的,再談一場戀愛。   所以做了這樣的主題,就是想把所謂浪漫,狠狠地,徹底地,進行下去。要華麗,因為青春理應肆意和張揚;要低調,因為在心底,總有一個最柔軟最隱秘的角落,是只屬于你的。最重要的,是要浪漫。在流淌著音樂的房間里,看點點燭光搖曳,撒在床上的玫瑰花瓣香味隱約撲來,舉起手中的紅酒杯,兩個人,相視無語。cheers. 感謝你們,與我們分享這美好。也但愿我能,一直見證你們的幸福。', null, '1291b1fb-40c2-4558-b102-02e05c4cff6c3.jpg'); INSERT INTO `t_setmeal` VALUES ('15', '云南-昆明-大理-麗江-香格里拉雙飛8日游套餐', '0004', 'ZAGD', '0', '14-20', '2400', '今日行程無導游陪同,如您當日抵昆時間較早,可自行將行李寄存在入住酒店(貴重物品請自行保管好);隨后,自由活動(如抵達昆明時間尚早,可自行前往云南師范大學(西南聯合大學舊址)、昆明金馬碧雞坊、南屏街、、陸軍講武堂等景點游覽、(外出酒店時貴重物品請自行保管好,請到酒店前臺帶上酒店名片,方便打車回酒店)', null, '68c7c13f-8fc2-46c3-b5d6-f7ec7992dc6e1.jpg'); INSERT INTO `t_setmeal` VALUES ('3', '澳門威尼斯人商圈酒店雙飛3-5日自由行套餐', '0001', 'RZTJ', '0', '18-60', '300', '澳門巴黎人是全澳門乃至亞洲的一顆閃耀新星,您可以在此感受“光之城”巴黎的獨特藝術氣息與迷人魅力。這里有約2千余間法式客房及套房供您選擇,還有依照巴黎埃菲爾鐵塔1/2比例建造的巴黎鐵塔,讓您體驗獨特的浪漫風情。您還可以于170家精品名店享受購物樂趣,或是品嘗經典法式美食,欣賞精彩的娛樂表演,暢游水世界、兒童王國等各種娛樂項目,像巴黎人一樣體驗無處不在的浪漫與驚喜!', null, 'a5e8e729-74ce-4939-bf36-9cdc02fb2ae51.jpg'); INSERT INTO `t_setmeal` VALUES ('4', '香港九龍尖沙咀商圈雙飛3-8日自由行套餐', '0001', 'RZTJ', '0', '18-60', '300', '香港九龍珀麗酒店(Rosedale Hotel Kowloon)位于市中心繁華鬧市,地處九龍中心地帶,毗鄰多個購物、娛樂中心;酒店提供班車來往旺角、尖沙嘴和“圓方”購物區,方便賓客出行。 香港九龍珀麗酒店(Rosedale Hotel Kowloon) 設計精巧、新穎獨特,擁有精致、高雅的各式客房。酒店客房均配有LED智能電視、iPod/ iPhone 底座,讓您盡享便捷、舒適生活。', null, 'a5e8e729-74ce-4939-bf36-9cdc02fb2ae51.jpg'); INSERT INTO `t_setmeal` VALUES ('5', '海南-亞龍灣-三亞雙飛7日游', '0001', 'RZTJ', '0', '18-60', '300', '全程由旅游局指定餐廳用餐,嚴格把控餐飲質量,讓您安心享用每一頓飲食,盡情嘗特色美食,讓味蕾綻放在路上,品味舌尖上的海南 。', null, 'a5e8e729-74ce-4939-bf36-9cdc02fb2ae51.jpg'); INSERT INTO `t_setmeal` VALUES ('6', '麗江-大理-香格里拉雙飛6日游', '0001', 'RZTJ', '0', '18-60', '300', '云南地處高原,老年人體溫調節功能較差,易受涼感冒,所以衣服要帶得夠,以便隨時增減,行走出汗時,不要馬上脫衣敞懷。高原地區晝夜溫差大,睡前要蓋好被毯,夜間風起雨來時要關好門窗。', null, 'a5e8e729-74ce-4939-bf36-9cdc02fb2ae51.jpg'); INSERT INTO `t_setmeal` VALUES ('7', '海南-亞龍灣-三亞雙飛8日游', '0001', 'RZTJ', '0', '18-60', '300', '旅游中要有充足的休息和睡眠,若感到體力不支,可略著休息或減緩旅行。在長時間步行游覽時應隨時坐下小憩。', null, 'a5e8e729-74ce-4939-bf36-9cdc02fb2ae51.jpg');INSERT INTO `t_setmeal_travelgroup` VALUES ('12', '5'); INSERT INTO `t_setmeal_travelgroup` VALUES ('12', '6'); INSERT INTO `t_setmeal_travelgroup` VALUES ('12', '7'); INSERT INTO `t_setmeal_travelgroup` VALUES ('12', '8'); INSERT INTO `t_setmeal_travelgroup` VALUES ('12', '9'); INSERT INTO `t_setmeal_travelgroup` VALUES ('12', '10'); INSERT INTO `t_setmeal_travelgroup` VALUES ('14', '10'); INSERT INTO `t_setmeal_travelgroup` VALUES ('15', '10'); INSERT INTO `t_setmeal_travelgroup` VALUES ('12', '11'); INSERT INTO `t_setmeal_travelgroup` VALUES ('14', '11'); INSERT INTO `t_setmeal_travelgroup` VALUES ('15', '11'); INSERT INTO `t_setmeal_travelgroup` VALUES ('14', '12'); INSERT INTO `t_setmeal_travelgroup` VALUES ('14', '13'); INSERT INTO `t_setmeal_travelgroup` VALUES ('15', '13'); INSERT INTO `t_setmeal_travelgroup` VALUES ('13', '14'); INSERT INTO `t_setmeal_travelgroup` VALUES ('15', '14'); INSERT INTO `t_setmeal_travelgroup` VALUES ('13', '15'); INSERT INTO `t_setmeal_travelgroup` VALUES ('3', '5'); INSERT INTO `t_setmeal_travelgroup` VALUES ('3', '6'); INSERT INTO `t_setmeal_travelgroup` VALUES ('3', '7'); INSERT INTO `t_setmeal_travelgroup` VALUES ('3', '8'); INSERT INTO `t_setmeal_travelgroup` VALUES ('3', '9'); INSERT INTO `t_setmeal_travelgroup` VALUES ('3', '10'); INSERT INTO `t_setmeal_travelgroup` VALUES ('4', '10'); INSERT INTO `t_setmeal_travelgroup` VALUES ('15', '10'); INSERT INTO `t_setmeal_travelgroup` VALUES ('3', '11'); INSERT INTO `t_setmeal_travelgroup` VALUES ('4', '11'); INSERT INTO `t_setmeal_travelgroup` VALUES ('5', '11'); INSERT INTO `t_setmeal_travelgroup` VALUES ('4', '12'); INSERT INTO `t_setmeal_travelgroup` VALUES ('4', '13'); INSERT INTO `t_setmeal_travelgroup` VALUES ('5', '13'); INSERT INTO `t_setmeal_travelgroup` VALUES ('6', '14'); INSERT INTO `t_setmeal_travelgroup` VALUES ('5', '14'); INSERT INTO `t_setmeal_travelgroup` VALUES ('6', '15');

【講解】

3.1. 前臺代碼

3.1.1. 定義分頁相關模型數據

pagination: {//分頁相關模型數據currentPage: 1,//當前頁碼pageSize:10,//每頁顯示的記錄數total:0,//總記錄數queryString:null//查詢條件 }, dataList: [],//當前頁要展示的分頁列表數據

3.1.2. 定義分頁方法

請求方式 post

請求地址

/setmeal/findPage.do

調用方requestparams子成員:

名稱類型必要說明
currentPageInteger頁碼
pageSizeInteger每頁記錄數
queryStringString查詢條件

返回方result子成員:

名稱類型必要說明
dataListList當前頁結果
totalLong總記錄數

(1)在頁面中提供了findPage方法用于分頁查詢,為了能夠在setmeal.html頁面加載后直接可以展示分頁數據,可以在VUE提供的鉤子函數created中調用findPage方法

//鉤子函數,VUE對象初始化完成后自動執行 created() {this.findPage(); },

(2)findPage()方法:

//分頁查詢 findPage() {//分頁參數var param = {currentPage:this.pagination.currentPage,//頁碼pageSize:this.pagination.pageSize,//每頁顯示的記錄數queryString:this.pagination.queryString//查詢條件};//請求后臺axios.post("/setmeal/findPage.do",param).then((response)=> {//為模型數據賦值,基于VUE的雙向綁定展示到頁面this.dataList = response.data.rows;this.pagination.total = response.data.total;}); },

3.1.3. 完善分頁方法執行時機

除了在created鉤子函數中調用findPage方法查詢分頁數據之外,當用戶點擊查詢按鈕或者點擊分頁條中的頁碼時也需要調用findPage方法重新發起查詢請求。

(1)為查詢按鈕綁定單擊事件,調用findPage方法

<el-button @click="handleCurrentChange(1)" class="dalfBut">查詢</el-button>

(2)為分頁條組件綁定current-change事件,此事件是分頁條組件自己定義的事件,當頁碼改變時觸發,對應的處理函數為handleCurrentChange

<div class="pagination-container"><el-paginationclass="pagiantion"@current-change="handleCurrentChange":current-page="pagination.currentPage":page-size="pagination.pageSize"layout="total, prev, pager, next, jumper":total="pagination.total"></el-pagination> </div>

定義handleCurrentChange方法

//切換頁碼 handleCurrentChange(currentPage) {//currentPage為切換后的頁碼this.pagination.currentPage = currentPage;this.findPage(); }

3.2. 后臺代碼

3.2.1. Controller

在 SetmealController 中增加分頁查詢方法

package com.atguigu.controller;import com.alibaba.dubbo.config.annotation.Reference; import com.atguigu.constant.MessageConstant; import com.atguigu.entity.PageResult; import com.atguigu.entity.QueryPageBean; import com.atguigu.entity.Result; import com.atguigu.pojo.Setmeal; import com.atguigu.service.SetmealService; import com.atguigu.utils.QiniuUtils; import org.springframework.web.bind.annotation.RequestBody; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RestController; import org.springframework.web.multipart.MultipartFile;import java.io.IOException; import java.util.List; import java.util.UUID;/*** SetmealController** @Author: 馬偉奇* @Description:*/ @RestController @RequestMapping("/setmeal") public class SetmealController {//分頁查詢 @RequestMapping("/findPage") public PageResult findPage(@RequestBody QueryPageBean queryPageBean){PageResult pageResult = setmealService.findPage(queryPageBean.getCurrentPage(),queryPageBean.getPageSize(),queryPageBean.getQueryString());return pageResult; }

3.2.2. 服務接口

在 SetmealService 服務接口中擴展分頁查詢方法

package com.atguigu.service;import com.atguigu.entity.PageResult; import com.atguigu.pojo.Setmeal;/*** SetmealService** @Author: 馬偉奇* @Description:*/ public interface SetmealService {PageResult findPage(Integer currentPage, Integer pageSize, String queryString);

3.2.3. 服務實現類

在 SetmealServiceImpl 服務實現類中實現分頁查詢方法,基于Mybatis分頁助手插件實現分頁

package com.atguigu.service.impl;import com.alibaba.dubbo.config.annotation.Service; import com.atguigu.dao.SetmealDao; import com.atguigu.entity.PageResult; import com.atguigu.pojo.Setmeal; import com.atguigu.service.SetmealService; import com.github.pagehelper.Page; import com.github.pagehelper.PageHelper; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.transaction.annotation.Transactional;import java.util.HashMap; import java.util.Map;/*** SetmealServiceImpl** @Author: 馬偉奇* @Description:*/ @Service(interfaceClass = SetmealService.class) @Transactional public class SetmealServiceImpl implements SetmealService {@Autowiredprivate SetmealDao setmealDao;public PageResult findPage(Integer currentPage, Integer pageSize, String queryString) {PageHelper.startPage(currentPage,pageSize);Page<Setmeal> page = setmealDao.findPage(queryString);return new PageResult(page.getTotal(),page.getResult()); }

3.2.4. Dao接口

在 SetmealDao 接口中擴展分頁查詢方法

package com.atguigu.dao;import com.atguigu.pojo.Setmeal; import com.github.pagehelper.Page;import java.util.Map;/*** SetmealDao** @Author: 馬偉奇* @Description:*/ public interface SetmealDao {Page<Setmeal> findPage(String queryString);

3.2.5. Mapper映射文件

在 SetmealDao.xml 文件中增加SQL定義

<select id="findPage" parameterType="string" resultType="setmeal">select * from t_setmeal<where><if test="value!=null and value.length>0">code=#{value} or name like concat('%',#{value},'%') or helpCode=#{value}</if></where> </select>

程序運行 http://localhost:82/pages/main.html

【小結】

1:前臺代碼

(1)定義分頁相關模型數據

(2)定義分頁方法

(3)完善分頁方法執行時機

2:后臺代碼

業務:

  • 體檢套餐分頁列表展示

(1)SetmealController.java(Controller)

(2)SetmealService.java(服務接口)

(3)SetmealServiceImpl.java(服務實現類)

(4)SetmealDao.java(Dao接口)

(5)SetmealDao.xml(Mapper映射文件)

4. 第四章. 定時任務組件Quartz

【目標】

定時任務組件Quartz

  • 清除文件上傳所產生的垃圾圖片

【路徑】

1:Quart介紹

  • 掌握場景(定時任務)

2:Quartz入門案例

  • spring整合Quartz(spring中配置)

3:cron表達式

4:cron表達式在線生成器

【講解】

4.1. Quartz介紹

Quartz是Job scheduling(作業調度)領域的一個開源項目,Quartz既可以單獨使用也可以跟spring框架整合使用,在實際開發中一般會使用后者。使用Quartz可以開發一個或者多個定時任務,每個定時任務可以單獨指定執行的時間,例如每隔1小時執行一次、每個月第一天上午10點執行一次、每個月最后一天下午5點執行一次等。

官網:https://www.w3cschool.cn/quartz_doc/

簡單來說,就是可以幫助我們設置一個有規律的或者在某個具體的時間點干點想干的事的一個開源框架。

在使用Scheduler之前,需要實例化 , scheduler實例化后,可以啟動(start)、暫停(stand-by)、停止(shutdown)。

Quartz API的關鍵接口是:

  • Scheduler:任務調度器,所有的任務都是從這里開始。
  • Trigger:觸發器,定義任務執行的方式、間隔。
  • JobDetail & Job : 定義任務具體執行的邏輯。

Scheduler的生命期,從SchedulerFactory創建它時開始,到Scheduler調用shutdown()方法時結束;Scheduler被創建后,可以增加、刪除和列舉Job和Trigger,以及執行其它與調度相關的操作(如暫停Trigger)。但是,Scheduler只有在調用start()方法后,才會真正地觸發trigger(即執行job)

創建項目 quartz_demo 導入 maven 坐標:

<dependencies><!--引入Quartz的依賴--><dependency><groupId>org.quartz-scheduler</groupId><artifactId>quartz</artifactId><version>2.2.1</version></dependency><dependency><groupId>org.quartz-scheduler</groupId><artifactId>quartz-jobs</artifactId><version>2.2.1</version></dependency></dependencies>

Quartz 入門案例

① 創建QuartzTest

package com.atguigu;import org.quartz.*; import org.quartz.impl.StdSchedulerFactory;/*** QuartzTest** @Author: 馬偉奇* @Description:*/ public class QuartzTest {public static void main(String[] args) {try {//定義一個JobDetailJobDetail jobDetail = JobBuilder.newJob(HelloQuartz.class)//定義name和group 給觸發器一些屬性 比如名字,組名。.withIdentity("job1", "group1")//job需要傳遞的內容 具體job傳遞參數。.usingJobData("name", "sdas").build();//定義一個TriggerTrigger trigger = TriggerBuilder.newTrigger().withIdentity("trigger1", "group1")//加入 scheduler之后立刻執行 立刻啟動.startNow()//定時 ,每隔1秒鐘執行一次 以某種觸發器觸發。.withSchedule(SimpleScheduleBuilder.simpleSchedule().withIntervalInSeconds(1)//重復執行.repeatForever()).build();//創建schedulerScheduler scheduler = StdSchedulerFactory.getDefaultScheduler();scheduler.scheduleJob(jobDetail, trigger);// Scheduler只有在調用start()方法后,才會真正地觸發trigger(即執行job)scheduler.start(); //運行一段時間后關閉try {Thread.sleep(8000);} catch (InterruptedException e) {e.printStackTrace();}//Scheduler調用shutdown()方法時結束scheduler.shutdown();} catch (Exception e) {e.printStackTrace();}} }

② 創建HelloQuartz

package com.atguigu; import org.quartz.Job; import org.quartz.JobDetail; import org.quartz.JobExecutionContext;import java.util.Date; /*** HelloQuartz** @Author: 馬偉奇* @Description:*/ public class HelloQuartz implements Job {public void execute(JobExecutionContext jobExecutionContext) {JobDetail detail = jobExecutionContext.getJobDetail();String name = detail.getJobDataMap().getString("name");System.out.println("my job name is " + name + " at " + new Date());} }

執行程序

<!--spring整合Quartz--> <dependency><groupId>org.springframework</groupId><artifactId>spring-context-support</artifactId><version>5.0.2.RELEASE</version> </dependency>

4.2. Quartz整合springboot

創建項目 quartz_demo

添加pom文件

<!--父工程--><parent><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-parent</artifactId><version>2.1.6.RELEASE</version><relativePath/> <!-- lookup parent from repository --></parent><dependencies><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-test</artifactId><scope>test</scope></dependency><!-- 添加 Scheduled 坐標 --><dependency><groupId>org.springframework</groupId><artifactId>spring-context-support</artifactId><version>5.0.5.RELEASE</version></dependency></dependencies>

創建 BootApplication

package com.atguigu;import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; import org.springframework.scheduling.annotation.EnableScheduling;/*** BootApplication** @Author: 馬偉奇* @Description:*/ @SpringBootApplication @EnableScheduling public class BootApplication {public static void main(String[] args) {SpringApplication.run(BootApplication.class, args);} }

創建 TaskController

package com.atguigu.controller; import java.text.SimpleDateFormat; import java.util.Date;import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.scheduling.annotation.Scheduled; import org.springframework.stereotype.Controller; /*** TaskController** @Author: 馬偉奇* @Description:*/@Controller("Task") public class TaskController{@Scheduled(fixedDelay = 3000)public void myTask1(){SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");System.out.println(simpleDateFormat.format(new Date()));try {Thread.sleep(3000);} catch (InterruptedException e) {e.printStackTrace();}}@Scheduled(fixedRate = 3000)public void myTask2(){SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");System.out.println(simpleDateFormat.format(new Date()));try {Thread.sleep(5000);} catch (InterruptedException e) {e.printStackTrace();}}/*** cron:,項目啟動后每5秒執行一次* fixedDelay:距離上一次定時任務執行完畢后N毫秒在執行,* 比如參數是3000,上次執行A任務花了5秒,執行完成之后在過3秒執行* fixedRate:執行周期,執行頻率,* 上一個定時任務執行開始,在過N毫秒后執行,比如參數是3000,上次執行A任務花了2秒,在過1秒后執行,* 上次執行A任務花了15秒,任務執行后,直接執行** @auther* @return void*/@Scheduled(cron = "0/5 * * * * ?")public void cronTask(){logger.info("Cron方式-定時任務執行時間:"+ dateFormat.format(new Date()));}}

4.2. Quartz整合spring

【路徑】

1:創建maven工程quartzdemo,打包方式為war,導入jar包

2:自定義一個Job

3:提供Spring配置文件application-jobs.xml,配置自定義Job、任務描述、觸發器、調度工廠等

4:web.xml中定義

5:啟動tomcat完成測試

【講解】

本案例基于Quartz和spring整合的方式使用。具體步驟:

(1)創建maven工程quartz_demo,打包方式為war,導入Quartz和spring相關坐標,pom.xml文件如下

導入jar包

<?xml version="1.0" encoding="UTF-8"?> <project xmlns="http://maven.apache.org/POM/4.0.0"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"><modelVersion>4.0.0</modelVersion><groupId>com.atguigu</groupId><artifactId>quartz_demo</artifactId><version>1.0-SNAPSHOT</version><packaging>war</packaging><dependencies><dependency><groupId>org.springframework</groupId><artifactId>spring-context-support</artifactId><version>5.0.2.RELEASE</version></dependency><dependency><groupId>org.springframework</groupId><artifactId>spring-tx</artifactId><version>5.0.2.RELEASE</version></dependency><dependency><groupId>org.springframework</groupId><artifactId>spring-web</artifactId><version>5.0.2.RELEASE</version></dependency><dependency><groupId>org.quartz-scheduler</groupId><artifactId>quartz</artifactId><version>2.2.1</version></dependency><dependency><groupId>org.quartz-scheduler</groupId><artifactId>quartz-jobs</artifactId><version>2.2.1</version></dependency></dependencies><build><plugins><plugin><groupId>org.apache.tomcat.maven</groupId><artifactId>tomcat7-maven-plugin</artifactId><configuration><!-- 指定端口 --><port>8080</port><!-- 請求路徑 --><path>/</path></configuration></plugin></plugins></build> </project>

(2)自定義一個Job

package com.atguigu;/*** JobDemo** @Author: 馬偉奇* @Description:*/ // 任務調度類 public class JobDemo {// 提供方法(備份數據庫,清理日志,清理圖片)public void run(){// 完成業務System.out.println(new Date());} }

(3)提供Spring配置文件application-jobs.xml,配置自定義Job、任務描述、觸發器、調度工廠等

【路徑】

1:創建JobDetail對象,作用是負責通過反射調用指定的Job,注入目標對象,注入目標方法

2:注冊一個觸發器,指定任務觸發的時間

3:注冊一個統一的調度工廠,通過這個調度工廠調度任務

<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xmlns:context="http://www.springframework.org/schema/context"xsi:schemaLocation="http://www.springframework.org/schema/beanshttp://www.springframework.org/schema/beans/spring-beans.xsdhttp://www.springframework.org/schema/contexthttp://www.springframework.org/schema/context/spring-context.xsd"><!-- 注冊自定義Job --><bean id="jobDemo" class="com.atguigu.JobDemo"></bean><!-- 1:創建JobDetail對象,作用是負責通過反射調用指定的Job,注入目標對象,注入目標方法 --><bean id="jobDetail"class="org.springframework.scheduling.quartz.MethodInvokingJobDetailFactoryBean"><!-- 注入目標對象 --><property name="targetObject" ref="jobDemo"/><!-- 注入目標方法 --><property name="targetMethod" value="run"/></bean><!-- 2:注冊一個觸發器,指定任務觸發的時間 --><bean id="myTrigger" class="org.springframework.scheduling.quartz.CronTriggerFactoryBean"><!-- 注入JobDetail --><property name="jobDetail" ref="jobDetail"/><!-- 指定觸發的時間,基于Cron表達式(0/10表示從0秒開始,每10秒執行一次) --><property name="cronExpression"><value>0/10 * * * * ?</value></property></bean><!-- 3:注冊一個統一的調度工廠,通過這個調度工廠調度任務 --><bean id="scheduler" class="org.springframework.scheduling.quartz.SchedulerFactoryBean"><!-- 注入多個觸發器 --><property name="triggers"><list><ref bean="myTrigger"/></list></property></bean> </beans>

(4)web.xml中定義

啟動web,自動加載spring容器。

<?xml version="1.0" encoding="UTF-8"?> <web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xmlns="http://java.sun.com/xml/ns/javaee"xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd"id="WebApp_ID" version="3.0"><listener><listener-class>org.springframework.web.context.ContextLoaderListener</listener-class></listener><context-param><param-name>contextConfigLocation</param-name><param-value>classpath:application-jobs.xml</param-value></context-param> </web-app>

執行上面main方法觀察控制臺,可以發現每隔10秒會輸出一次,說明每隔10秒自定義Job被調用一次。

4.3. cron表達式

上面的入門案例中我們指定了一個表達式:0/10 * * * * ?

這種表達式稱為cron表達式,通過cron表達式可以靈活的定義出符合要求的程序執行的時間。本小節我們就來學習一下cron表達式的使用方法。如下圖:

cron表達式分為七個域,之間使用空格分隔。其中最后一個域(年)可以為空。每個域都有自己允許的值和一些特殊字符構成。使用這些特殊字符可以使我們定義的表達式更加靈活。

下面是對這些特殊字符的介紹:

逗號(,):指定一個值列表,例如使用在月域上1,4,5,7表示1月、4月、5月和7月

橫杠(-):指定一個范圍,例如在時域上3-6表示3點到6點(即3點、4點、5點、6點)

星號(*):表示這個域上包含所有合法的值。例如,在月份域上使用星號意味著每個月都會觸發

斜線(/):表示遞增,例如使用在秒域上0/15表示每15秒

問號(?):只能用在日和周域上,但是不能在這兩個域上同時使用。表示不指定,例如想在每月的20日觸發調度,不管20日到底是星期幾,則只能使用如下寫法: 13 13 15 20 * ?, 其中最后一位只能用?,而不能使用 *,如果使用 * 表示不管星期幾都會觸發,實際上并不是這樣。

井號(#):只能使用在周域上,用于指定月份中的第幾周的哪一天,例如6#3,意思是某月的第三個周五 (6=星期五,3意味著月份中的第三周)

L:某域上允許的最后一個值。只能使用在日和周域上。當用在日域上,表示的是在月域上指定的月份的最后一天。用于周域上時,表示周的最后一天,就是星期六

W:W 字符代表著工作日 (星期一到星期五),只能用在日域上,它用來指定離指定日的最近的一個工作日

4.3.1 常用表達式例子

(1)0 0 2 1 * ? * 表示在每月的1日的凌晨2點調整任務(2)0 15 10 ? * MON-FRI 表示周一到周五每天上午10:15執行作業(3)0 0 10,14,16 * * ? 每天上午10點,下午2點,4點 (4)0 0 12 ? * WED 表示每個星期三中午12點 (5)0 0 12 * * ? 每天中午12點觸發 (6)0 15 10 ? * * 每天上午10:15觸發 (7)0 15 10 * * ? 每天上午10:15觸發 (8)0 15 10 * * ? * 每天上午10:15觸發 (9)0 15 10 * * ? 2005 2005年的每天上午10:15觸發 (10)0 * 14 * * ? 在每天下午2點到下午2:59期間的每1分鐘觸發 (11)0 0/5 14 * * ? 在每天下午2點到下午2:55期間的每5分鐘觸發 (12)0 0/5 14,18 * * ? 在每天下午2點到2:55期間和下午6點到6:55期間的每5分鐘觸發 (13)0 0-5 14 * * ? 在每天下午2點到下午2:05期間的每1分鐘觸發 (14)0 10,44 14 ? 3 WED 每年三月的星期三的下午2:10和2:44觸發 (15)0 15 10 ? * MON-FRI 周一至周五的上午10:15觸發 (16)0 15 10 15 * ? 每月15日上午10:15觸發 (17)0 15 10 L * ? 每月最后一日的上午10:15觸發 (18)0 15 10 ? * 6L 每月的最后一個星期五上午10:15觸發 (19)0 15 10 ? * 6L 2002-2005 2002年至2005年的每月的最后一個星期五上午10:15觸發 (20)0 15 10 ? * 6#3 每月的第三個星期五上午10:15觸發(21)0 15 10 ? 6L 2002-2006 表示2002-2006年的每個月的最后一個星期五上午10:15執行作(22)0 0/30 9-17 * * ? 朝九晚五工作時間內每半小時

4.4. cron表達式在線生成器

前面介紹了cron表達式,但是自己編寫表達式還是有一些困難的,我們可以借助一些cron表達式在線生成器來根據我們的需求生成表達式即可。

http://cron.qqe2.com/

【小結】

1:Quart介紹

  • 掌握場景(定時任務)

2:Quartz入門案例

  • spring整合Quartz(spring中配置)

3:cron表達式

4:cron表達式在線生成器

http://cron.qqe2.com/

5. 第五章. 定時清理垃圾圖片

【目標】

Quartz整合項目,完成定時清理垃圾圖片

【路徑】

1:創建maven聚合工程meinian_jobs,打包方式為war,導入Quartz等相關坐標

2:配置web.xml

  • web容器啟動,加載spring容器

3:配置log4j.properties

4:配置applicationContext-redis.xml

  • spring整合redis

5:配置applicationContext-jobs.xml

  • spring整合Quartz

6:創建ClearImgJob定時任務類

  • 使用Quartz清理垃圾圖片

【講解】

前面我們已經完成了旅游套餐的管理,在新增套餐時套餐的基本信息和圖片是分兩次提交到后臺進行操作的。也就是用戶首先將圖片上傳到七牛云服務器,然后再提交新增窗口中錄入的其他信息。如果用戶只是上傳了圖片而沒有提交錄入的其他信息,此時的圖片就變為了垃圾圖片,因為在數據庫中并沒有記錄它的存在。此時我們要如何處理這些垃圾圖片呢?

解決方案就是通過定時任務組件定時清理這些垃圾圖片。為了能夠區分出來哪些圖片是垃圾圖片,我們在文件上傳成功后將圖片保存到了一個 redis 集合中,當套餐數據插入到數據庫后我們又將圖片名稱保存到了另一個redis集合中,通過計算這兩個集合的差值就可以獲得所有垃圾圖片的名稱。

本章節我們就會基于Quartz 定時任務,通過計算 redis 兩個集合的差值找出所有的垃圾圖片,就可以將垃圾圖片清理掉。

操作步驟:

(1)創建maven聚合工程 meinian_jobs ,打包方式為war,導入Quartz等相關坐標

<?xml version="1.0" encoding="UTF-8"?> <project xmlns="http://maven.apache.org/POM/4.0.0"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"><parent><artifactId>meinian_parent</artifactId><groupId>com.atguigu</groupId><version>1.0-SNAPSHOT</version></parent><modelVersion>4.0.0</modelVersion><artifactId>meinian_jobs</artifactId><packaging>war</packaging><properties><project.build.sourceEncoding>UTF-8</project.build.sourceEncoding><maven.compiler.source>1.8</maven.compiler.source><maven.compiler.target>1.8</maven.compiler.target></properties><dependencies><dependency><groupId>com.atguigu</groupId><artifactId>meinian_interface</artifactId><version>1.0-SNAPSHOT</version></dependency><dependency><groupId>org.quartz-scheduler</groupId><artifactId>quartz</artifactId></dependency><dependency><groupId>org.quartz-scheduler</groupId><artifactId>quartz-jobs</artifactId></dependency></dependencies><build><plugins><plugin><groupId>org.apache.tomcat.maven</groupId><artifactId>tomcat7-maven-plugin</artifactId><configuration><!-- 指定端口 --><port>83</port><!-- 請求路徑 --><path>/</path></configuration></plugin></plugins></build> </project>

(2)配置web.xml

<?xml version="1.0" encoding="UTF-8"?> <web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xmlns="http://java.sun.com/xml/ns/javaee"xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd"id="WebApp_ID" version="3.0"><display-name>Archetype Created Web Application</display-name><!-- 加載spring容器 --><context-param><param-name>contextConfigLocation</param-name><param-value>classpath*:applicationContext*.xml</param-value></context-param><listener><listener-class>org.springframework.web.context.ContextLoaderListener</listener-class></listener> </web-app>

(3)配置log4j.properties

### direct log messages to stdout ### log4j.appender.stdout=org.apache.log4j.ConsoleAppender log4j.appender.stdout.Target=System.err log4j.appender.stdout.layout=org.apache.log4j.PatternLayout log4j.appender.stdout.layout.ConversionPattern=%d{ABSOLUTE} %5p %c{1}:%L - %m%n### direct messages to file mylog.log ### log4j.appender.file=org.apache.log4j.FileAppender log4j.appender.file.File=c:\\mylog.log log4j.appender.file.layout=org.apache.log4j.PatternLayout log4j.appender.file.layout.ConversionPattern=%d{ABSOLUTE} %5p %c{1}:%L - %m%n### set log levels - for more verbose logging change 'info' to 'debug' ###log4j.rootLogger=debug, stdout

(4)配置applicationContext-redis.xml

<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xmlns:p="http://www.springframework.org/schema/p"xmlns:context="http://www.springframework.org/schema/context"xmlns:dubbo="http://code.alibabatech.com/schema/dubbo"xmlns:mvc="http://www.springframework.org/schema/mvc"xsi:schemaLocation="http://www.springframework.org/schema/beanshttp://www.springframework.org/schema/beans/spring-beans.xsdhttp://www.springframework.org/schema/mvchttp://www.springframework.org/schema/mvc/spring-mvc.xsdhttp://code.alibabatech.com/schema/dubbohttp://code.alibabatech.com/schema/dubbo/dubbo.xsdhttp://www.springframework.org/schema/contexthttp://www.springframework.org/schema/context/spring-context.xsd"><!--Jedis連接池的相關配置--><bean id="jedisPoolConfig" class="redis.clients.jedis.JedisPoolConfig"><!--在指定時刻通過pool能夠獲取到的最大的連接的jedis個數--><property name="maxTotal"><value>200</value></property><!--最大能夠保持idle的數量--><property name="maxIdle"><value>50</value></property><!--表示連接池在創建鏈接的時候會先測試一下鏈接是否可用,這樣可以保證連接池中的鏈接都可用的。--><property name="testOnBorrow" value="true"/><property name="testOnReturn" value="true"/></bean><bean id="jedisPool" class="redis.clients.jedis.JedisPool"><constructor-arg name="poolConfig" ref="jedisPoolConfig" /><constructor-arg name="host" value="127.0.0.1" /><constructor-arg name="port" value="6379" type="int" /><constructor-arg name="timeout" value="30000" type="int" /></bean> </beans>

(5)配置 applicationContext-jobs.xml

使用組件:

<!--組件的掃描 開啟注解配置支持,否則在ClearImgJob不能使用@Autowired--> <context:component-scan base-package="com.atguigu"></context:component-scan> <?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xmlns:context="http://www.springframework.org/schema/context"xsi:schemaLocation="http://www.springframework.org/schema/beanshttp://www.springframework.org/schema/beans/spring-beans.xsdhttp://www.springframework.org/schema/contexthttp://www.springframework.org/schema/context/spring-context.xsd"><!--開啟注解配置支持,否則在ClearImgJob不能使用@Autowired--><context:component-scan base-package="com.atguigu"></context:component-scan><!-- 注冊自定義Job --><bean id="jobDemo" class="com.atguigu.job.ClearImgJob"></bean><!-- 注冊JobDetail,作用是負責通過反射調用指定的Job --><bean id="jobDetail"class="org.springframework.scheduling.quartz.MethodInvokingJobDetailFactoryBean"><!-- 注入目標對象 --><property name="targetObject" ref="jobDemo"/><!-- 注入目標方法 --><property name="targetMethod" value="clearImg"/></bean><!-- 注冊一個觸發器,指定任務觸發的時間 --><bean id="myTrigger" class="org.springframework.scheduling.quartz.CronTriggerFactoryBean"><!-- 注入JobDetail --><property name="jobDetail" ref="jobDetail"/><!-- 指定觸發的時間,基于Cron表達式(0 0 2 * * ?表示凌晨2點執行) --><!-- 指定觸發的時間,基于Cron表達式(0 25 12 * * ?表示12點25分執行) --><property name="cronExpression"><value>0 0 2 * * ?</value></property></bean><!-- 注冊一個統一的調度工廠,通過這個調度工廠調度任務 --><bean id="scheduler" class="org.springframework.scheduling.quartz.SchedulerFactoryBean"><!-- 注入多個觸發器 --><property name="triggers"><list><ref bean="myTrigger"/></list></property></bean> </beans>

(6)創建ClearImgJob定時任務類

package com.atguigu.job;import com.atguigu.constant.RedisConstant; import com.atguigu.utils.QiniuUtils; import org.springframework.beans.factory.annotation.Autowired; import redis.clients.jedis.JedisPool;import java.util.Iterator; import java.util.Set;/*** ClearImgJob** @Author: 馬偉奇* @Description:*/ public class ClearImgJob {@Autowiredprivate JedisPool jedisPool;//清理圖片public void clearImg(){//計算redis中兩個集合的差值,獲取垃圾圖片名稱// 需要注意:在比較的時候,數據多的放到前面,如果pic多,那么pic放到前面,db多,db放到前面Set<String> set = jedisPool.getResource().sdiff(RedisConstant.SETMEAL_PIC_RESOURCES,RedisConstant.SETMEAL_PIC_DB_RESOURCES);Iterator<String> iterator = set.iterator();while(iterator.hasNext()){String pic = iterator.next();System.out.println("刪除圖片的名稱是:"+pic);//刪除圖片服務器中的圖片文件QiniuUtils.deleteFileFromQiniu(pic);//刪除redis中的數據jedisPool.getResource().srem(RedisConstant.SETMEAL_PIC_RESOURCES,pic);}} }

測試:

注意:如果 redis 服務端啟動如下,不需要擔心,直接使用 , 只是沒有圖標而已。

【小結】

1:創建maven聚合工程 meinian_jobs ,打包方式為war,導入Quartz等相關坐標

2:配置web.xml

  • web容器啟動,加載spring容器

3:配置log4j.properties

4:配置applicationContext-redis.xml

  • spring整合redis

5:配置applicationContext-jobs.xml

  • spring整合Quartz

6:創建ClearImgJob定時任務類

  • 使用Quartz清理垃圾圖片
    m.atguigu.job.ClearImgJob">




    0 0 2 * * ?
```

(6)創建ClearImgJob定時任務類

package com.atguigu.job;import com.atguigu.constant.RedisConstant; import com.atguigu.utils.QiniuUtils; import org.springframework.beans.factory.annotation.Autowired; import redis.clients.jedis.JedisPool;import java.util.Iterator; import java.util.Set;/*** ClearImgJob** @Author: 馬偉奇* @Description:*/ public class ClearImgJob {@Autowiredprivate JedisPool jedisPool;//清理圖片public void clearImg(){//計算redis中兩個集合的差值,獲取垃圾圖片名稱// 需要注意:在比較的時候,數據多的放到前面,如果pic多,那么pic放到前面,db多,db放到前面Set<String> set = jedisPool.getResource().sdiff(RedisConstant.SETMEAL_PIC_RESOURCES,RedisConstant.SETMEAL_PIC_DB_RESOURCES);Iterator<String> iterator = set.iterator();while(iterator.hasNext()){String pic = iterator.next();System.out.println("刪除圖片的名稱是:"+pic);//刪除圖片服務器中的圖片文件QiniuUtils.deleteFileFromQiniu(pic);//刪除redis中的數據jedisPool.getResource().srem(RedisConstant.SETMEAL_PIC_RESOURCES,pic);}} }

測試:

[外鏈圖片轉存中…(img-78Qc0k5F-1654660667120)]

注意:如果 redis 服務端啟動如下,不需要擔心,直接使用 , 只是沒有圖標而已。

[外鏈圖片轉存中…(img-y4qLs3If-1654660667121)]

【小結】

1:創建maven聚合工程 meinian_jobs ,打包方式為war,導入Quartz等相關坐標

2:配置web.xml

  • web容器啟動,加載spring容器

3:配置log4j.properties

4:配置applicationContext-redis.xml

  • spring整合redis

5:配置applicationContext-jobs.xml

  • spring整合Quartz

6:創建ClearImgJob定時任務類

  • 使用Quartz清理垃圾圖片

總結

以上是生活随笔為你收集整理的java+ElementUI前后端分离旅游项目第三天 预约管理的全部內容,希望文章能夠幫你解決所遇到的問題。

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

国产成人无码一二三区视频 | 永久黄网站色视频免费直播 | 久久人人97超碰a片精品 | 亚洲一区二区三区国产精华液 | 欧美一区二区三区视频在线观看 | 亚洲精品国偷拍自产在线麻豆 | 红桃av一区二区三区在线无码av | 亚洲中文字幕无码中文字在线 | 欧美真人作爱免费视频 | 欧美老人巨大xxxx做受 | 少妇厨房愉情理9仑片视频 | 人人澡人人妻人人爽人人蜜桃 | 国产精品亚洲五月天高清 | 久久综合给合久久狠狠狠97色 | 免费视频欧美无人区码 | 成人片黄网站色大片免费观看 | 性生交大片免费看女人按摩摩 | 狠狠cao日日穞夜夜穞av | 国产福利视频一区二区 | 中文字幕av无码一区二区三区电影 | 人妻少妇被猛烈进入中文字幕 | 亚洲综合伊人久久大杳蕉 | 亚洲国产成人av在线观看 | 水蜜桃av无码 | 国产午夜手机精彩视频 | 乌克兰少妇性做爰 | 欧美猛少妇色xxxxx | 国产热a欧美热a在线视频 | 人人妻人人澡人人爽欧美精品 | 国产乡下妇女做爰 | 国产高清不卡无码视频 | 欧美人与物videos另类 | 亚洲熟妇色xxxxx亚洲 | 国产精品对白交换视频 | 国产精品福利视频导航 | 四虎4hu永久免费 | 九九热爱视频精品 | 蜜臀av无码人妻精品 | 99久久婷婷国产综合精品青草免费 | 国内丰满熟女出轨videos | 乌克兰少妇xxxx做受 | 国产真实伦对白全集 | 色狠狠av一区二区三区 | 欧美日本日韩 | 久久久久99精品成人片 | 亚洲а∨天堂久久精品2021 | 国产热a欧美热a在线视频 | 巨爆乳无码视频在线观看 | 国产亚洲日韩欧美另类第八页 | 精品无码国产一区二区三区av | 日本高清一区免费中文视频 | 荫蒂添的好舒服视频囗交 | 日本乱人伦片中文三区 | 永久免费观看国产裸体美女 | 国产亚洲欧美日韩亚洲中文色 | 国产精品久久久久无码av色戒 | 一本大道伊人av久久综合 | 中文字幕乱码中文乱码51精品 | 亚洲精品国产精品乱码视色 | 中文字幕人妻无码一区二区三区 | 四虎影视成人永久免费观看视频 | 夫妻免费无码v看片 | 无码人妻av免费一区二区三区 | 国产无套粉嫩白浆在线 | 国产又爽又黄又刺激的视频 | 免费观看激色视频网站 | 少妇人妻大乳在线视频 | 亚洲s码欧洲m码国产av | 亚洲呦女专区 | 伊人久久大香线蕉亚洲 | 国产手机在线αⅴ片无码观看 | 亚洲国产高清在线观看视频 | 久久久久久国产精品无码下载 | 亚洲乱码中文字幕在线 | 色妞www精品免费视频 | 亚洲色偷偷男人的天堂 | 国产成人午夜福利在线播放 | 夜夜夜高潮夜夜爽夜夜爰爰 | 荡女精品导航 | 欧美阿v高清资源不卡在线播放 | 欧美黑人巨大xxxxx | 清纯唯美经典一区二区 | 欧美老妇交乱视频在线观看 | 欧美日韩综合一区二区三区 | 精品久久8x国产免费观看 | a在线亚洲男人的天堂 | 人人妻人人澡人人爽精品欧美 | 色偷偷人人澡人人爽人人模 | 亚洲一区二区三区在线观看网站 | 无码av最新清无码专区吞精 | 精品国产青草久久久久福利 | 丰满肥臀大屁股熟妇激情视频 | 成 人 网 站国产免费观看 | 亚洲成av人片天堂网无码】 | 亲嘴扒胸摸屁股激烈网站 | 十八禁视频网站在线观看 | 中文无码伦av中文字幕 | 亚洲 欧美 激情 小说 另类 | 人人澡人摸人人添 | 老熟妇乱子伦牲交视频 | 久久久中文久久久无码 | 麻豆蜜桃av蜜臀av色欲av | 日韩av激情在线观看 | 久久99精品久久久久婷婷 | 国产办公室秘书无码精品99 | 欧美xxxxx精品 | 兔费看少妇性l交大片免费 | 熟女体下毛毛黑森林 | 大乳丰满人妻中文字幕日本 | 色婷婷综合激情综在线播放 | 国内老熟妇对白xxxxhd | 无码人妻av免费一区二区三区 | 国内精品久久久久久中文字幕 | 亚洲日韩一区二区 | 成人无码视频在线观看网站 | 国产午夜视频在线观看 | 中文字幕乱妇无码av在线 | 国产成人综合美国十次 | 97久久超碰中文字幕 | 午夜福利不卡在线视频 | 亚洲综合无码久久精品综合 | 日韩欧美中文字幕在线三区 | √8天堂资源地址中文在线 | 亚洲中文无码av永久不收费 | 亚洲人成人无码网www国产 | 亚无码乱人伦一区二区 | 丰满少妇高潮惨叫视频 | 久久www免费人成人片 | 天堂а√在线中文在线 | 无码人妻少妇伦在线电影 | 欧美zoozzooz性欧美 | 日韩亚洲欧美精品综合 | 精品无码一区二区三区的天堂 | 欧美野外疯狂做受xxxx高潮 | 奇米影视7777久久精品 | 人妻少妇精品久久 | 亚洲一区二区三区含羞草 | 99久久精品日本一区二区免费 | 色婷婷久久一区二区三区麻豆 | 日韩欧美中文字幕在线三区 | 性生交大片免费看l | 欧美性猛交xxxx富婆 | 亚洲区小说区激情区图片区 | 中文字幕av无码一区二区三区电影 | 99久久久国产精品无码免费 | 国产成人无码专区 | 亚洲中文无码av永久不收费 | 正在播放老肥熟妇露脸 | 日韩在线不卡免费视频一区 | 色综合久久网 | 无码人中文字幕 | 伊人色综合久久天天小片 | 国产真实伦对白全集 | 久久国产精品_国产精品 | 99精品视频在线观看免费 | 国产口爆吞精在线视频 | 少妇高潮喷潮久久久影院 | 亚洲国产精华液网站w | 成人片黄网站色大片免费观看 | 久久久久免费精品国产 | 欧美人与禽zoz0性伦交 | 少妇厨房愉情理9仑片视频 | 国产成人无码av一区二区 | 日日鲁鲁鲁夜夜爽爽狠狠 | 天堂亚洲免费视频 | 精品久久久久香蕉网 | 亚洲国产精品无码久久久久高潮 | 国产午夜无码精品免费看 | 久久久精品成人免费观看 | 99精品国产综合久久久久五月天 | 国内精品人妻无码久久久影院蜜桃 | 97夜夜澡人人双人人人喊 | 国产在线精品一区二区三区直播 | 欧美日韩久久久精品a片 | 亚洲综合无码一区二区三区 | 樱花草在线播放免费中文 | 18禁止看的免费污网站 | 少妇高潮喷潮久久久影院 | 午夜福利试看120秒体验区 | 国产在线aaa片一区二区99 | 国产人妖乱国产精品人妖 | 色五月丁香五月综合五月 | 天天摸天天碰天天添 | 天天做天天爱天天爽综合网 | 无套内谢的新婚少妇国语播放 | 国产亚洲欧美在线专区 | 久久久久久国产精品无码下载 | 荫蒂添的好舒服视频囗交 | 亚欧洲精品在线视频免费观看 | 国产一区二区三区精品视频 | 亚洲天堂2017无码 | 欧洲欧美人成视频在线 | 亚洲阿v天堂在线 | 成熟人妻av无码专区 | 亚洲综合色区中文字幕 | 国产在线aaa片一区二区99 | 中文字幕乱码人妻无码久久 | 国产女主播喷水视频在线观看 | 久久国产精品萌白酱免费 | 亚洲欧洲日本综合aⅴ在线 | 亚洲精品综合一区二区三区在线 | 亚洲国产精华液网站w | 精品人妻人人做人人爽夜夜爽 | 色婷婷香蕉在线一区二区 | 狠狠色丁香久久婷婷综合五月 | 国产熟妇高潮叫床视频播放 | 国产欧美熟妇另类久久久 | а√天堂www在线天堂小说 | 精品午夜福利在线观看 | 人人妻人人澡人人爽人人精品浪潮 | 无码免费一区二区三区 | 蜜桃臀无码内射一区二区三区 | 国产情侣作爱视频免费观看 | 亚洲中文字幕无码中文字在线 | 国产又粗又硬又大爽黄老大爷视 | 男人扒开女人内裤强吻桶进去 | 国产精品高潮呻吟av久久 | 乱人伦人妻中文字幕无码久久网 | 久久午夜夜伦鲁鲁片无码免费 | 熟妇人妻无乱码中文字幕 | 欧美老熟妇乱xxxxx | 伊人久久大香线焦av综合影院 | 免费乱码人妻系列无码专区 | 亚洲成a人片在线观看无码 | 欧美性生交xxxxx久久久 | 婷婷色婷婷开心五月四房播播 | 国产情侣作爱视频免费观看 | 无码av免费一区二区三区试看 | 香港三级日本三级妇三级 | 四虎4hu永久免费 | 成在人线av无码免观看麻豆 | 77777熟女视频在线观看 а天堂中文在线官网 | 国产精品无码成人午夜电影 | 天天燥日日燥 | 无码人妻出轨黑人中文字幕 | 欧美高清在线精品一区 | 亚洲狠狠色丁香婷婷综合 | 亚洲国产精品无码久久久久高潮 | 色情久久久av熟女人妻网站 | 国产极品美女高潮无套在线观看 | 波多野结衣aⅴ在线 | 中文无码成人免费视频在线观看 | 国产成人精品一区二区在线小狼 | 成人综合网亚洲伊人 | 玩弄少妇高潮ⅹxxxyw | 国产精品无码一区二区三区不卡 | 人妻无码久久精品人妻 | 人妻体内射精一区二区三四 | 四虎国产精品免费久久 | 无遮挡国产高潮视频免费观看 | 无码播放一区二区三区 | 中文字幕乱码亚洲无线三区 | 18精品久久久无码午夜福利 | 欧美高清在线精品一区 | 日日躁夜夜躁狠狠躁 | 精品无人区无码乱码毛片国产 | 亚洲第一无码av无码专区 | 午夜不卡av免费 一本久久a久久精品vr综合 | 亚洲精品国产精品乱码不卡 | 欧美猛少妇色xxxxx | 国产精品香蕉在线观看 | 97资源共享在线视频 | 精品国产青草久久久久福利 | 麻花豆传媒剧国产免费mv在线 | aⅴ在线视频男人的天堂 | 色偷偷av老熟女 久久精品人妻少妇一区二区三区 | 亚洲人成影院在线无码按摩店 | 亚洲爆乳大丰满无码专区 | 狠狠亚洲超碰狼人久久 | 国产精品亚洲专区无码不卡 | 亚洲熟妇色xxxxx欧美老妇 | 成人综合网亚洲伊人 | 国产精品无码久久av | 美女毛片一区二区三区四区 | 亚洲中文字幕无码中文字在线 | 水蜜桃亚洲一二三四在线 | 少妇人妻偷人精品无码视频 | 麻豆av传媒蜜桃天美传媒 | 天堂а√在线中文在线 | 欧美肥老太牲交大战 | 女人和拘做爰正片视频 | 一个人免费观看的www视频 | 色综合久久久无码中文字幕 | 亚洲精品一区二区三区在线 | 麻豆国产人妻欲求不满谁演的 | 亚洲国产成人a精品不卡在线 | 国产精品鲁鲁鲁 | 无码人妻丰满熟妇区五十路百度 | 精品日本一区二区三区在线观看 | 亚洲色无码一区二区三区 | 亚洲综合无码一区二区三区 | 亚洲欧洲日本综合aⅴ在线 | 丝袜 中出 制服 人妻 美腿 | 国内精品一区二区三区不卡 | 中文字幕av伊人av无码av | 少妇一晚三次一区二区三区 | 亚洲日韩一区二区 | 国产av人人夜夜澡人人爽麻豆 | 亚洲国产成人av在线观看 | 性欧美大战久久久久久久 | 伊在人天堂亚洲香蕉精品区 | 全球成人中文在线 | √8天堂资源地址中文在线 | 亚洲国产欧美国产综合一区 | 国产精品人妻一区二区三区四 | √8天堂资源地址中文在线 | 国产精品久久久av久久久 | 久久精品中文字幕大胸 | 久久国产精品二国产精品 | 久久久久久九九精品久 | 亚洲精品一区国产 | 亚洲色无码一区二区三区 | 欧美第一黄网免费网站 | 乱码av麻豆丝袜熟女系列 | 性欧美疯狂xxxxbbbb | 97资源共享在线视频 | 久久伊人色av天堂九九小黄鸭 | 一区二区三区乱码在线 | 欧洲 | 少妇人妻大乳在线视频 | 欧美一区二区三区 | 99久久99久久免费精品蜜桃 | 一本久道久久综合狠狠爱 | 帮老师解开蕾丝奶罩吸乳网站 | 精品国产国产综合精品 | 亚洲gv猛男gv无码男同 | 亚洲精品一区二区三区四区五区 | 欧美熟妇另类久久久久久多毛 | 亚洲成a人片在线观看日本 | 欧美野外疯狂做受xxxx高潮 | 午夜福利不卡在线视频 | 99久久久国产精品无码免费 | 无套内谢老熟女 | 一区二区三区高清视频一 | 日韩精品无码免费一区二区三区 | 2019午夜福利不卡片在线 | 日韩 欧美 动漫 国产 制服 | 亚洲 a v无 码免 费 成 人 a v | 一本久道久久综合婷婷五月 | 理论片87福利理论电影 | 国产精品亚洲五月天高清 | 久久久久成人精品免费播放动漫 | 国产成人一区二区三区在线观看 | 欧美日韩久久久精品a片 | 人妻无码久久精品人妻 | 日本饥渴人妻欲求不满 | 亚洲成a人片在线观看无码 | 亚洲阿v天堂在线 | 四虎永久在线精品免费网址 | 亚洲欧美精品伊人久久 | 永久免费精品精品永久-夜色 | 少妇久久久久久人妻无码 | 性生交大片免费看女人按摩摩 | 熟女少妇在线视频播放 | 任你躁国产自任一区二区三区 | 中文字幕无码av激情不卡 | 中文毛片无遮挡高清免费 | 在线播放无码字幕亚洲 | 激情国产av做激情国产爱 | 扒开双腿疯狂进出爽爽爽视频 | 色老头在线一区二区三区 | 亚洲精品久久久久avwww潮水 | 国产精华av午夜在线观看 | 久久人妻内射无码一区三区 | 欧美自拍另类欧美综合图片区 | 老司机亚洲精品影院无码 | 国产高潮视频在线观看 | 成人av无码一区二区三区 | 欧美乱妇无乱码大黄a片 | 无码国产色欲xxxxx视频 | 少妇厨房愉情理9仑片视频 | 精品无码av一区二区三区 | 日本一区二区三区免费播放 | 国产人妻精品一区二区三区 | 又色又爽又黄的美女裸体网站 | 久久无码专区国产精品s | 内射爽无广熟女亚洲 | 亚洲熟女一区二区三区 | 乱人伦人妻中文字幕无码久久网 | 伊人久久大香线蕉av一区二区 | 亚洲精品久久久久久一区二区 | 人人爽人人澡人人人妻 | 99久久久无码国产aaa精品 | 久久午夜夜伦鲁鲁片无码免费 | 人人妻人人澡人人爽人人精品 | 久久99精品国产麻豆 | 国产乱子伦视频在线播放 | 免费网站看v片在线18禁无码 | 狠狠色丁香久久婷婷综合五月 | 无码人妻丰满熟妇区五十路百度 | 午夜精品久久久内射近拍高清 | 麻豆成人精品国产免费 | 国产av无码专区亚洲awww | 亚洲一区二区三区国产精华液 | 中文字幕人成乱码熟女app | 国产97人人超碰caoprom | 大屁股大乳丰满人妻 | 欧美性生交xxxxx久久久 | 久久午夜无码鲁丝片午夜精品 | 欧美 日韩 人妻 高清 中文 | 人人超人人超碰超国产 | 老熟女乱子伦 | 国产成人人人97超碰超爽8 | 日日鲁鲁鲁夜夜爽爽狠狠 | 亚洲精品国产精品乱码视色 | 无码毛片视频一区二区本码 | 88国产精品欧美一区二区三区 | 亚洲毛片av日韩av无码 | www国产亚洲精品久久久日本 | 欧美性生交活xxxxxdddd | 欧美三级不卡在线观看 | 久久国语露脸国产精品电影 | 日本肉体xxxx裸交 | 夜夜夜高潮夜夜爽夜夜爰爰 | 伊在人天堂亚洲香蕉精品区 | 88国产精品欧美一区二区三区 | 久久久久久久人妻无码中文字幕爆 | 成人一在线视频日韩国产 | 国产av久久久久精东av | 亚洲日韩乱码中文无码蜜桃臀网站 | 性生交大片免费看女人按摩摩 | 国产va免费精品观看 | 亚洲欧美日韩国产精品一区二区 | 青青青手机频在线观看 | 国产精品免费大片 | 内射巨臀欧美在线视频 | 国产猛烈高潮尖叫视频免费 | 4hu四虎永久在线观看 | 漂亮人妻洗澡被公强 日日躁 | 成人精品天堂一区二区三区 | 日日天干夜夜狠狠爱 | 成人亚洲精品久久久久软件 | 国产又粗又硬又大爽黄老大爷视 | 精品久久综合1区2区3区激情 | 日韩少妇内射免费播放 | 日本www一道久久久免费榴莲 | 亚洲理论电影在线观看 | 亚洲综合在线一区二区三区 | 曰韩少妇内射免费播放 | 国产精品美女久久久久av爽李琼 | 日日摸天天摸爽爽狠狠97 | 丰满少妇高潮惨叫视频 | 国产亚洲美女精品久久久2020 | 成人试看120秒体验区 | 国产亚av手机在线观看 | 国产凸凹视频一区二区 | 99久久亚洲精品无码毛片 | av无码不卡在线观看免费 | 亚洲国产高清在线观看视频 | 国产精品人人妻人人爽 | 国产精品理论片在线观看 | 中文字幕人妻无码一区二区三区 | 国产深夜福利视频在线 | 国内精品人妻无码久久久影院 | 性生交大片免费看女人按摩摩 | 国产激情综合五月久久 | 欧美国产日产一区二区 | 亚洲精品无码人妻无码 | 国产极品美女高潮无套在线观看 | 久久精品视频在线看15 | 久久久精品国产sm最大网站 | 色欲久久久天天天综合网精品 | 中文字幕无码av波多野吉衣 | 久久精品中文字幕大胸 | 国产精品美女久久久 | 六十路熟妇乱子伦 | 国产亚洲视频中文字幕97精品 | 伊人久久大香线蕉av一区二区 | 欧美xxxxx精品 | 99久久久国产精品无码免费 | 国产成人精品视频ⅴa片软件竹菊 | 99久久人妻精品免费一区 | 久久午夜无码鲁丝片 | 久久国产劲爆∧v内射 | 免费观看又污又黄的网站 | 午夜福利不卡在线视频 | 久久国语露脸国产精品电影 | 亚洲精品欧美二区三区中文字幕 | 无码av最新清无码专区吞精 | 亚洲精品久久久久avwww潮水 | 伊人久久婷婷五月综合97色 | 少妇被粗大的猛进出69影院 | 国内揄拍国内精品人妻 | 男女猛烈xx00免费视频试看 | 领导边摸边吃奶边做爽在线观看 | www国产精品内射老师 | 色欲av亚洲一区无码少妇 | 一本色道婷婷久久欧美 | 欧美 日韩 人妻 高清 中文 | 亚洲国产欧美在线成人 | 久久久国产精品无码免费专区 | 精品乱子伦一区二区三区 | 7777奇米四色成人眼影 | 久在线观看福利视频 | 午夜熟女插插xx免费视频 | 国产精品久久久久久亚洲影视内衣 | 乌克兰少妇xxxx做受 | 亚洲国产精品毛片av不卡在线 | 久久亚洲国产成人精品性色 | 国产精品人妻一区二区三区四 | 大乳丰满人妻中文字幕日本 | 丁香花在线影院观看在线播放 | 欧美国产日产一区二区 | av在线亚洲欧洲日产一区二区 | 国产亚洲精品久久久闺蜜 | 小鲜肉自慰网站xnxx | 少妇被粗大的猛进出69影院 | 国产欧美精品一区二区三区 | 成人片黄网站色大片免费观看 | 亚洲娇小与黑人巨大交 | 人妻中文无码久热丝袜 | 亚洲色在线无码国产精品不卡 | 日日鲁鲁鲁夜夜爽爽狠狠 | 一区二区三区乱码在线 | 欧洲 | 人人妻人人澡人人爽精品欧美 | 日韩精品无码一本二本三本色 | 香港三级日本三级妇三级 | aⅴ亚洲 日韩 色 图网站 播放 | 老熟女重囗味hdxx69 | 成人欧美一区二区三区黑人免费 | 久久久久亚洲精品中文字幕 | 亚洲人成无码网www | 亚洲人成网站免费播放 | 亚洲综合伊人久久大杳蕉 | 国产精品久久久久无码av色戒 | 性做久久久久久久久 | 欧美三级a做爰在线观看 | 中文字幕乱码中文乱码51精品 | 夜夜躁日日躁狠狠久久av | 欧美日本精品一区二区三区 | 国产精品va在线播放 | 台湾无码一区二区 | 色欲av亚洲一区无码少妇 | 少妇无码吹潮 | 性色欲情网站iwww九文堂 | 人妻夜夜爽天天爽三区 | ass日本丰满熟妇pics | 中文字幕无码视频专区 | 免费无码的av片在线观看 | 亚洲色在线无码国产精品不卡 | 国产精品久久国产三级国 | 在线观看国产一区二区三区 | 日日麻批免费40分钟无码 | 国内少妇偷人精品视频 | 日韩欧美中文字幕在线三区 | 内射老妇bbwx0c0ck | 国产精品亚洲五月天高清 | 久久www免费人成人片 | 无码人妻av免费一区二区三区 | 国产成人一区二区三区在线观看 | 熟女体下毛毛黑森林 | 亚洲精品中文字幕久久久久 | 国产色视频一区二区三区 | 女人被男人爽到呻吟的视频 | 动漫av一区二区在线观看 | 欧美日韩在线亚洲综合国产人 | 男女作爱免费网站 | 少妇人妻av毛片在线看 | 99国产精品白浆在线观看免费 | 丰满少妇熟乱xxxxx视频 | 狠狠色丁香久久婷婷综合五月 | 性生交大片免费看女人按摩摩 | 国产麻豆精品一区二区三区v视界 | 偷窥日本少妇撒尿chinese | 少妇愉情理伦片bd | 国产乱人无码伦av在线a | 久久久www成人免费毛片 | 熟妇女人妻丰满少妇中文字幕 | 亲嘴扒胸摸屁股激烈网站 | 男人的天堂2018无码 | 色婷婷欧美在线播放内射 | 正在播放老肥熟妇露脸 | av无码久久久久不卡免费网站 | 波多野结衣 黑人 | 十八禁视频网站在线观看 | av人摸人人人澡人人超碰下载 | 亚洲人成网站色7799 | 欧美一区二区三区视频在线观看 | 国产偷抇久久精品a片69 | 国产精品无码永久免费888 | 国产xxx69麻豆国语对白 | 国产熟妇高潮叫床视频播放 | 国产精品久久久 | 欧美高清在线精品一区 | 欧美老人巨大xxxx做受 | 亚洲欧美日韩成人高清在线一区 | 在线а√天堂中文官网 | 国产激情无码一区二区 | 中文无码成人免费视频在线观看 | 日韩少妇白浆无码系列 | 国模大胆一区二区三区 | 日本精品人妻无码免费大全 | 性色av无码免费一区二区三区 | 欧美熟妇另类久久久久久多毛 | 美女黄网站人色视频免费国产 | 国产激情艳情在线看视频 | 香港三级日本三级妇三级 | 国产亚洲精品久久久久久久久动漫 | 亚洲精品久久久久久久久久久 | 夜夜夜高潮夜夜爽夜夜爰爰 | 国产精品久久久一区二区三区 | 色婷婷欧美在线播放内射 | 国产av人人夜夜澡人人爽麻豆 | 亚洲综合伊人久久大杳蕉 | 亚洲日韩乱码中文无码蜜桃臀网站 | 少妇人妻大乳在线视频 | 免费国产黄网站在线观看 | 3d动漫精品啪啪一区二区中 | 四虎国产精品一区二区 | 亚洲成熟女人毛毛耸耸多 | 国产成人精品视频ⅴa片软件竹菊 | 精品国产一区av天美传媒 | 牲欲强的熟妇农村老妇女视频 | 久久精品人人做人人综合试看 | 人人妻人人澡人人爽欧美精品 | 少妇邻居内射在线 | 亚洲中文字幕va福利 | 特黄特色大片免费播放器图片 | 国产乱人伦app精品久久 国产在线无码精品电影网 国产国产精品人在线视 | 婷婷综合久久中文字幕蜜桃三电影 | 内射老妇bbwx0c0ck | 黑人粗大猛烈进出高潮视频 | 欧美日韩在线亚洲综合国产人 | 国产精品.xx视频.xxtv | 欧美黑人巨大xxxxx | 国产性生交xxxxx无码 | 午夜嘿嘿嘿影院 | 在线观看国产午夜福利片 | 天堂在线观看www | 国产av无码专区亚洲a∨毛片 | 麻花豆传媒剧国产免费mv在线 | 精品久久久久香蕉网 | 精品夜夜澡人妻无码av蜜桃 | 国产电影无码午夜在线播放 | 天堂а√在线中文在线 | 99久久精品日本一区二区免费 | 亚洲日韩精品欧美一区二区 | 久久综合久久自在自线精品自 | 亚洲精品一区二区三区四区五区 | 成人免费视频在线观看 | 日本一卡2卡3卡四卡精品网站 | 性生交大片免费看女人按摩摩 | 亚洲欧洲中文日韩av乱码 | 国产一区二区三区四区五区加勒比 | 亚洲一区二区三区香蕉 | 天堂久久天堂av色综合 | 亚洲天堂2017无码中文 | 中文字幕无码人妻少妇免费 | 国产精品igao视频网 | 国产人妻人伦精品1国产丝袜 | 三级4级全黄60分钟 | 日本精品人妻无码免费大全 | 无码av免费一区二区三区试看 | 欧美国产日韩久久mv | 国产熟妇高潮叫床视频播放 | 成人亚洲精品久久久久软件 | 日韩人妻无码一区二区三区久久99 | 精品 日韩 国产 欧美 视频 | 亚洲人成网站在线播放942 | 精品厕所偷拍各类美女tp嘘嘘 | 欧美 丝袜 自拍 制服 另类 | 精品久久久无码人妻字幂 | 日本肉体xxxx裸交 | 欧美人与禽猛交狂配 | 久久亚洲精品成人无码 | 国产精品第一国产精品 | 国内老熟妇对白xxxxhd | 亚洲精品久久久久中文第一幕 | 亚洲一区二区三区四区 | 国产精品丝袜黑色高跟鞋 | 欧美变态另类xxxx | 小鲜肉自慰网站xnxx | 性色av无码免费一区二区三区 | 东京热一精品无码av | 少妇无套内谢久久久久 | 精品亚洲韩国一区二区三区 | 午夜肉伦伦影院 | 欧美国产日韩久久mv | 免费播放一区二区三区 | 亚洲熟妇自偷自拍另类 | 欧美自拍另类欧美综合图片区 | 永久免费精品精品永久-夜色 | 日日躁夜夜躁狠狠躁 | 久久人人97超碰a片精品 | 色五月五月丁香亚洲综合网 | 女人被男人躁得好爽免费视频 | 国产真实夫妇视频 | 亚洲成在人网站无码天堂 | 又色又爽又黄的美女裸体网站 | 国产精品毛多多水多 | 中文亚洲成a人片在线观看 | 国产偷国产偷精品高清尤物 | 97人妻精品一区二区三区 | 日本精品人妻无码免费大全 | 日韩精品无码免费一区二区三区 | 色偷偷人人澡人人爽人人模 | 亚洲 另类 在线 欧美 制服 | 国产精品理论片在线观看 | 国产乡下妇女做爰 | 欧美日韩色另类综合 | 亚洲成a人片在线观看无码 | 国产又粗又硬又大爽黄老大爷视 | 好爽又高潮了毛片免费下载 | 欧美大屁股xxxxhd黑色 | 国产精品久久国产精品99 | 亚洲国产成人av在线观看 | 午夜性刺激在线视频免费 | 一本久道高清无码视频 | 免费人成网站视频在线观看 | 超碰97人人做人人爱少妇 | 成人无码精品一区二区三区 | 在线看片无码永久免费视频 | 黑森林福利视频导航 | 精品偷拍一区二区三区在线看 | 丰满少妇熟乱xxxxx视频 | 久久精品国产一区二区三区 | 午夜精品一区二区三区的区别 | 奇米影视7777久久精品人人爽 | 日本一区二区三区免费播放 | 2019nv天堂香蕉在线观看 | 人人妻人人澡人人爽欧美精品 | 成人动漫在线观看 | 野外少妇愉情中文字幕 | 一区二区三区高清视频一 | 中文字幕无码免费久久99 | 国产精品久久久久久久9999 | 亚洲一区二区三区含羞草 | 亚洲欧美日韩综合久久久 | 未满小14洗澡无码视频网站 | 国产精品国产三级国产专播 | 99精品无人区乱码1区2区3区 | 麻豆国产97在线 | 欧洲 | 18无码粉嫩小泬无套在线观看 | 亚洲中文字幕成人无码 | 欧美精品无码一区二区三区 | 欧美精品国产综合久久 | 精品欧洲av无码一区二区三区 | 特黄特色大片免费播放器图片 | 色综合久久88色综合天天 | 蜜臀aⅴ国产精品久久久国产老师 | 精品无人国产偷自产在线 | 亚洲另类伦春色综合小说 | 色欲综合久久中文字幕网 | 欧美日韩在线亚洲综合国产人 | 小sao货水好多真紧h无码视频 | 亚洲国产精品美女久久久久 | 四虎4hu永久免费 | 日韩av无码一区二区三区 | 丝袜人妻一区二区三区 | 在线观看国产午夜福利片 | 国产人妻人伦精品1国产丝袜 | 嫩b人妻精品一区二区三区 | 一个人免费观看的www视频 | 动漫av网站免费观看 | 亚洲色www成人永久网址 | 国产va免费精品观看 | 精品国产麻豆免费人成网站 | 亚洲男人av天堂午夜在 | 丝袜人妻一区二区三区 | 领导边摸边吃奶边做爽在线观看 | 四虎永久在线精品免费网址 | 97无码免费人妻超级碰碰夜夜 | 水蜜桃av无码 | 玩弄中年熟妇正在播放 | 中文字幕无线码 | 久久99精品久久久久久动态图 | 亚洲国产精华液网站w | 久久久婷婷五月亚洲97号色 | 国产国语老龄妇女a片 | 久久午夜无码鲁丝片午夜精品 | 欧美xxxx黑人又粗又长 | 一本色道久久综合亚洲精品不卡 | 99久久婷婷国产综合精品青草免费 | 丰满人妻翻云覆雨呻吟视频 | 四虎影视成人永久免费观看视频 | 国产午夜福利亚洲第一 | 精品无码成人片一区二区98 | 国产午夜精品一区二区三区嫩草 | 少女韩国电视剧在线观看完整 | 99久久人妻精品免费一区 | 给我免费的视频在线观看 | 性欧美熟妇videofreesex | 国产激情精品一区二区三区 | 99久久精品无码一区二区毛片 | 欧美人妻一区二区三区 | 熟妇人妻无乱码中文字幕 | 欧美熟妇另类久久久久久多毛 | 亚洲男人av天堂午夜在 | 午夜无码区在线观看 | 中文字幕av日韩精品一区二区 | 无码人妻少妇伦在线电影 | 色综合久久久久综合一本到桃花网 | 东京热无码av男人的天堂 | 精品亚洲成av人在线观看 | 一本色道久久综合亚洲精品不卡 | 一本色道婷婷久久欧美 | 久久这里只有精品视频9 | 又大又紧又粉嫩18p少妇 | 99精品无人区乱码1区2区3区 | 午夜嘿嘿嘿影院 | 欧美日韩一区二区综合 | 国产午夜精品一区二区三区嫩草 | 国产精品福利视频导航 | 精品久久8x国产免费观看 | 少妇激情av一区二区 | 国产真实乱对白精彩久久 | 无码人妻出轨黑人中文字幕 | 99er热精品视频 | 俺去俺来也在线www色官网 | 成人试看120秒体验区 | 精品乱子伦一区二区三区 | 亚洲色欲色欲天天天www | 中文字幕无码免费久久99 | 小鲜肉自慰网站xnxx | 粉嫩少妇内射浓精videos | 国产99久久精品一区二区 | 国产精品99久久精品爆乳 | 丰满妇女强制高潮18xxxx | 国产精品对白交换视频 | 免费国产黄网站在线观看 | 亚洲一区二区三区偷拍女厕 | 77777熟女视频在线观看 а天堂中文在线官网 | 欧美性生交活xxxxxdddd | 蜜桃av蜜臀av色欲av麻 999久久久国产精品消防器材 | 国产一区二区三区精品视频 | 成人无码影片精品久久久 | 国产农村妇女高潮大叫 | 性欧美疯狂xxxxbbbb | 98国产精品综合一区二区三区 | 国产亚洲欧美日韩亚洲中文色 | 国产福利视频一区二区 | 精品少妇爆乳无码av无码专区 | 亚洲中文无码av永久不收费 | 樱花草在线播放免费中文 | 日韩 欧美 动漫 国产 制服 | 日本又色又爽又黄的a片18禁 | 精品人人妻人人澡人人爽人人 | 亚洲熟女一区二区三区 | 精品欧洲av无码一区二区三区 | 婷婷五月综合缴情在线视频 | 性欧美牲交xxxxx视频 | 国产色视频一区二区三区 | 无码乱肉视频免费大全合集 | 国产精品亚洲专区无码不卡 | 国产人妻大战黑人第1集 | 精品成在人线av无码免费看 | 熟女体下毛毛黑森林 | 人人妻人人藻人人爽欧美一区 | 男女作爱免费网站 | 亚洲色欲久久久综合网东京热 | 国精产品一区二区三区 | 无码av免费一区二区三区试看 | 在线观看国产一区二区三区 | 精品无人区无码乱码毛片国产 | 国产精品人妻一区二区三区四 | 5858s亚洲色大成网站www | 亚洲中文字幕av在天堂 | 久久综合九色综合97网 | 久久久久久a亚洲欧洲av冫 | 人人澡人摸人人添 | 亚洲gv猛男gv无码男同 | 纯爱无遮挡h肉动漫在线播放 | 国产亚av手机在线观看 | 国产欧美熟妇另类久久久 | 撕开奶罩揉吮奶头视频 | 日韩无码专区 | 久久综合给合久久狠狠狠97色 | 18精品久久久无码午夜福利 | 午夜熟女插插xx免费视频 | 牛和人交xxxx欧美 | 亚洲国产精品无码久久久久高潮 | 成人精品视频一区二区三区尤物 | 精品无码一区二区三区爱欲 | 初尝人妻少妇中文字幕 | 中文字幕无码人妻少妇免费 | 国产欧美精品一区二区三区 | 亚洲爆乳大丰满无码专区 | 澳门永久av免费网站 | 中文字幕久久久久人妻 | 欧美乱妇无乱码大黄a片 | 中文精品久久久久人妻不卡 | 久热国产vs视频在线观看 | 激情五月综合色婷婷一区二区 | 永久黄网站色视频免费直播 | 性生交大片免费看l | 狠狠综合久久久久综合网 | 亚洲欧美日韩成人高清在线一区 | 国产成人精品久久亚洲高清不卡 | 国产精品久久久一区二区三区 | 欧洲美熟女乱又伦 | 精品无码av一区二区三区 | 夜夜躁日日躁狠狠久久av | 无码精品国产va在线观看dvd | 内射白嫩少妇超碰 | 性史性农村dvd毛片 | 国产国产精品人在线视 | 免费国产成人高清在线观看网站 | 97se亚洲精品一区 | 性生交片免费无码看人 | 久久久久国色av免费观看性色 | 国产激情综合五月久久 | 欧美黑人性暴力猛交喷水 | 欧美熟妇另类久久久久久不卡 | 国产人妻人伦精品 | 国产精品二区一区二区aⅴ污介绍 | aⅴ在线视频男人的天堂 | 人妻人人添人妻人人爱 | 狠狠色噜噜狠狠狠狠7777米奇 | 欧美性生交活xxxxxdddd | 精品国产av色一区二区深夜久久 | 欧美日韩视频无码一区二区三 | 极品嫩模高潮叫床 | 无码av中文字幕免费放 | 无码毛片视频一区二区本码 | 国产一精品一av一免费 | 日本一区二区更新不卡 | 日韩欧美中文字幕在线三区 | 亚欧洲精品在线视频免费观看 | 久久久久se色偷偷亚洲精品av | 色综合久久久无码中文字幕 | 亚洲精品午夜国产va久久成人 | 国产亚洲精品久久久久久久久动漫 | 在线观看免费人成视频 | 久久综合给合久久狠狠狠97色 | 久久99精品国产麻豆蜜芽 | 夜先锋av资源网站 | 图片区 小说区 区 亚洲五月 | 日本熟妇大屁股人妻 | 伊人久久大香线蕉午夜 | 亚洲中文无码av永久不收费 | 亚洲午夜久久久影院 | 亚洲一区二区三区播放 | 国产猛烈高潮尖叫视频免费 | 在线a亚洲视频播放在线观看 | 在线观看欧美一区二区三区 | 久久精品中文字幕一区 | 亚洲综合色区中文字幕 | 亚洲色偷偷男人的天堂 | 午夜性刺激在线视频免费 | 又色又爽又黄的美女裸体网站 | 欧美人与禽猛交狂配 | 久久久久亚洲精品男人的天堂 | 亚洲精品国偷拍自产在线麻豆 | 欧美丰满老熟妇xxxxx性 | 奇米综合四色77777久久 东京无码熟妇人妻av在线网址 | 妺妺窝人体色www婷婷 | 亚洲色欲色欲天天天www | 日本熟妇乱子伦xxxx | 久久五月精品中文字幕 | 午夜熟女插插xx免费视频 | 精品人妻av区 | 精品日本一区二区三区在线观看 | 少妇无码av无码专区在线观看 | 精品久久久久久人妻无码中文字幕 | 欧美老妇交乱视频在线观看 | 欧美精品免费观看二区 | 国产激情精品一区二区三区 | 成人毛片一区二区 | 一个人看的视频www在线 | 欧洲熟妇精品视频 | 色综合久久中文娱乐网 | 无码任你躁久久久久久久 | 成人免费视频视频在线观看 免费 | 欧美freesex黑人又粗又大 | 国产精品手机免费 | 午夜男女很黄的视频 | 88国产精品欧美一区二区三区 | 亚洲精品一区二区三区在线 | 国产精品久久国产三级国 | 亚洲欧美日韩综合久久久 | 日本肉体xxxx裸交 | 玩弄中年熟妇正在播放 | 色一情一乱一伦 | 88国产精品欧美一区二区三区 | 欧美丰满少妇xxxx性 | 欧美人与物videos另类 | 久久综合九色综合97网 | 色一情一乱一伦一视频免费看 | 午夜福利一区二区三区在线观看 | 高潮喷水的毛片 | 久久 国产 尿 小便 嘘嘘 | 精品一区二区三区无码免费视频 | 日日麻批免费40分钟无码 | 亚洲精品久久久久久久久久久 | 亚洲 欧美 激情 小说 另类 | 色爱情人网站 | 99久久精品无码一区二区毛片 | 无码吃奶揉捏奶头高潮视频 | 波多野结衣av在线观看 | 少妇无码一区二区二三区 | 久久综合九色综合97网 | 国产精品爱久久久久久久 | 国产亚洲精品久久久ai换 | 人妻夜夜爽天天爽三区 | 青草青草久热国产精品 | 日本xxxx色视频在线观看免费 | 激情内射亚州一区二区三区爱妻 | 蜜臀aⅴ国产精品久久久国产老师 | 亚洲男人av香蕉爽爽爽爽 | 国产午夜福利亚洲第一 | 亚洲国产精品一区二区美利坚 | 免费无码的av片在线观看 | 高潮喷水的毛片 | 伊人久久大香线蕉av一区二区 | 婷婷丁香六月激情综合啪 | 色情久久久av熟女人妻网站 | 久久精品一区二区三区四区 | 一本大道久久东京热无码av | 精品欧洲av无码一区二区三区 | 欧美变态另类xxxx | 欧洲熟妇精品视频 | 日日碰狠狠丁香久燥 | 国产精品久久久 | 强辱丰满人妻hd中文字幕 | 国产午夜无码视频在线观看 | 一本久道久久综合狠狠爱 | 国产精品久久福利网站 | 无码乱肉视频免费大全合集 | 亚洲gv猛男gv无码男同 | 国产乱人无码伦av在线a | 午夜免费福利小电影 | 精品水蜜桃久久久久久久 | 日韩欧美中文字幕在线三区 | 捆绑白丝粉色jk震动捧喷白浆 | 亚洲成色www久久网站 | 国产精品亚洲а∨无码播放麻豆 | 日韩人妻系列无码专区 | 蜜桃视频韩日免费播放 | 国产精品国产自线拍免费软件 | 久久人人爽人人人人片 | 欧美真人作爱免费视频 | 波多野结衣av一区二区全免费观看 | a在线亚洲男人的天堂 | 牛和人交xxxx欧美 | 国产精品国产三级国产专播 | 国产尤物精品视频 | 国产精品二区一区二区aⅴ污介绍 | 爱做久久久久久 | www国产亚洲精品久久网站 | 欧美激情综合亚洲一二区 | 久久久久免费精品国产 | 精品久久8x国产免费观看 | 又湿又紧又大又爽a视频国产 | 日本成熟视频免费视频 | 又大又紧又粉嫩18p少妇 | 无码av中文字幕免费放 | 国精产品一区二区三区 | 日日天干夜夜狠狠爱 | 九九热爱视频精品 | 久久综合给合久久狠狠狠97色 | 国产一区二区三区四区五区加勒比 | 激情国产av做激情国产爱 | 亚洲精品午夜国产va久久成人 | 亚洲综合无码一区二区三区 | 国产精品永久免费视频 | 国产成人精品无码播放 | 玩弄少妇高潮ⅹxxxyw | 亚洲狠狠婷婷综合久久 | 亚洲欧美日韩成人高清在线一区 | 国产无遮挡又黄又爽又色 | 激情内射亚州一区二区三区爱妻 | 99er热精品视频 | 最近的中文字幕在线看视频 | 妺妺窝人体色www婷婷 | 国产成人精品久久亚洲高清不卡 | 国精产品一品二品国精品69xx | 欧美人与禽zoz0性伦交 | 露脸叫床粗话东北少妇 | 国产精品理论片在线观看 | 荫蒂添的好舒服视频囗交 | 国产无av码在线观看 | 亚洲一区二区三区香蕉 | 一区二区三区高清视频一 | 76少妇精品导航 | 国产欧美亚洲精品a | 日韩人妻无码中文字幕视频 | 国产亚洲精品久久久ai换 | 四虎4hu永久免费 | 日韩人妻系列无码专区 | 成在人线av无码免观看麻豆 | 欧洲精品码一区二区三区免费看 | 国产suv精品一区二区五 | 老司机亚洲精品影院 | 扒开双腿吃奶呻吟做受视频 | 国产精品无码永久免费888 | 人人妻人人澡人人爽人人精品 | 国产精品久久精品三级 | 成人女人看片免费视频放人 | 7777奇米四色成人眼影 | 久久综合九色综合欧美狠狠 | 国产精品久久久午夜夜伦鲁鲁 | 亚洲欧美综合区丁香五月小说 | 国产精品久久久av久久久 | 国产又粗又硬又大爽黄老大爷视 | 日本欧美一区二区三区乱码 | 亚洲成色www久久网站 | 日本丰满护士爆乳xxxx | 内射后入在线观看一区 | 欧美丰满熟妇xxxx性ppx人交 | 国产午夜精品一区二区三区嫩草 | 丰满少妇女裸体bbw | 中文字幕日产无线码一区 | 亚洲日韩av一区二区三区四区 | 亚洲国产精品久久久天堂 | 少妇无套内谢久久久久 | 色一情一乱一伦 | аⅴ资源天堂资源库在线 | 国产精品视频免费播放 | 人人妻人人澡人人爽人人精品 | 国产精品.xx视频.xxtv | 精品无码成人片一区二区98 | 亚洲 日韩 欧美 成人 在线观看 | 亚洲精品国产精品乱码不卡 | 国产欧美精品一区二区三区 | 国产又粗又硬又大爽黄老大爷视 | 久久精品无码一区二区三区 | 天堂久久天堂av色综合 | 久久五月精品中文字幕 | 欧美日韩综合一区二区三区 | 国产一区二区三区影院 | 好屌草这里只有精品 | 国产成人综合色在线观看网站 | 国内少妇偷人精品视频 | av人摸人人人澡人人超碰下载 | 亚洲日韩中文字幕在线播放 | 亚洲精品国产品国语在线观看 | 国内综合精品午夜久久资源 | 人人澡人摸人人添 | 最近中文2019字幕第二页 | 国产在线aaa片一区二区99 | 人妻aⅴ无码一区二区三区 | 色 综合 欧美 亚洲 国产 | 精品人妻av区 | 色一情一乱一伦一区二区三欧美 | 九一九色国产 | 国产精品久久国产三级国 | 日韩少妇白浆无码系列 | 在线成人www免费观看视频 | 色婷婷久久一区二区三区麻豆 | 免费无码的av片在线观看 | 国内综合精品午夜久久资源 | 国精产品一区二区三区 | 波多野结衣一区二区三区av免费 | 国产午夜精品一区二区三区嫩草 | 成人片黄网站色大片免费观看 | 牛和人交xxxx欧美 | 国产又粗又硬又大爽黄老大爷视 | 人人爽人人澡人人高潮 | 婷婷综合久久中文字幕蜜桃三电影 | 久久成人a毛片免费观看网站 | 成人免费视频视频在线观看 免费 | 成人毛片一区二区 | 日韩无码专区 | 午夜精品一区二区三区的区别 | 成年美女黄网站色大免费视频 | 亚洲乱码中文字幕在线 | 亚洲精品国产精品乱码不卡 | 久久天天躁狠狠躁夜夜免费观看 | 粉嫩少妇内射浓精videos | 亚洲欧洲中文日韩av乱码 | 欧美日本免费一区二区三区 | 天堂久久天堂av色综合 | 国产精品久久久久久亚洲影视内衣 | 少妇性荡欲午夜性开放视频剧场 | 日韩成人一区二区三区在线观看 | 激情国产av做激情国产爱 | 国产超碰人人爽人人做人人添 | 欧美肥老太牲交大战 | 国产在热线精品视频 | aⅴ在线视频男人的天堂 | 欧美性生交xxxxx久久久 | 久在线观看福利视频 | 在线播放免费人成毛片乱码 | 人人爽人人澡人人人妻 | 东京无码熟妇人妻av在线网址 | 欧美人与禽zoz0性伦交 | 久久 国产 尿 小便 嘘嘘 | 亚洲a无码综合a国产av中文 | 99久久无码一区人妻 | 天天燥日日燥 | 国产人妻大战黑人第1集 | 久久久久久久久888 | 久久五月精品中文字幕 | 一本大道久久东京热无码av | 国产suv精品一区二区五 | 男女作爱免费网站 | 欧美freesex黑人又粗又大 | 中文无码成人免费视频在线观看 | 亚洲欧美精品aaaaaa片 | 男女下面进入的视频免费午夜 | 欧美日本精品一区二区三区 | 久久精品丝袜高跟鞋 | 亚洲欧美日韩综合久久久 | 老熟女重囗味hdxx69 | 免费无码午夜福利片69 | 亚洲 高清 成人 动漫 | 性色欲情网站iwww九文堂 | 色欲人妻aaaaaaa无码 | 爽爽影院免费观看 | 国产亚洲精品久久久久久久久动漫 | 国产婷婷色一区二区三区在线 | 成人一在线视频日韩国产 | 漂亮人妻洗澡被公强 日日躁 | 亚洲欧美中文字幕5发布 | 日本丰满熟妇videos | av无码久久久久不卡免费网站 | 久久综合激激的五月天 | 天天做天天爱天天爽综合网 | 精品亚洲成av人在线观看 | 久久久av男人的天堂 | 国产精品视频免费播放 | 水蜜桃亚洲一二三四在线 | 免费网站看v片在线18禁无码 | 激情国产av做激情国产爱 | 国产69精品久久久久app下载 | 久久亚洲中文字幕无码 | 亚洲第一无码av无码专区 | 久久成人a毛片免费观看网站 | 亚洲精品美女久久久久久久 | 国精产品一品二品国精品69xx | 人妻有码中文字幕在线 | 久久国产劲爆∧v内射 | 纯爱无遮挡h肉动漫在线播放 | 成人欧美一区二区三区黑人免费 | 欧美真人作爱免费视频 | 精品水蜜桃久久久久久久 | 内射白嫩少妇超碰 | 久久久久久a亚洲欧洲av冫 | 亚洲の无码国产の无码影院 | 日产精品高潮呻吟av久久 | 九九久久精品国产免费看小说 | 久久99热只有频精品8 | 亚洲成av人片在线观看无码不卡 | 亚洲 另类 在线 欧美 制服 | 欧美日韩一区二区三区自拍 | 国产婷婷色一区二区三区在线 | 亚洲精品欧美二区三区中文字幕 | 波多野结衣一区二区三区av免费 | 人妻少妇精品无码专区动漫 | 久久亚洲a片com人成 | 丰腴饱满的极品熟妇 | 激情爆乳一区二区三区 | 成人aaa片一区国产精品 | 小泽玛莉亚一区二区视频在线 | 又大又黄又粗又爽的免费视频 | 中文字幕av日韩精品一区二区 | 熟女体下毛毛黑森林 | 波多野42部无码喷潮在线 | 亚洲爆乳精品无码一区二区三区 | 亚洲精品成人福利网站 | 国产又爽又猛又粗的视频a片 | 成人无码精品一区二区三区 | 国产真人无遮挡作爱免费视频 | 国产猛烈高潮尖叫视频免费 | 亚洲精品一区二区三区婷婷月 | 伊人久久婷婷五月综合97色 | 99久久99久久免费精品蜜桃 | 性色欲网站人妻丰满中文久久不卡 | 18禁黄网站男男禁片免费观看 | 一个人看的视频www在线 | 国产无av码在线观看 | 成人精品视频一区二区三区尤物 | 丰满人妻一区二区三区免费视频 | 在线精品国产一区二区三区 | 久久亚洲国产成人精品性色 | 国产精品久久福利网站 | 亚洲午夜无码久久 | 老子影院午夜精品无码 | 色噜噜亚洲男人的天堂 | 久久久久亚洲精品男人的天堂 | 男女猛烈xx00免费视频试看 | 波多野结衣乳巨码无在线观看 | 无码毛片视频一区二区本码 | 成人欧美一区二区三区黑人免费 | 亚洲熟妇色xxxxx欧美老妇 | 1000部夫妻午夜免费 | 成人片黄网站色大片免费观看 | 久久久久久av无码免费看大片 | 狠狠色噜噜狠狠狠狠7777米奇 | 久久人人爽人人人人片 | 无码国产乱人伦偷精品视频 | 99久久无码一区人妻 | 2020久久香蕉国产线看观看 | 欧美人与禽zoz0性伦交 | 色婷婷久久一区二区三区麻豆 | 亚洲国产精品无码久久久久高潮 | 亚洲色偷偷偷综合网 | 玩弄少妇高潮ⅹxxxyw | 亚洲日韩av一区二区三区四区 | 一二三四在线观看免费视频 | 97久久精品无码一区二区 | 成年美女黄网站色大免费全看 | 秋霞特色aa大片 | 人妻天天爽夜夜爽一区二区 | 久久精品丝袜高跟鞋 | 18禁黄网站男男禁片免费观看 | 六十路熟妇乱子伦 | 婷婷六月久久综合丁香 | 色欲综合久久中文字幕网 | 久久熟妇人妻午夜寂寞影院 | 亚洲一区二区三区在线观看网站 | 欧美三级不卡在线观看 | 国产亚洲精品久久久久久大师 | 无码福利日韩神码福利片 | 国产性猛交╳xxx乱大交 国产精品久久久久久无码 欧洲欧美人成视频在线 | 久久久久久av无码免费看大片 | 亚洲成a人片在线观看日本 | 国产明星裸体无码xxxx视频 | 国产黑色丝袜在线播放 | 天天做天天爱天天爽综合网 | 丰满肥臀大屁股熟妇激情视频 | 久久久久99精品国产片 | 成人一区二区免费视频 | 久久亚洲日韩精品一区二区三区 | 久久久久成人片免费观看蜜芽 | 久久精品中文闷骚内射 | 久久亚洲中文字幕无码 | 性欧美疯狂xxxxbbbb | 少妇性俱乐部纵欲狂欢电影 | 少妇高潮一区二区三区99 | 狂野欧美性猛交免费视频 | 国产精品亚洲综合色区韩国 | 天天摸天天碰天天添 | 夜精品a片一区二区三区无码白浆 | 久久无码专区国产精品s | 国内精品一区二区三区不卡 | 窝窝午夜理论片影院 | 日产精品99久久久久久 | 午夜肉伦伦影院 | 午夜时刻免费入口 | 亚洲国产精品一区二区第一页 | 领导边摸边吃奶边做爽在线观看 | 男人的天堂2018无码 | 亚洲日韩精品欧美一区二区 | 在线精品亚洲一区二区 | 玩弄少妇高潮ⅹxxxyw | 综合激情五月综合激情五月激情1 | 亚洲日韩中文字幕在线播放 | 国产亚洲精品久久久久久国模美 | 亚洲日韩av一区二区三区中文 | 丰满少妇高潮惨叫视频 | 秋霞成人午夜鲁丝一区二区三区 | 一个人免费观看的www视频 | 国产成人无码专区 | 国产精品亚洲五月天高清 | 欧美成人高清在线播放 | 欧美亚洲日韩国产人成在线播放 | 无码精品国产va在线观看dvd | 国产绳艺sm调教室论坛 | 日韩精品无码一区二区中文字幕 | 亚洲精品久久久久avwww潮水 | 国产成人综合在线女婷五月99播放 | 日产精品99久久久久久 | 老熟妇仑乱视频一区二区 | 老熟女乱子伦 | 国产精品亚洲а∨无码播放麻豆 | 3d动漫精品啪啪一区二区中 | 小鲜肉自慰网站xnxx | 99精品国产综合久久久久五月天 | 国产亚洲精品久久久久久大师 | 午夜男女很黄的视频 | 亚洲国产精品成人久久蜜臀 | 亚洲第一无码av无码专区 | 亚洲成av人影院在线观看 | 久久亚洲国产成人精品性色 | 日本www一道久久久免费榴莲 | 天海翼激烈高潮到腰振不止 | 精品厕所偷拍各类美女tp嘘嘘 | 风流少妇按摩来高潮 | 国产精品人人爽人人做我的可爱 | 国产精品久久福利网站 | 四虎影视成人永久免费观看视频 | 久久精品国产99久久6动漫 | 中文字幕无码热在线视频 | 高中生自慰www网站 | 中文字幕+乱码+中文字幕一区 | 成人无码视频在线观看网站 | 精品无人区无码乱码毛片国产 | 色婷婷欧美在线播放内射 | 无码人妻少妇伦在线电影 | 久久精品女人的天堂av | 免费国产成人高清在线观看网站 | 人人妻人人澡人人爽人人精品浪潮 | 久久人人爽人人爽人人片av高清 | 国产99久久精品一区二区 | 人人妻人人澡人人爽欧美精品 | 亚洲天堂2017无码中文 | 亚洲国产av精品一区二区蜜芽 | 99久久人妻精品免费一区 | 中文精品久久久久人妻不卡 | 成年美女黄网站色大免费视频 | 日韩精品无码一本二本三本色 | 成人影院yy111111在线观看 | 中文字幕av日韩精品一区二区 | 国产猛烈高潮尖叫视频免费 | 国产suv精品一区二区五 | 国产高清av在线播放 | 亚洲人亚洲人成电影网站色 | 青青青手机频在线观看 | av在线亚洲欧洲日产一区二区 | 久久精品丝袜高跟鞋 | 18黄暴禁片在线观看 | 中文久久乱码一区二区 | 国产精品嫩草久久久久 | 久激情内射婷内射蜜桃人妖 | 国产乱人偷精品人妻a片 | 欧美国产日韩久久mv | 男女猛烈xx00免费视频试看 | 麻花豆传媒剧国产免费mv在线 | 日欧一片内射va在线影院 | 色综合久久久无码中文字幕 | 天堂在线观看www | 少妇久久久久久人妻无码 | 暴力强奷在线播放无码 | 最近的中文字幕在线看视频 | 久久久久成人精品免费播放动漫 | 色综合视频一区二区三区 | 学生妹亚洲一区二区 | 国产精品第一国产精品 | 四虎影视成人永久免费观看视频 | 国产日产欧产精品精品app | 精品欧美一区二区三区久久久 | 老司机亚洲精品影院无码 | 天天做天天爱天天爽综合网 | 国内精品久久久久久中文字幕 | 日韩人妻少妇一区二区三区 | 人人妻人人澡人人爽人人精品 | 一二三四在线观看免费视频 | 成人无码精品1区2区3区免费看 | 亚洲狠狠色丁香婷婷综合 | 国产三级精品三级男人的天堂 | 99国产精品白浆在线观看免费 | 久久久久亚洲精品中文字幕 | 亚洲国产精品久久人人爱 | 清纯唯美经典一区二区 | 成 人 网 站国产免费观看 | 亚洲人成网站色7799 | 99精品国产综合久久久久五月天 | 亚洲一区二区三区国产精华液 | 亚洲国产精品美女久久久久 | 亚洲精品一区三区三区在线观看 | 日韩成人一区二区三区在线观看 | 亚洲熟妇色xxxxx亚洲 | 国产乱人伦app精品久久 国产在线无码精品电影网 国产国产精品人在线视 | 国产成人无码区免费内射一片色欲 | 国产精品第一国产精品 | 狂野欧美性猛xxxx乱大交 | 国产午夜福利100集发布 | 日本一卡二卡不卡视频查询 | 中文字幕中文有码在线 | 青青青手机频在线观看 | 在线观看欧美一区二区三区 | 亚洲欧美日韩国产精品一区二区 | 蜜桃无码一区二区三区 | 天天躁日日躁狠狠躁免费麻豆 | 欧美乱妇无乱码大黄a片 | 又大又硬又爽免费视频 | 麻豆av传媒蜜桃天美传媒 | 亚洲色欲色欲天天天www | 伊人久久大香线蕉av一区二区 | 国内精品人妻无码久久久影院 | 99麻豆久久久国产精品免费 | 色综合久久88色综合天天 | 水蜜桃色314在线观看 | 蜜桃视频韩日免费播放 | 色 综合 欧美 亚洲 国产 | 欧美猛少妇色xxxxx | 亚洲精品鲁一鲁一区二区三区 | 国产精品国产三级国产专播 | 久久综合给久久狠狠97色 | 中文字幕乱妇无码av在线 | 国产精品.xx视频.xxtv | 亚洲一区二区三区无码久久 | 大屁股大乳丰满人妻 | 波多野结衣一区二区三区av免费 | 国产小呦泬泬99精品 | www国产亚洲精品久久久日本 | 国产午夜无码视频在线观看 | 一本大道久久东京热无码av | 无码中文字幕色专区 | 欧美兽交xxxx×视频 | 亚洲の无码国产の无码步美 | 久久综合久久自在自线精品自 | 漂亮人妻洗澡被公强 日日躁 | 久久人人爽人人爽人人片ⅴ | 亚洲男女内射在线播放 | 中文字幕 亚洲精品 第1页 | 无码人妻出轨黑人中文字幕 | 色 综合 欧美 亚洲 国产 | 蜜臀av在线观看 在线欧美精品一区二区三区 | 欧美一区二区三区 | 丝袜人妻一区二区三区 | 亚洲区欧美区综合区自拍区 | 亚洲欧美日韩成人高清在线一区 | 日产国产精品亚洲系列 | 国产舌乚八伦偷品w中 | 国精产品一品二品国精品69xx | av在线亚洲欧洲日产一区二区 | 国产精品18久久久久久麻辣 | 无码一区二区三区在线 | 特黄特色大片免费播放器图片 | 少妇无套内谢久久久久 | 青青久在线视频免费观看 | 中文字幕无码热在线视频 | 精品熟女少妇av免费观看 | 亚洲爆乳无码专区 | 国产亚洲欧美在线专区 | 六十路熟妇乱子伦 | a国产一区二区免费入口 | 久久久av男人的天堂 | 98国产精品综合一区二区三区 | 国产亚洲视频中文字幕97精品 | 又色又爽又黄的美女裸体网站 | 色综合天天综合狠狠爱 | 中文字幕色婷婷在线视频 | 色一情一乱一伦一视频免费看 | 成人欧美一区二区三区 | 俺去俺来也www色官网 | 无码国产乱人伦偷精品视频 | 久久久成人毛片无码 | 麻豆国产人妻欲求不满 | 激情内射日本一区二区三区 | 国产又爽又猛又粗的视频a片 | 特黄特色大片免费播放器图片 | 波多野结衣av在线观看 | 国精品人妻无码一区二区三区蜜柚 | 一本色道婷婷久久欧美 | 四虎4hu永久免费 | 亚洲一区av无码专区在线观看 | 97夜夜澡人人爽人人喊中国片 | 国产莉萝无码av在线播放 | 中文字幕乱码人妻二区三区 | 国产精品高潮呻吟av久久 | 国产免费无码一区二区视频 | 日本熟妇大屁股人妻 | 色窝窝无码一区二区三区色欲 | 精品欧美一区二区三区久久久 | 俺去俺来也www色官网 | 亚洲色成人中文字幕网站 | 无码人妻出轨黑人中文字幕 | 欧美喷潮久久久xxxxx | 欧美性猛交内射兽交老熟妇 | 亚洲精品美女久久久久久久 | 久精品国产欧美亚洲色aⅴ大片 | 国产激情一区二区三区 | 国产香蕉尹人综合在线观看 | 亚洲色无码一区二区三区 | 欧美人与牲动交xxxx | 欧美刺激性大交 | 亚洲精品www久久久 | 久久国语露脸国产精品电影 | 乱码午夜-极国产极内射 | 亚洲无人区午夜福利码高清完整版 | 麻豆果冻传媒2021精品传媒一区下载 | 国产疯狂伦交大片 | 中文字幕无码av激情不卡 | 老头边吃奶边弄进去呻吟 | 成人免费视频一区二区 | 熟女少妇在线视频播放 | 成人免费视频一区二区 | 亚洲中文无码av永久不收费 | 蜜桃av抽搐高潮一区二区 | 欧美自拍另类欧美综合图片区 | 精品国产av色一区二区深夜久久 | 99久久亚洲精品无码毛片 | 色诱久久久久综合网ywww | 88国产精品欧美一区二区三区 | 美女极度色诱视频国产 | 欧美色就是色 | 亚洲国产欧美日韩精品一区二区三区 | 国产情侣作爱视频免费观看 | 亚洲色在线无码国产精品不卡 | 欧美人与动性行为视频 | 高中生自慰www网站 | 无码吃奶揉捏奶头高潮视频 | 日本丰满护士爆乳xxxx | 国产热a欧美热a在线视频 | 亚洲国产午夜精品理论片 | 荫蒂添的好舒服视频囗交 | 亚洲一区av无码专区在线观看 | 人妻体内射精一区二区三四 | 男女超爽视频免费播放 | 最新国产麻豆aⅴ精品无码 | 亚洲大尺度无码无码专区 | 亚洲欧美国产精品专区久久 | 中文无码伦av中文字幕 | 99久久人妻精品免费一区 | 麻豆蜜桃av蜜臀av色欲av | 欧美成人家庭影院 | 亚洲精品一区二区三区四区五区 | 欧美阿v高清资源不卡在线播放 | 少妇性l交大片欧洲热妇乱xxx | 无码帝国www无码专区色综合 | 人人妻人人澡人人爽人人精品 | 乱人伦人妻中文字幕无码 | 精品国产乱码久久久久乱码 | 免费看男女做好爽好硬视频 | 成人无码精品一区二区三区 | 国产熟妇另类久久久久 | 精品国产一区二区三区四区在线看 | 国产精品无码一区二区桃花视频 | 窝窝午夜理论片影院 | 国产亚洲精品精品国产亚洲综合 | 图片小说视频一区二区 | 日本www一道久久久免费榴莲 | 亚洲精品成a人在线观看 | 久久精品中文闷骚内射 | 亚洲高清偷拍一区二区三区 | 天堂亚洲2017在线观看 | 亚洲无人区午夜福利码高清完整版 | 乱码av麻豆丝袜熟女系列 | 乱人伦人妻中文字幕无码久久网 | 玩弄少妇高潮ⅹxxxyw | 国产精品久久久一区二区三区 | 日日摸日日碰夜夜爽av | 中文字幕亚洲情99在线 | 亚洲gv猛男gv无码男同 | 东京热无码av男人的天堂 | 国产亲子乱弄免费视频 | 丰满人妻精品国产99aⅴ | 国产精品鲁鲁鲁 | 亚洲乱码日产精品bd | 爆乳一区二区三区无码 | 少妇性俱乐部纵欲狂欢电影 | 亚洲爆乳精品无码一区二区三区 | 亚洲精品综合五月久久小说 | 国产亚洲精品久久久久久国模美 | 青青青爽视频在线观看 | 久久久www成人免费毛片 | 国产乱码精品一品二品 | 精品国产精品久久一区免费式 | 久久久久免费精品国产 | 国产激情综合五月久久 | 日韩视频 中文字幕 视频一区 | 国产亚洲欧美在线专区 | 99精品无人区乱码1区2区3区 | 成人无码精品1区2区3区免费看 | 国产av剧情md精品麻豆 | yw尤物av无码国产在线观看 | 国产农村乱对白刺激视频 | 日韩精品成人一区二区三区 | 国内精品九九久久久精品 | 亚洲s色大片在线观看 | 成人影院yy111111在线观看 | 国产乱人伦app精品久久 国产在线无码精品电影网 国产国产精品人在线视 | 成人欧美一区二区三区黑人 | √天堂中文官网8在线 | 日韩av无码一区二区三区不卡 | 亚洲欧美日韩成人高清在线一区 | 精品偷自拍另类在线观看 | 亚洲小说图区综合在线 | 国产人妻大战黑人第1集 | 99久久久国产精品无码免费 | 欧美大屁股xxxxhd黑色 | 国产精品福利视频导航 | 欧美日韩综合一区二区三区 | 日本va欧美va欧美va精品 | 欧美亚洲日韩国产人成在线播放 | 亚洲日韩精品欧美一区二区 | 无遮挡啪啪摇乳动态图 | 日韩少妇白浆无码系列 | 一本久道高清无码视频 | 日本精品人妻无码免费大全 | 亚洲精品成人福利网站 | 丁香啪啪综合成人亚洲 | 国产成人精品视频ⅴa片软件竹菊 | 免费国产黄网站在线观看 | 小泽玛莉亚一区二区视频在线 | 国产亚洲精品久久久久久大师 | 亚洲色成人中文字幕网站 | 日本一卡2卡3卡4卡无卡免费网站 国产一区二区三区影院 | 三级4级全黄60分钟 | 任你躁国产自任一区二区三区 | 无码国产激情在线观看 | 国产肉丝袜在线观看 | 99久久人妻精品免费一区 | 国产人妻大战黑人第1集 |