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

歡迎訪問 生活随笔!

生活随笔

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

javascript

22-08-06 西安 尚医通(03)EasyExcel; Spring Cache 、Redis做缓存

發布時間:2023/12/20 javascript 40 豆豆
生活随笔 收集整理的這篇文章主要介紹了 22-08-06 西安 尚医通(03)EasyExcel; Spring Cache 、Redis做缓存 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

EasyExcel

EasyExcel:一行一行讀取到內存
EasyExcel是阿里巴巴開源的一個excel處理框架,以使用簡單、節省內存著稱

POI:java里操作excel,讀取、創建excel

POI的缺點:耗內存。因為會把所有數據一起加載到內存中


EasyExcl讀寫演示

1.加依賴

<!-- https://mvnrepository.com/artifact/com.alibaba/easyexcel --><dependency><groupId>com.alibaba</groupId><artifactId>easyexcel</artifactId><version>2.1.1</version></dependency>

2.@ExcelProperty,創建實體類Anchor用來和表格做映射
index第幾列,value列名

@Data @AllArgsConstructor @NoArgsConstructor public class Anchor {@ExcelProperty(index = 0,value = "主播姓名")private String name;@ExcelProperty(index = 1,value = "直播平臺")private String platform;@ExcelProperty(index=2,value = "成名英雄")private String hero; }

演示創建excel表格

一行代碼,調用3個方法 EasyExcel.write().sheet().doWrite();

public static void main(String[] args) {Anchor anchor1 = new Anchor("北慕", "虎牙", "露娜");Anchor anchor2 = new Anchor("騷白", "斗魚", "花木蘭");Anchor anchor3 = new Anchor("賴神", "虎牙", "老夫子");List<Anchor> anchorList = Arrays.asList(anchor1, anchor2, anchor3);EasyExcel.write("C:\\Users\\lenovo\\Desktop\\主播列表.xlsx",Anchor.class).sheet("主播列表").doWrite(anchorList);}

效果如下:

—————————————————————————————————————————

演示讀取excel表格

EasyExcel采用一行一行的解析模式,
并將一行的解析結果以觀察者的模式通知處理AnalysisEventListener

invoke方法用于處理每條數據,讀者可以在這邊進行業務邏輯處理
doAfterAllAnalysed方法是只處理完所有數據后進行的動作;

public class ExcelListener extends AnalysisEventListener<Anchor> {//一行一行去讀取excle內容@Overridepublic void invoke(Anchor anchor, AnalysisContext analysisContext) {System.out.println("***"+anchor);}//所有行讀取完成后執行@Overridepublic void doAfterAllAnalysed(AnalysisContext analysisContext) {System.out.println("讀取完成后");} }

主函數:正真讀取是按照第二行開始的

public static void main(String[] args) {String fileName = "C:\\Users\\lenovo\\Desktop\\主播列表.xlsx";// 這里 需要指定讀用哪個class去讀,然后讀取第一個sheet 文件流會自動關閉EasyExcel.read(fileName, Anchor.class, new ExcelListener()).sheet("主播列表").doRead();}

控制臺打印如下:


數據字典導出

后端代碼

可以理解為文件下載功能

DictEeVo,導出的數據字典格式

@Data public class DictEeVo {@ExcelProperty(value = "id" ,index = 0)private Long id;@ExcelProperty(value = "上級id" ,index = 1)private Long parentId;@ExcelProperty(value = "名稱" ,index = 2)private String name;@ExcelProperty(value = "值" ,index = 3)private String value;@ExcelProperty(value = "編碼" ,index = 4)private String dictCode;}

字典文件下載controller層,返回值為void就行,必須用response對象

@ApiOperation(value="導出") @GetMapping(value = "/exportData") public void exportData(HttpServletResponse response) {dictService.exportData(response); }

正真的實現是在service層。如下

public void exportData(HttpServletResponse response) {try {//設置響應頭response.setContentType("application/vnd.ms-excel"); //指示響應內容的格式response.setCharacterEncoding("utf-8");// 這里URLEncoder.encode可以防止中文亂碼 當然和easyexcel沒有關系String fileName = URLEncoder.encode("數據字典", "UTF-8");// 指示響應內容以附件形式下載response.setHeader("Content-disposition", "attachment;filename=" + fileName + ".xlsx");//封裝數據集合List<Dict> dictList = baseMapper.selectList(null);ArrayList<DictEeVo> dictEeVos = new ArrayList<>();dictList.forEach(dict -> {DictEeVo dictEeVo = new DictEeVo();BeanUtils.copyProperties(dict, dictEeVo);dictEeVos.add(dictEeVo);});//用流的方式,瀏覽器文件下載EasyExcel.write(response.getOutputStream(), DictEeVo.class).sheet("數據字典").doWrite(dictEeVos);} catch (IOException e) {e.printStackTrace();}}

前端代碼

在前臺頁面點擊導出,


相關前端代碼大致如下:

<div class="el-toolbar-body" style="justify-content: flex-start"><el-button type="primary" @click="exportData"><i class="el-icon-download el-icon--right" /> 導出</el-button> ```

不需要寫api部分,直接訪問。也可以訪問9001

exportData() {window.open("http://localhost:8202/admin/cmn/dict/exportData");},

導出效果:


數據字典導入

后端接口

導入的excel文件格式,要滿足格式DictEeVo

Controller方法想接收一個文件,這里文件名稱必須是file,可以使用@RequestParam(“file”)

@ApiOperation(value = "導入")@PostMapping("importData")public R importData(MultipartFile file) {dictService.importDictData(file);return R.ok();}
1、創建監聽器讀取

invoke,每讀一行,這個方法就調用一次

@Component public class DictListener extends AnalysisEventListener<DictEeVo> {@Autowiredprivate DictMapper dictMapper;//一行一行讀取@Overridepublic void invoke(DictEeVo dictEeVo, AnalysisContext analysisContext) {//調用方法添加數據庫Dict dict = new Dict();BeanUtils.copyProperties(dictEeVo,dict);dictMapper.insert(dict);}@Overridepublic void doAfterAllAnalysed(AnalysisContext analysisContext) {} }
2.service層實現業務邏輯
@Overridepublic void importDictData(MultipartFile file) {try {EasyExcel.read(file.getInputStream(), DictEeVo.class, dictListener).sheet().doRead();} catch (IOException e) {e.printStackTrace();}}
3.使用postman測試文件上傳接口

查看數據庫的字典表,導入成功


前端部分


點擊彈窗框上選擇導入的文件,visible.sync控制顯示隱藏彈出框

<el-dialog title="導入" :visible.sync="dialogImportVisible" width="480px"><el-form label-position="right" label-width="170px"><el-form-item label="文件"><el-upload:multiple="false":on-success="onUploadSuccess":action="'http://localhost:8202/admin/cmn/dict/importData'"class="upload-demo"><el-button size="small" type="primary">點擊上傳</el-button><div slot="tip" class="el-upload__tip">只能上傳xls文件,且不超過500kb</div></el-upload></el-form-item></el-form><div slot="footer" class="dialog-footer"><el-button @click="dialogImportVisible = false">取消</el-button></div></el-dialog>

效果如下:

導入成功回調方法

importData() {this.dialogImportVisible = true;},onUploadSuccess(response, file) {this.$message.info("導入成功");//關閉彈出框this.dialogImportVisible = false;//重新查詢一級數據this.getDictList(1);},

Spring Cache

Spring Cache 是一個非常優秀的緩存組件;是Spring基于aop提供的自動緩存管理

只需要通過注解標注到查詢的業務方法上 可以將查詢方法返回的結果緩存起來,以后查詢時有緩存不在執行業務代碼

Spring Cache步驟:
1、為springcache提供一個緩存管理接口的實現
2、啟動類/配置類 添加**@EnableCaching注解
3、在需要緩存管理的業務方法(查詢)上使用
@Cachable(…key )** 標注

spring會自動管理業務方法的數據緩存 調用第一步實現的緩存管理對象的生命周期方法管理緩存


1、緩存管理接口的實現

redis緩存:緩存的目的避免(減少)客戶端從mysql中讀取數據

1.添加依賴

<!-- redis --> <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-redis</artifactId> </dependency><!-- spring2.X集成redis所需common-pool2--> <dependency><groupId>org.apache.commons</groupId><artifactId>commons-pool2</artifactId><version>2.6.0</version> </dependency>

2.創建配置類(拷貝)


@EnableCaching 必須要加,否則spring-data-cache相關注解不會生效…

@Configuration @EnableCaching public class RedisConfig {/*** 設置RedisTemplate規則* @param redisConnectionFactory* @return*/@Beanpublic RedisTemplate<Object, Object> redisTemplate(RedisConnectionFactory redisConnectionFactory) {RedisTemplate<Object, Object> redisTemplate = new RedisTemplate<>();redisTemplate.setConnectionFactory(redisConnectionFactory);Jackson2JsonRedisSerializer jackson2JsonRedisSerializer = new Jackson2JsonRedisSerializer(Object.class);//解決查詢緩存轉換異常的問題ObjectMapper om = new ObjectMapper(); // 指定要序列化的域,field,get和set,以及修飾符范圍,ANY是都有包括private和publicom.setVisibility(PropertyAccessor.ALL, JsonAutoDetect.Visibility.ANY); // 指定序列化輸入的類型,類必須是非final修飾的,final修飾的類,比如String,Integer等會跑出異常om.enableDefaultTyping(ObjectMapper.DefaultTyping.NON_FINAL);jackson2JsonRedisSerializer.setObjectMapper(om);//序列號key valueredisTemplate.setKeySerializer(new StringRedisSerializer());redisTemplate.setValueSerializer(jackson2JsonRedisSerializer);redisTemplate.setHashKeySerializer(new StringRedisSerializer());redisTemplate.setHashValueSerializer(jackson2JsonRedisSerializer);redisTemplate.afterPropertiesSet();return redisTemplate;}/*** 設置CacheManager緩存規則* @param factory* @return*/@Beanpublic CacheManager cacheManager(RedisConnectionFactory factory) {RedisSerializer<String> redisSerializer = new StringRedisSerializer();Jackson2JsonRedisSerializer jackson2JsonRedisSerializer = new Jackson2JsonRedisSerializer(Object.class);//解決查詢緩存轉換異常的問題ObjectMapper om = new ObjectMapper();om.setVisibility(PropertyAccessor.ALL, JsonAutoDetect.Visibility.ANY);om.enableDefaultTyping(ObjectMapper.DefaultTyping.NON_FINAL);jackson2JsonRedisSerializer.setObjectMapper(om);// 配置序列化(解決亂碼的問題),過期時間600秒RedisCacheConfiguration config = RedisCacheConfiguration.defaultCacheConfig().entryTtl(Duration.ofSeconds(600)).serializeKeysWith(RedisSerializationContext.SerializationPair.fromSerializer(redisSerializer)).serializeValuesWith(RedisSerializationContext.SerializationPair.fromSerializer(jackson2JsonRedisSerializer)).disableCachingNullValues();RedisCacheManager cacheManager = RedisCacheManager.builder(factory).cacheDefaults(config).build();return cacheManager;} }

當然還有第二版,這一版是之后加的(這版是老師講過的,還算是能看懂。。。)

@Configuration public class RedisCacheConfig {//1、RedisTemplate配置鍵和值的序列化器@AutowiredRedisTemplate redisTemplate;@PostConstructpublic void init(){redisTemplate.setKeySerializer(new StringRedisSerializer());redisTemplate.setValueSerializer(new GenericJackson2JsonRedisSerializer());}//2、緩存管理CacheManager接口的實現//LettuceConnectionFactory commons-pool2包中提供的Redis連接池工廠類@Beanpublic CacheManager cacheManager(LettuceConnectionFactory connectionFactory){RedisCacheConfiguration cacheConfig = RedisCacheConfiguration.defaultCacheConfig().entryTtl(Duration.ofMinutes(30)) //緩存過期時間.disableCachingNullValues() //不緩存空值.serializeKeysWith(RedisSerializationContext.SerializationPair.fromSerializer(new StringRedisSerializer())) //鍵序列化器.serializeValuesWith(RedisSerializationContext.SerializationPair.fromSerializer(new GenericJackson2JsonRedisSerializer()));//值序列化器RedisCacheManager cacheManager = RedisCacheManager.builder(connectionFactory).cacheDefaults(cacheConfig).build();return cacheManager;} }

3.配置文件

spring.redis.host=192.168.2.108 spring.redis.port=6379 spring.redis.database= 0 spring.redis.timeout=1800000#連接池最大連接數 spring.redis.lettuce.pool.max-active=20 #連接池最大阻塞等待時間(使用負值表示沒有限制) spring.redis.lettuce.pool.max-wait=-1 #連接池中的最大空閑連接 spring.redis.lettuce.pool.max-idle=5 #連接池中的最小空閑連接 spring.redis.lettuce.pool.min-idle=0

2、使用@Cachable緩存管理

@Cacheable添加緩存

1、查詢數據字典+@Cacheable

  • 如果緩存存在,則直接讀取緩存數據返回;
  • 如果緩存不存在,則執行方法,并把返回的結果存入緩存中。

1.key 可選屬性,可以使用 SpEL 標簽自定義緩存的key, key中可以獲取業務方法的形參值
2.#號代表這是一個 SpEL 表達式,此表達式可以遍歷方法的參數對象
@Cacheable(value = "dictCache", key = "'dict_'+#id")
3. 緩存的key: 使用value和key的值拼接,如: dictCache::dict_id的值

如果參數是對象Dict dict,可以這么獲取
> key="'dict_'+#dict.value"

//value:命名空間@Cacheable(value = "dictCache", key = "'dict_'+#id")@Overridepublic List<Dict> findChildData(Long id) {QueryWrapper<Dict> queryWrapper = new QueryWrapper<>();queryWrapper.eq("parent_id", id);//向list集合每個dict對象中設置hasChildrenList<Dict> dicts = baseMapper.selectList(queryWrapper);System.out.println("從mysql中查詢id=" + id + "的數據");dicts.forEach(dict -> {dict.setHasChildren(this.isChildren(dict.getId()));});return dicts;}

redis中效果:


@CacheEvict緩存驅逐

放在刪除、更新方法上

使用該注解**@CacheEvict**標志的方法,會清空指定的緩存。一般用在更新或者刪除方法上
allEntries 是否清除當前 value值空間下的所有緩存數據。默認false

導入數據的時候,把redis中數據都清除

@CacheEvict(value = "dictCache", allEntries = true)@Overridepublic void importDictData(MultipartFile file) {try {EasyExcel.read(file.getInputStream(), DictEeVo.class, dictListener).sheet().doRead();} catch (IOException e) {e.printStackTrace();}}

@CachePut更新緩存

用在修改方法或添加方法上

同步緩存的做法
當mysql中的數據發生改變,就會清空redis中對應命名空間下的緩存數據


3、手動緩存管理

由于緩存雪崩的問題,我們需要手動管理緩存。。使TTL設置的時間不那么集中。雖然這是另外一個方法,不要在意這些細節。。。

@Autowired PmsClient pmsClient;//遠程服務調用的feign接口@Autowired RedisTemplate redisTemplate; //刪除上面的Cacheable注解 @Override public List<CategoryEntity> levelTwoAndSubsCates(String cid) {//使用緩存管理//1、從緩存中查詢cid的二級三級分類集合 如果有直接返回String key = "idx:cache:cates:"+cid;Object obj = redisTemplate.opsForValue().get(key);if(obj!=null){return (List<CategoryEntity>) obj;}//2、如果緩存沒有 再遠程查詢二三級分類集合ResponseVo<List<CategoryEntity>> responseVo = pmsClient.lv2AndSubsCates(cid);//將查詢結果存到緩存中redisTemplate.opsForValue().set(key,responseVo.getData() ,1800+new Random().nextInt(200), TimeUnit.SECONDS);return responseVo.getData(); }

4、緩存一致性

數據庫數據更新后如何保證緩存的數據和數據庫數據一致:

  • 雙寫模式:數據庫更新同時更新redis緩存數據

    ? 先寫哪一個存在問題:redis和數據庫之間的事務不容易保證

  • 失效模式: 更新數據庫時 讓緩存失效

    ? 更新數據庫業務執行時 緩存會失效,此時如果數據還未寫成功 有請求查詢數據查到了數據庫中還未更新的數據到緩存中,此時才寫成功 緩存的數據和數據庫仍然不一致

  • 雙刪模式:更新數據庫前刪除一次緩存 更新成功后再刪除一次緩存

  • 數據庫同步中間件:基于mysql的binlog日志將數據庫更新的數據同步到第三方的中間件(redis mq es)

    • canal:阿里開源的一個框架

5、緩存并發問題

1.緩存雪崩

緩存雪崩:首頁數據訪問量大,數據緩存過期時間接近 會導致多個緩存同時失效,大量的請求可能直接查詢數據庫

解決:隨機因子 讓多個熱門key失效的時間分散


2.緩存擊穿

緩存擊穿:單個熱點key突然失效,導致大量的請求同時訪問數據庫查詢數據

?解決:控制只讓一個線程查數據 其他的等待使用緩存 分布式鎖


3.緩存穿透

緩存穿透 : 訪問數據庫一定不存在的數據時,請求每次都會先查詢緩存,然后再查數據庫

解決:

  • 空數據也短暫的緩存:為了避免惡意攻擊
  • 布隆過濾器
  • 總結

    以上是生活随笔為你收集整理的22-08-06 西安 尚医通(03)EasyExcel; Spring Cache 、Redis做缓存的全部內容,希望文章能夠幫你解決所遇到的問題。

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

    天天综合导航 | 天天干夜夜爽 | 欧美成人性网 | 日韩精品一区二区三区视频播放 | 亚洲欧洲精品在线 | 国产精品九九九 | 麻豆国产视频下载 | 亚洲区精品视频 | 99国产成+人+综合+亚洲 欧美 | 欧美a级免费视频 | 成人av影视观看 | 婷婷中文字幕在线观看 | 91成人蝌蚪 | av成人黄色 | 日韩.com| 日韩系列 | 亚洲高清av在线 | 色a在线观看 | 午夜视频一区二区三区 | 色综合天天视频在线观看 | 99视频免费| 免费男女羞羞的视频网站中文字幕 | 手机在线看a | 国产精品美女久久久久久久 | av在线8 | 日韩久久久久 | 91天堂影院| 国产精品久久久久一区二区 | 91精品国产麻豆国产自产影视 | 国产精品一区二区吃奶在线观看 | 狠狠操精品 | 96久久久| 夜夜操夜夜干 | 中文字幕免费高清在线 | 97夜夜澡人人爽人人免费 | 久操视频在线免费看 | 亚洲精品国产精品国自 | 久久a v视频 | 精品国产伦一区二区三区免费 | 一区二区国产精品 | 黄色视屏免费在线观看 | 国产成人精品久久久久蜜臀 | 亚洲人天堂 | 国产精品2020 | 99久久99热这里只有精品 | 国产只有精品 | 中文字幕免费一区 | www.888.av| 色婷av| 国产精品系列在线 | 91成人午夜 | 中文字幕久久精品一区 | 97超碰中文 | 999久久国精品免费观看网站 | 啪啪免费观看网站 | 天天操 夜夜操 | 久久另类小说 | 天天操天天色综合 | 天天草av | 亚洲精品美女久久久 | 国产精品女同一区二区三区久久夜 | 久久久亚洲国产精品麻豆综合天堂 | 天天操天天操天天操天天操 | 特级黄录像视频 | 最新av中文字幕 | 91精品入口| 色婷婷激婷婷情综天天 | 久久精品小视频 | 色婷婷色| 伊人资源站 | 在线а√天堂中文官网 | 午夜久久久久 | 精品国产伦一区二区三区 | 91视频一8mav| 在线91播放 | 国产精品毛片久久久久久久久久99999999 | 精品99久久 | 免费在线观看午夜视频 | 国产韩国日本高清视频 | 99re6热在线精品视频 | 麻花天美星空视频 | 日韩视频免费播放 | 狠狠躁夜夜躁人人爽视频 | 91久久久久久久一区二区 | 免费黄色小网站 | 成人av免费电影 | 欧美性做爰猛烈叫床潮 | 天天亚洲综合 | 亚洲狠狠操 | 久久久久国产一区二区 | 日韩av进入 | 在线日韩视频 | 大片网站久久 | 在线观看免费av网站 | 久久久久久免费毛片精品 | 亚洲日本va在线观看 | 国产一级免费电影 | avwww在线 | 久久国产精品99久久久久久老狼 | 亚洲天天干| 久久国产精品一国产精品 | 深爱激情亚洲 | www.97色.com| 波多野结衣在线视频免费观看 | 日韩av电影手机在线观看 | 手机av片| 精品亚洲欧美一区 | 亚洲在线观看av | 日韩久久精品一区二区 | 欧美性性网 | 久草在线久草在线2 | 黄www在线观看 | 草久热| 国产精品麻豆一区二区三区 | 五月天婷亚洲天综合网精品偷 | 日韩精品欧美精品 | 狠狠网亚洲精品 | 91在线看黄 | 特级西西人体444是什么意思 | 久草在线免费看视频 | 久久久久久久免费 | 一区二区视频在线观看免费 | 日韩av手机在线观看 | 国产视频一二区 | 五月婷婷黄色网 | 天天干天天天 | 久久国产品 | 美女黄频免费 | 久二影院 | 日韩高清在线一区二区三区 | 亚洲国产一区在线观看 | 三级大片网站 | 国产精品成人一区 | 亚洲无吗视频在线 | 999国产| 国产在线精品一区二区三区 | 999久久久| 久久成年人网站 | 国产黄色在线看 | 国产黄色免费看 | 国产美女视频免费观看的网站 | 久久人人爽 | www.色午夜.com | 青青网视频 | 亚洲精选国产 | 黄色小说在线观看视频 | 操夜夜操| 欧美日韩xxx | 国产一二三区av | 中文免费在线观看 | 91麻豆精品国产91久久久久久久久 | 日韩综合一区二区三区 | 国产精品专区h在线观看 | 亚洲第一成网站 | 婷婷成人亚洲综合国产xv88 | 天堂av网在线 | 成人三级黄色 | 国产在线不卡 | av成人在线看 | 亚洲视频久久 | 午夜免费久久看 | 欧美色婷 | 精品亚洲一区二区三区 | 久久精品毛片基地 | 欧美色综合 | 国产日韩中文字幕 | 亚洲第一av在线播放 | 免费国产黄线在线观看视频 | 中文字幕亚洲欧美日韩 | 国产69久久久 | 九九视频这里只有精品 | 最新中文字幕在线观看视频 | 色综合激情久久 | 人人添人人澡人人澡人人人爽 | 麻豆91视频 | 91亚洲精品久久久蜜桃 | 日韩日韩日韩日韩 | 在线观看 亚洲 | 国产精品网站一区二区三区 | 中文字幕乱码日本亚洲一区二区 | 亚洲美女免费精品视频在线观看 | 日韩欧美视频在线观看免费 | 婷婷色吧 | 精品国内自产拍在线观看视频 | 亚洲精品美女在线 | 天天爱天天插 | 国产亚洲精品电影 | 国产在线免费 | 亚洲精品日韩在线观看 | 五月激情婷婷丁香 | 午夜av免费观看 | 国产精品成人aaaaa网站 | 欧美日韩精品综合 | 亚洲成a人片77777kkkk1在线观看 | 免费成人在线电影 | 久久99久久99精品免观看粉嫩 | 国际精品久久久久 | 中中文字幕av在线 | 中文字幕亚洲精品在线观看 | 国产精品久久精品国产 | 超碰成人网| 五月激情六月丁香 | 久草视频中文 | 日日精品| 亚洲乱亚洲乱亚洲 | 日韩婷婷 | 91丨porny丨九色| 97在线精品国自产拍中文 | 精品91| 亚洲欧美精品在线 | 日韩aⅴ视频 | 一级黄色在线视频 | 国产在线欧美日韩 | 日本免费久久高清视频 | 91在线公开视频 | 韩日精品视频 | 九九欧美视频 | 亚洲国产偷 | 国产一区二区成人 | 欧美九九九| 成人av资源网 | 免费不卡中文字幕视频 | 国产免费嫩草影院 | 丁五月婷婷 | 亚洲欧美日韩在线一区二区 | 日韩高清不卡一区二区三区 | 在线免费观看黄色大片 | 久久久久久久久毛片精品 | 18做爰免费视频网站 | 成年人黄色免费看 | 最新av在线免费观看 | 色综合久久中文字幕综合网 | 91精品在线免费观看视频 | 国产精品一区在线观看 | 欧美男同视频网站 | 在线 国产 亚洲 欧美 | 国产探花视频在线播放 | av在线最新| 中文字幕亚洲精品在线观看 | 3d黄动漫免费看 | 在线亚洲午夜片av大片 | 精品久久久久久久久久久久久久久久 | 天天综合网 天天 | 国产精品一区二区在线播放 | 96av在线| 美女国产网站 | 中文字幕免费观看视频 | 波多野结依在线观看 | 久久久免费av | 国产永久免费高清在线观看视频 | 精品999久久久 | 天天天天天天天天操 | 国产精品第一页在线观看 | 中文字幕在 | 午夜色大片在线观看 | 免费网站黄 | 超碰97人人在线 | 最新91在线视频 | 久久99网站 | 国产亚洲精品xxoo | 国产美女精品视频免费观看 | 97碰碰精品嫩模在线播放 | 婷婷视频在线 | 最新av电影网站 | 国产日韩视频在线播放 | 在线成人av | 精品在线亚洲视频 | 国产免费人成xvideos视频 | 久久中文欧美 | 天天干天天在线 | 综合天天色 | 国产一区二区在线看 | 国产中文字幕网 | 免费日韩高清 | 亚洲精品国产免费 | 国产精品久久一区二区无卡 | 色综合天天天天做夜夜夜夜做 | 国产美女网站在线观看 | 色婷婷久久一区二区 | 在线看成人片 | 国产精品视频在线看 | 在线v片 | 亚洲精品国内 | 久久国产精品免费一区 | 九九久久国产 | 亚洲精品免费在线观看 | 国产色综合 | 久久视频精品在线观看 | 久久一区91 | 国产精品一区二区久久久 | 激情开心站 | 超碰97成人 | 96国产精品| 综合五月 | 日本精品在线视频 | av在线影视 | 中文字幕av播放 | 色综合五月 | 成人在线视频观看 | 91色影院 | 久久精品久久99 | 中文字幕的| 91亚洲精品久久久蜜桃借种 | 久久免费视频在线观看 | 色综合天天综合网国产成人网 | 久久精品黄 | 婷婷在线观看视频 | 超碰在线人 | 视频在线日韩 | 黄色大全视频 | 久久国产精品成人免费浪潮 | 一区二区成人国产精品 | 涩涩网站在线观看 | 久草在线资源观看 | 黄色午夜 | 精品一二三区 | 99久久日韩精品免费热麻豆美女 | 制服丝袜亚洲 | 久久久夜色 | 欧美日韩久久不卡 | 在线久久 | 国产裸体永久免费视频网站 | 天天色天天色 | 久久久久久国产精品久久 | 不卡电影免费在线播放一区 | 天天干天天干天天干天天干天天干天天干 | 国产一区二区在线观看视频 | 男女男视频 | 99日韩精品 | 美女网站免费福利视频 | 色综合五月天 | 天天操天天干天天爽 | 五月综合在线观看 | 天天艹天天操 | 日韩欧美精品在线视频 | 在线观看亚洲国产 | 日韩欧美视频一区 | 久久精品亚洲 | 91爱爱网址 | 亚洲无吗av | 国产成人免费观看 | 国产在线a不卡 | 国产一级电影免费观看 | 超碰免费久久 | 在线色资源 | 免费在线看成人av | 日韩色一区二区三区 | 免费h漫在线观看 | 日韩中文字幕电影 | 狠狠色伊人亚洲综合网站野外 | 久热免费 | 日日躁夜夜躁aaaaxxxx | 亚洲精品久久久久久久蜜桃 | 久久人网| 91久久偷偷做嫩草影院 | 国产在线欧美在线 | 日本精品视频在线观看 | 波多野结衣日韩 | 伊人热| 色国产视频| 天天做天天爱天天爽综合网 | 久久亚洲影院 | 午夜精品福利在线 | 91精品在线免费观看 | 成人精品在线 | 国产精品久久99综合免费观看尤物 | 久久人操 | 93久久精品日日躁夜夜躁欧美 | 精品国产乱码久久久久久天美 | 女人魂免费观看 | 欧美性另类 | 一级c片 | 国产91免费在线 | 日日干日日 | 日本精品一区二区 | 国产网站色 | 黄色片免费在线 | 欧美成人区 | 99热在线看 | 999免费视频 | 69久久久久久久 | 日韩精品在线观看视频 | 日韩av成人在线观看 | 黄色小说在线免费观看 | 亚洲午夜在线视频 | 国产在线观看,日本 | 亚洲区视频在线观看 | 久久躁日日躁aaaaxxxx | 国产免费av一区二区三区 | 五月综合网 | 狠狠久久婷婷 | 国产成人久久精品77777综合 | 欧美在线日韩在线 | 午夜免费在线观看 | 日韩区视频 | 日韩四虎| 美女视频黄免费的久久 | 色妞色视频一区二区三区四区 | 国产特级毛片aaaaaa高清 | 久久久久一区二区三区 | 97中文字幕| 五月天激情综合网 | 国产精品99在线播放 | 国产精品video爽爽爽爽 | 中文超碰字幕 | 91九色丨porny丨丰满6 | 在线午夜电影神马影院 | 日韩av视屏 | 亚洲天堂网在线观看视频 | 亚洲另类xxxx| 国产视频欧美视频 | 国产精品成人自产拍在线观看 | 在线视频久久 | 欧洲一区二区三区精品 | 国产91丝袜在线播放动漫 | 视频精品一区二区三区 | 99久久精品日本一区二区免费 | 久久久久久欧美二区电影网 | 国内外成人在线视频 | 国产精品久久三 | 激情婷婷综合 | 色综合天天 | 久久亚洲欧美日韩精品专区 | 久久久久久久国产精品影院 | 久久久久观看 | 精品国产乱码一区二 | 在线观看国产区 | 国产区在线视频 | 欧美精品一区二区在线播放 | 国产精品久久久久久久久久不蜜月 | 男女免费视频观看 | 国产亚洲视频中文字幕视频 | 国产免费一区二区三区最新6 | 香蕉视频导航 | 久久丁香| 九色免费视频 | 亚洲精品玖玖玖av在线看 | 91桃色在线免费观看 | 黄色视屏免费在线观看 | 亚洲人成综合 | 三级a毛片 | 精品成人免费 | 欧美激情视频免费看 | 精品在线观| 午夜视频在线观看一区二区 | 91最新视频在线观看 | www.天天干| 久久久久高清毛片一级 | 日韩精品高清视频 | 激情丁香婷婷 | 午夜国产福利在线 | 久草在线免费看视频 | 伊人久久电影网 | 中文字幕在线成人 | 国精产品满18岁在线 | 中文字幕中文字幕中文字幕 | 99在线观看精品 | 99热国产在线 | 国产成人精品女人久久久 | 黄色美女免费网站 | 天天色.com | 国产免费高清 | 国产精品亚洲精品 | 中文字幕一区二区三区在线视频 | 在线观看日韩专区 | 天天操天天玩 | 99色在线| 91热这里只有精品 | 少妇bbw搡bbbb搡bbb | 中文字幕一区二 | 视频高清| 中文字幕在线字幕中文 | 激情五月亚洲 | 亚洲一区二区三区四区在线视频 | 国产精品九九久久99视频 | 毛片视频电影 | 337p日本欧洲亚洲大胆裸体艺术 | 又黄又爽又湿又无遮挡的在线视频 | www91在线 | 久久久99国产精品免费 | 久久久久免费精品国产小说色大师 | 丝袜美腿在线 | 国产高清精品在线 | 丰满少妇在线观看资源站 | 久久综合久久综合久久综合 | 久久伊人精品一区二区三区 | 91亚洲精品国偷拍 | 国产精品免费观看网站 | 视频在线精品 | 91毛片视频| 91日韩精品 | 国产老妇av | 欧美一级激情 | 亚洲国产av精品毛片鲁大师 | 久久久久久久久毛片精品 | 99久久精品久久久久久动态片 | 中文字幕久久亚洲 | www..com黄色片 | 国产精品久一 | 亚洲黄色激情小说 | 91视频-88av| 999超碰 | 人人精久 | 日韩精品久久久免费观看夜色 | av噜噜噜在线播放 | 国产精品免费在线观看视频 | av一级网站 | 尤物九九久久国产精品的分类 | 欧美一区成人 | 99国产精品久久久久久久久久 | 国产精品网红直播 | 天天射天天操天天色 | 国产一二区免费视频 | 99在线观看视频 | 国产中文字幕在线观看 | 韩国在线一区二区 | 亚洲成人av在线播放 | 在线免费观看视频一区二区三区 | 伊人电影在线观看 | 亚洲黄色小说网 | 在线亚洲日本 | 久久99中文字幕 | 亚洲午夜精品久久久久久久久久久久 | 久草在线视频网 | 国产高清第一页 | 又爽又黄又无遮挡网站动态图 | 亚洲影视资源 | 成人免费 在线播放 | 不卡电影免费在线播放一区 | 日韩精品在线视频免费观看 | 91精品网站| av在线播放观看 | 国产精品久久久久久高潮 | 99精品视频在线 | 精品久久久久久久久中文字幕 | 懂色av懂色av粉嫩av分享吧 | 中文字幕在线观看免费高清电影 | 人人舔人人射 | 五月婷婷,六月丁香 | 国产在线观看免费av | 伊人国产女 | 在线观看成人 | 一区二区精品国产 | 国产免费视频在线 | 最近中文字幕视频网 | 国产精品国产三级国产不产一地 | 999在线精品 | 一区二区三区在线播放 | 中文av字幕在线观看 | 一区二区三区在线电影 | 婷婷电影在线观看 | 综合天堂av久久久久久久 | 在线观看视频一区二区三区 | 91亚洲精品视频 | 午夜色婷婷 | 色诱亚洲精品久久久久久 | 欧洲一区二区在线观看 | 国产一级二级在线观看 | 国产精品99爱| 五月激情站 | 蜜桃av久久久亚洲精品 | 日韩在线中文字幕 | 最近中文字幕在线中文高清版 | 国产精品久久久久久久午夜 | 六月激情网 | 免费观看www7722午夜电影 | 久久久午夜影院 | 蜜桃久久久 | 在线观看亚洲a | 一区二区久久久久 | 色综合久久88色综合天天免费 | 亚洲专区一二三 | 黄色一级大片免费看 | 欧美一级性生活视频 | 一级性视频 | 婷婷婷国产在线视频 | 免费观看国产视频 | 日韩av一区二区在线播放 | 国产玖玖在线 | www.av免费 | 五月婷婷在线视频观看 | 日韩大片在线 | 国内久久久久久 | 成人av一区二区在线观看 | 国产一区自拍视频 | 99国产成+人+综合+亚洲 欧美 | 毛片基地黄久久久久久天堂 | 国产一区免费在线观看 | 91免费观看国产 | 久久久精品福利视频 | 国产精品午夜8888 | 六月婷婷色| 精品亚洲视频在线 | 亚洲性xxxx | 久久中文精品视频 | 又粗又长又大又爽又黄少妇毛片 | 视频99爱 | 久久资源在线 | 日韩亚洲国产中文字幕 | 精品久久久成人 | 久久精品专区 | 久久久久国产一区二区 | 国产一区视频导航 | 黄色av免费看 | 91精品办公室少妇高潮对白 | 免费国产亚洲视频 | 中文字幕有码在线观看 | 91在线国产观看 | 亚洲日本中文字幕在线观看 | 在线观看视频一区二区 | 国产亚洲综合精品 | 日韩理论电影在线 | 免费av黄色 | 亚洲免费在线观看视频 | 丝袜美腿av | 亚洲国产精品女人久久久 | 国产精品毛片一区 | 免费韩国av| 99视频黄 | 久久人人爽人人片av | 国产午夜精品一区二区三区四区 | 激情久久婷婷 | 婷婷丁香激情 | 国产区精品区 | 夜夜夜夜猛噜噜噜噜噜初音未来 | 私人av | 欧美精品在线一区 | 五月天久久久 | av夜夜操| 特黄特色特刺激视频免费播放 | 国产精品热 | 国产一级大片免费看 | 天天操·夜夜操 | 久久99久国产精品黄毛片入口 | 天天干天天草天天爽 | 黄a在线观看 | 国产在线va | 久久综合九色综合网站 | 狠狠躁日日躁夜夜躁av | 麻豆精品视频 | 久久久久久久久影视 | 免费日韩 精品中文字幕视频在线 | 国产精成人品免费观看 | 1024久久| 国产91精品在线播放 | 91精品国产高清自在线观看 | 天天操天天干天天爱 | 日本在线视频网址 | 天天操人人要 | 欧美a视频在线观看 | 少妇av片 | 欧美一区二区在线看 | 亚洲波多野结衣 | 日日添夜夜添 | 久草视频免费 | 日韩精品一区电影 | 日日干日日色 | 久久99电影 | 日本中文字幕视频 | 中文字幕国产一区二区 | 天天爽天天碰狠狠添 | 成人黄色在线观看视频 | 91精品啪在线观看国产 | 一区二区精品在线 | 91麻豆精品国产自产在线游戏 | 国产精品久久久久久一区二区三区 | 日本精品一区二区在线观看 | 99久久精品视频免费 | 久久久久国产精品www | 久久精品xxx| 亚洲精品456在线播放 | 国产又黄又爽无遮挡 | 中文在线免费看视频 | 在线 你懂| 国产精品久久久久久爽爽爽 | 夜夜操天天操 | 高清视频一区二区三区 | 日韩国产精品久久久久久亚洲 | 国产高清一区二区 | 国产亚洲精品久 | 夜夜躁日日躁 | 亚洲精品视频在线免费播放 | 亚洲国产高清视频 | 久久久久国产视频 | 97操碰| 婷婷久月 | 91精品国产一区二区三区 | 欧美日韩一区二区三区在线免费观看 | 国产精品成人一区二区三区 | 亚洲欧美乱综合图片区小说区 | 国产精品a成v人在线播放 | 久久精品九色 | www.久久久com | 日韩中文字幕电影 | 免费日韩一区 | 欧美精品久久久久久久亚洲调教 | 高清一区二区 | 国产精品美女久久久 | 日韩精品免费专区 | 国产精品午夜久久久久久99热 | 亚洲综合精品视频 | 色伊人网 | 欧美一级日韩三级 | 久久免费电影网 | 亚洲国产资源 | 在线观看久久久久久 | 国产91电影在线观看 | 久久午夜电影 | 99性视频 | 精品福利视频在线观看 | 欧美激情精品久久久久久免费 | 久草视频在线资源 | 亚洲精品视 | 玖玖玖精品| 久久超碰99 | 夜夜躁日日躁狠狠久久88av | 国产精品成人免费 | 国产视频九色蝌蚪 | a级国产毛片 | 91在线欧美| 中文字幕在线日 | 人人爽人人做 | 日韩高清久久 | 永久免费精品视频网站 | 国产日韩在线观看一区 | 亚洲午夜久久久久久久久久久 | 天天天天天操 | 91一区啪爱嗯打偷拍欧美 | 天天操天天艹 | 在线观看片 | 亚洲精品美女在线观看播放 | 国产 色| 日韩不卡高清视频 | 探花国产在线 | 日本中文字幕高清 | 国产精品video| www.久久视频 | 超碰免费av | 久久综合久久综合这里只有精品 | 久草影视在线观看 | 五月婷婷综合在线视频 | 香蕉视频在线播放 | 狠狠综合久久av | 欧美性粗大hdvideo | 在线观看av片 | 亚洲久久视频 | 欧日韩在线视频 | 国产精品永久免费在线 | 性色在线视频 | 久久国产精品色婷婷 | 午夜国产一区二区 | 久久96国产精品久久99漫画 | 五月婷婷在线综合 | 欧美性黑人| 久久天天操 | 9999亚洲 | 免费黄色小网站 | 97色在线观看 | 国产视频99| av电影中文字幕 | 免费黄色激情视频 | 91精品中文字幕 | 99久久99热这里只有精品 | 麻豆视频免费观看 | 日本中文字幕在线一区 | 日韩精品中文字幕在线不卡尤物 | 欧美日韩中文国产 | 亚洲精品国产精品国自 | 国产成人1区 | 亚洲精品在线免费播放 | 欧美va天堂va视频va在线 | 欧洲精品在线视频 | 久久亚洲人 | 久久免费高清 | 六月丁香色婷婷 | 在线观看蜜桃视频 | 午夜久久视频 | 人人干在线观看 | 久久精品久久精品 | 丁香花中文在线免费观看 | 久久久久国产一区二区三区四区 | 天天色图| 日韩av综合网站 | 久久久久夜色 | 久久午夜电影院 | 91中文字幕视频 | 亚洲日本国产 | 四虎影视成人永久免费观看视频 | 色狠狠操 | 91av电影在线观看 | 99精品久久久久久久 | av网址在线播放 | 日韩高清免费观看 | 久久国产精品精品国产色婷婷 | 国产人在线成免费视频 | av网站播放 | 欧美精品乱码久久久久久按摩 | 一区二区三区动漫 | 婷婷激情在线 | 丁香九月激情 | 欧美日韩三级在线观看 | 婷婷六月网 | 成年人黄色免费看 | 久久久精品国产免费观看一区二区 | 五月天.com| 国产一级二级三级在线观看 | 96亚洲精品久久久蜜桃 | 波多野结衣久久资源 | 欧美激情综合色综合啪啪五月 | 色综合婷婷 | 精品九九九九 | 91精品国 | 欧美肥妇free | 人人看黄色| 欧美 日韩 成人 | 99视频在线观看一区三区 | 亚洲精品大全 | 精品视频一区在线观看 | 成 人 黄 色 免费播放 | 97视频免费 | 播五月综合 | 99热这里只有精品国产首页 | 一本一道久久a久久精品蜜桃 | 午夜久久福利影院 | 久久精品一二区 | 国产免费观看久久黄 | 高清国产在线一区 | 亚洲精品在线观看中文字幕 | 欧洲在线免费视频 | 99精品欧美一区二区三区黑人哦 | 又紧又大又爽精品一区二区 | 国产精品资源网 | 久久精品二区 | www.久久成人 | 日韩视频图片 | 在线观看岛国片 | 怡红院av| 日韩欧美在线中文字幕 | 超碰官网 | 日韩av中文 | 在线国产99 | 91丨九色丨丝袜 | 国产精品久久久久av福利动漫 | 97碰碰视频 | 国产精品久久久久久久免费大片 | 狠狠操在线 | 在线黄色毛片 | 人人爽人人片 | 在线播放 日韩专区 | 中文字幕麻豆 | 成人夜晚看av | 中文av在线免费观看 | 黄色小说在线观看视频 | 亚洲国产中文在线观看 | 国产精品成人一区二区 | 久久96国产精品久久99软件 | 中文字幕在线观看免费高清完整版 | 黄色免费电影网站 | 在线观看黄色小视频 | 国产高清精品在线 | www.狠狠 | 久久综合一本 | 国内毛片毛片 | 久久免费视频在线观看30 | av电影中文| 免费a v观看 | 国产啊v在线 | 一区二区三区免费在线播放 | 亚洲精品国内 | 91插插影库 | 欧美性久久久久久 | 福利一区在线视频 | 国产高清免费av | 一本一道久久a久久精品蜜桃 | 中文一区二区三区在线观看 | 免费能看的av | 97在线视频网站 | 丁香六月av| 天天躁天天狠天天透 | 岛国精品一区二区 | 日韩xxxxxxxxx | 四虎影视精品永久在线观看 | 日三级在线 | 一区二区伦理 | 国际精品久久久久 | 日韩精品一区二区三区免费视频观看 | 久草视频资源 | 亚洲国产精品电影在线观看 | 91免费观看视频在线 | 91av视频网| 8x成人免费视频 | 超碰在线日韩 | 天天爱天天干天天爽 | 99精品视频中文字幕 | 精品日韩视频 | 手机在线免费av | 日韩有码专区 | 婷婷电影网| 一区二区三区精品在线视频 | 欧美极品一区二区三区 | 中文字幕在线观看第一区 | 国产精品自产拍在线观看 | www.夜夜草| 久久精品免视看 | 久久狠狠一本精品综合网 | 国产成人精品av久久 | 亚洲爱爱视频 | 国产原创在线视频 | 免费国产在线精品 | 99久久精品久久亚洲精品 | 欧美成人日韩 | 日韩在线观看中文 | 精品久久久一区二区 | 丁香婷婷在线 | 亚洲另类在线视频 | 午夜视频一区二区三区 | 国产精品久久网站 | 婷婷色影院 | 久久电影中文字幕视频 | 亚洲精品自在在线观看 | 日韩久久精品一区二区三区 | 亚洲精品国久久99热 | 韩国av在线播放 | 99re8这里有精品热视频免费 | 中文久久精品 | 国产精品女同一区二区三区久久夜 | 激情电影在线观看 | 久久精品亚洲一区二区三区观看模式 | 91网在线观看 | 国产高清免费观看 | 成人动漫一区二区 | 久久99热这里只有精品国产 | 中文字幕在线播放第一页 | 果冻av在线 | 欧美成人精品欧美一级乱黄 | 亚洲视频h | 色网影音先锋 | 久热免费在线观看 | 69av久久| 日韩欧美在线免费观看 | 日韩网站在线免费观看 | 狠狠88综合久久久久综合网 | 天堂av观看 | 精品国产_亚洲人成在线 | 香蕉视频在线免费 | 五月天中文在线 | 亚洲午夜精品一区二区三区电影院 | 狠狠躁夜夜av | 久久精彩 | 久久ww | 欧美性大胆 | 超碰免费97 | 亚洲乱码国产乱码精品天美传媒 | 日韩二级毛片 | 91黄色免费看 | www天天干| 国产亚洲久一区二区 | 欧美国产在线看 | 五月天天色 | 亚洲 欧洲 国产 日本 综合 | 亚洲精品视频在线看 | 色婷婷啪啪免费在线电影观看 | 久草在线久草在线2 | 亚洲精品视频免费看 | 在线视频你懂得 | 欧美一区二区在线刺激视频 | 久久免费观看视频 | 国产免费看 | 欧美资源 | www.久草视频 | 综合色狠狠 | 国产999在线| 久久久久久久久亚洲精品 | 日日夜夜天天射 | 久草在线免费新视频 | 色综合网 | 深夜免费福利网站 | 国产一二三区av | 97超碰免费在线观看 | 黄色av三级在线 | 国产成人精品亚洲日本在线观看 | 99免费观看视频 | 中文字幕日韩免费视频 | 中文字幕一区二区在线播放 | 9幺看片 | 99热99| 成人激情开心网 | 中文欧美字幕免费 | 精品久久久久国产免费第一页 | 91色蜜桃 | 高清视频一区二区三区 | 亚洲日本va午夜在线影院 | 色噜噜日韩精品欧美一区二区 | 伊人久久电影网 | 成人av免费在线看 | 最新av网址在线 | 日韩在线一区二区免费 | av不卡中文字幕 |