精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

來,你們想要的打卡功能

開發 后端
打卡在生活中還是應用挺多的,比如上班打卡,健身打卡,學習打卡...等等,實際上打卡功能開發是挺容易的,讓我們來一起實現它吧,讓我們自己用著自己開發的功能吧!

前言

你的世界多數情況下充滿了混沌和單調,你的身體雖然不胖但并不會讓你感覺到那么有力量;你的過往乏善可陳,充斥著很多傷心與自我否定,你過往的未來也沒有驚喜在場。你想要一場新生,想要一次脫胎換骨,沒有行動,一切都是空想,依舊忍受痛苦與弱小。一點一滴的積累,才能感受飛輪轉起來時的酣暢淋漓,才會有氣勢如虹的力量 ,一點一滴的積累就是需要一個打卡的功能。

[[346092]]

打卡在生活中還是應用挺多的,比如上班打卡,健身打卡,學習打卡...等等,實際上打卡功能開發是挺容易的,讓我們來一起實現它吧,讓我們自己用著自己開發的功能吧!

為什么寫一篇打卡的功能性文章吶?

公司一個系統需要實現的一個小小功能,也是為了方便日后進行回顧以及優化,特此記錄下來,話不多說我們來實現它吧。

數據庫設計

1. 為什么要設計數據庫

  • 節省數據的存儲空間
  • 保證數據的完整性
  • 方便根據數據庫進行系統的開發

2. 根據需求設計數據庫

  • 打卡功能
  • 日志表(打卡用戶,打卡項目編號,打卡時間) 這個表中的打卡項目這個字段是非必須的,添加這個字段只是為了方便日后的擴展,其他兩個字段都是必須的
  • 項目表(項目編號,項目名稱,創建時間) 這個表是非必須的,只是為了方便日后的擴展,可加可不加
  • 統計表(項目編號,總打卡數,連續打卡數,打卡用戶,打卡時間) 這個表中的字段除了項目編號這個字段不是必須的,其他都是必須要的基本字段,
  • 我這樣設計三張表只是為了方便以后的擴展使用,除了項目表,其他兩張表都是最基礎的必須要的
  • 首先創建一個數據庫 clockin CHARACTER SET:指定數據庫采用的字符集,utf8不能寫成utf-8 COLLATE:指定數據庫字符集的排序規則,utf8的默認排序規則為
    1. utf8_general_ci(通過show character set查看) drop database if EXISTS clockin ; create database clockin CHARACTER SET utf8 COLLATE utf8_general_ci; 
  • sql 語句如下
    1. DROP TABLE IF EXISTS `clockin_count`; 
    2. CREATE TABLE `clockin_count` ( 
    3.   `id` int(11) NOT NULL AUTO_INCREMENT, 
    4.   `pid` int(11) DEFAULT NULL COMMENT '打卡項目', 
    5.   `sum` int(11) DEFAULT NULL COMMENT '打卡總次數', 
    6.   `cloop` int(11) DEFAULT NULL COMMENT '打卡連續次數', 
    7.   `name` varchar(25) COLLATE utf8_bin DEFAULT NULL COMMENT '打卡人', 
    8.   `dtime` datetime DEFAULT NULL ON UPDATE CURRENT_TIMESTAMP, 
    9.   PRIMARY KEY (`id`) 
    10. ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin
    11.  
    12. DROP TABLE IF EXISTS `clockin_log`; 
    13. CREATE TABLE `clockin_log` ( 
    14.   `id` int(11) NOT NULL AUTO_INCREMENT, 
    15.   `name` varchar(25) COLLATE utf8_bin DEFAULT NULL COMMENT '打卡人', 
    16.   `pid` int(11) DEFAULT NULL COMMENT '打卡項目', 
    17.   `dtime` datetime DEFAULT NULL COMMENT '打卡時間', 
    18.   PRIMARY KEY (`id`) 
    19. ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin
    20.  
    21. DROP TABLE IF EXISTS `clockin_project`; 
    22. CREATE TABLE `clockin_project` ( 
    23.   `id` int(11) NOT NULL AUTO_INCREMENT, 
    24.   `pid` int(11) NOT NULL, 
    25.   `project` varchar(25) COLLATE utf8_bin NOT NULL, 
    26.   `dtime` datetime DEFAULT NULL, 
    27.   PRIMARY KEY (`id`) 
    28. ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin

3. 理解清楚數據表之間的映射關系

  • clockin_log : 日志表,存儲用戶的每天打卡日志信息,表的數據更新率比較高,特此提出來,作為單獨的表使用
  • clockin_project:項目表,在什么項目上的打卡,不是非必要的,只是為了方便日后的擴展使用,而添加的
  • clockin_count:統計表,統計日志表中用戶的打卡信息,數據相對比較少,提取出來更加直觀,查詢數據用的比較頻繁

實現思路

首先進行判斷項目是否存在,存在才能進行打卡,接著判斷今天是否已打卡,如果今天沒打卡則插入數據,然后判斷昨天是否打卡,

昨天如果打卡了則連續天數,總天數都加一,若昨天沒打卡,則連續天數設為一,總天數加一,思維導圖如下:

來,你們想要的打卡功能

這里主要就是sql語句的編寫,我這里主要用到了sql中的 LEFT語法 ,對應了oracle中的substr(),主要是用來判斷今天昨天是否打卡

語法: ==LEFT (ARG,LENGTH)== ARG源數據,LENGTH個字符串,ARG可以是CHAR或BINARY STRING

例如:left('12345',2) --> 12

  1. <!-- 查詢今天是否打卡--> 
  2.     <select id="selectClockinIsexit" resultType="ClockinLog"> 
  3.         SELECT * FROM clockin_log where name = #{name} and pid = #{pid} 
  4.                    and LEFT(dtime,10) = LEFT(NOW(),10) 
  5.     </select> 
  6.  
  7. <!-- 查詢昨天是否打卡--> 
  8.     <select id="selectClockinYesterdayIsexit" resultType="ClockinLog"> 
  9.           SELECT * FROM clockin_log where name = #{name} and pid = #{pid} 
  10.            and LEFT(dtime,10)=LEFT(#{dtime},10) 
  11.     </select> 
  12.  
  13. 既由 2020-10-10T10:30:51  得到  2020-10-10 

主要代碼

這里我用到了 MybatisPlus,具體使用可以參照

這里的Result是我定義了一個結果集包含 code —— 狀態碼,msg —— 返回消息 ,data —— 數據信息

  1. // name 用戶名 pid 項目編號    
  2. public Result clock(String name,String pid){ 
  3.  
  4.         // 返回的數據類型 
  5.         Result<Object> result = new Result<>(); 
  6.  
  7.         // 得到昨天的日期 
  8.         Calendar calCalendar.getInstance(); 
  9.         cal.add(Calendar.DATE,-1); 
  10.         Date yesterday=cal.getTime(); 
  11.  
  12.         // 判斷今天是否打卡 
  13.         Boolean isexit = clockinLogService
  14.                 selectClockinIsexit(name, Integer.parseInt(pid)); 
  15.  
  16.         LambdaQueryWrapper<ClockinCount> wrapper = new LambdaQueryWrapper<>(); 
  17.         wrapper.eq(ClockinCount::getName,name).eq(ClockinCount::getPid,Integer.parseInt(pid)); 
  18.         ClockinCount one = clockinCountService.getOne(wrapper); 
  19.  
  20.         LambdaQueryWrapper<ClockinProject> wrapper1 = new LambdaQueryWrapper<>(); 
  21.         wrapper1.eq(ClockinProject::getPid,Integer.parseInt(pid)); 
  22.         ClockinProject project = clockinProjectService.getOne(wrapper1); 
  23.  
  24.         //打卡項目是否存在 
  25.         if (!StringUtils.isEmpty(project)){ 
  26.             if (isexit){// 判斷今天是否打卡 
  27.                 result.setRetCode(Result.ERROR); 
  28.                 result.setRetMsg("今日已打卡"); 
  29.                 result.setRowData(one); 
  30.                 return result; 
  31.             }else { 
  32.                 // 記錄打卡信息 
  33.                 ClockinLog clockinLog = new ClockinLog(); 
  34.                 clockinLog.setName(name).setPid(Integer.parseInt(pid)).setDtime(LocalDateTime.now()); 
  35.                 boolean save = clockinLogService.save(clockinLog); 
  36.                 if(save){//是否插入數據成功 
  37.                     Boolean yesterdayIsexit = clockinLogService
  38.                             selectClockinYesterdayIsexit(name, Integer.parseInt(pid), yesterday); 
  39.                     System.err.println("yesterdayIsexit->"+yesterdayIsexit); 
  40.                     if (yesterdayIsexit){  //判斷昨天有沒有打卡 
  41.                         System.err.println("昨天打卡了"); 
  42.                         // 更新打卡次數 
  43.                         ClockinCount cc = new ClockinCount(); 
  44.                         LambdaUpdateWrapper<ClockinCount> updateWrapper = new LambdaUpdateWrapper<>(); 
  45.                         updateWrapper.eq(ClockinCount::getPid,Integer.parseInt(pid)).eq(ClockinCount::getName, name); 
  46.                         cc.setSum(one.getSum()+1).setCloop(one.getCloop()+1); 
  47.                         clockinCountService.update(cc,updateWrapper); 
  48.                     }else { 
  49.                         if (!StringUtils.isEmpty(one)){  // 統計表中用戶存在否 
  50.                             // 更新打卡次數 
  51.                             ClockinCount cc = new ClockinCount(); 
  52.                             LambdaUpdateWrapper<ClockinCount> updateWrapper = new LambdaUpdateWrapper<>(); 
  53.                             updateWrapper.eq(ClockinCount::getPid,Integer.parseInt(pid)).eq(ClockinCount::getName, name); 
  54.                             cc.setSum(one.getSum()+1).setCloop(1); 
  55.                             clockinCountService.update(cc,updateWrapper); 
  56.                         }else { 
  57.                             // 插入數據信息 
  58.                             ClockinCount cc = new ClockinCount(); 
  59.                             cc.setCloop(1).setName(name).setPid(Integer.parseInt(pid)).setSum(1).setDtime(LocalDateTime.now()); 
  60.                             clockinCountService.save(cc); 
  61.                         } 
  62.                     } 
  63.                     one = clockinCountService.getOne(wrapper); 
  64.                     result.setRetCode(Result.SUCCESS); 
  65.                     result.setRetMsg("成功"); 
  66.                     result.setRowData(one); 
  67.                     return result; 
  68.                 } 
  69.             } 
  70.         }else { 
  71.             result.setRetCode(Result.ERROR); 
  72.             result.setRetMsg("失敗"); 
  73.             result.setRowData("打卡項目不存在"); 
  74.         } 
  75.         return null; 
  76.     } 

總結

本文主要介紹了用Java寫一個打卡功能的主要過程,打卡主要是記錄了一個人階段性的努力,如果自己的自我規劃學習能力不高,自我督促能力不強,那么這個打卡功能就可以完美的解決督促自己進行學習以及其他事情。以上就是本篇文章的主要代碼以及思路。

本文授權轉載自公眾號「良許Linux」。良許,世界500強外企Linux開發工程師,公眾號里分享大量Linux干貨,歡迎關注!

 

責任編輯:趙寧寧 來源: 今日頭條
相關推薦

2020-12-11 07:23:03

微信更新移動應用

2021-01-03 17:46:51

微信微信7.0.22移動應用

2015-05-04 11:26:52

2025-01-24 08:04:48

2013-12-12 13:13:10

Windows 9

2018-05-23 20:48:26

iOS 12分屏果粉

2019-10-24 14:15:52

Python工具數據

2012-08-17 09:44:27

Windows Pho

2021-10-14 14:00:44

996加班工作

2010-07-09 11:27:40

思科標準

2020-09-02 08:52:16

地圖Echarts可視化

2010-03-29 16:11:57

無線上網卡

2020-05-20 11:17:29

緩存服務器地址

2020-08-07 16:18:38

JavaScriptC++Python

2021-04-20 10:52:23

人工智能智能家居科技

2021-09-24 15:46:35

低碳未來

2019-11-27 15:09:41

開源技術 軟件

2013-08-26 09:31:47

技術面試

2009-12-24 13:48:57

Linux安裝
點贊
收藏

51CTO技術棧公眾號

天天影视网天天综合色在线播放| 国产色综合网| 日韩欧美在线综合网| 欧美精品一区二区性色a+v| 91久久国语露脸精品国产高跟| 亚洲最好看的视频| 日本电影亚洲天堂一区| 一本一道久久a久久综合精品| 国产精品欧美综合亚洲| 欧美视频一区| 亚洲欧美综合图区| 亚洲三级在线观看视频| 国产美女一区视频| 成人成人成人在线视频| 日本中文字幕久久看| 日韩欧美黄色网址| 国产精品成人**免费视频| 一二三区精品视频| 国产综合18久久久久久| 久久久久亚洲视频| 好看的av在线不卡观看| 亚洲人成伊人成综合网久久久| 天天干天天av| 国产在线88av| 国产精品传媒视频| 久久福利电影| 91亚洲精品国偷拍自产在线观看 | 国产精品伦子伦| 韩国成人在线| 亚洲欧美一区二区三区国产精品 | 成人一区二区三区中文字幕| 午夜精品一区二区三区视频免费看 | 日本孕妇大胆孕交无码| 久久蜜桃一区二区| 岛国一区二区三区高清视频| 销魂美女一区二区| 91久久综合| 欧美成人精品在线视频| 日本一区二区三区网站| 色999久久久精品人人澡69| 亚洲高清在线精品| www亚洲国产| 春暖花开成人亚洲区| 成人国产一区二区三区精品| 国产日韩欧美日韩| 国产伦精品一区二区三区视频我 | 久久免费一级片| 国产精品一区在线看| 波多野结衣一区二区三区| 成人在线精品视频| 久久精品偷拍视频| 久久精品网址| 欧美在线视频网| 日韩精品一区二区在线播放| 五月天综合网站| 亚洲精品一区中文字幕乱码| 91视频在线免费| 一区二区三区在线免费看 | 日本黄色片一级片| 成人短视频在线| 亚洲天堂成人在线观看| 先锋影音日韩| 成人福利在线| 国产日韩精品久久久| 久久综合九色综合久99| 无码国产色欲xxxx视频| 国产精品911| 亚洲精品免费网站| 国产内射老熟女aaaa∵| 国产综合久久久久影院| 成人黄色大片在线免费观看| 在线观看日韩一区二区| 麻豆精品精品国产自在97香蕉| 日本久久久久亚洲中字幕| 人妻丰满熟妇av无码区| 欧美一区=区| 久久综合久久八八| 国产亚洲精品精品精品| 97久久视频| 久久久av一区| 亚洲色图综合区| 欧美不卡视频| 欧美激情视频网站| 国产亚洲色婷婷久久99精品| 欧美激情性爽国产精品17p| 久久91亚洲精品中文字幕奶水| 久久久久久视频| 欧美性色综合| 欧美在线性视频| 99成人精品视频| 精品一区二区三区香蕉蜜桃| 666精品在线| 神马午夜在线观看| 久久久91精品国产一区二区三区| 水蜜桃亚洲一二三四在线| 成人在线观看免费| 亚洲日本在线a| 成人免费在线网| gogo亚洲高清大胆美女人体| 欧美日韩大陆在线| 一本色道久久亚洲综合精品蜜桃| 成人噜噜噜噜| 亚洲精品国产免费| 天天操天天摸天天舔| 国产精品99一区二区| 日本最新高清不卡中文字幕| 97人妻一区二区精品免费视频| 国产高清精品久久久久| 麻豆亚洲一区| 免费在线看黄| 黄色成人av在线| 天天爽天天爽夜夜爽| 国产精品**亚洲精品| 日韩欧美aaaaaa| 久久人妻一区二区| 欧美一区 二区| 亚洲人成伊人成综合网久久久| 99久久精品久久亚洲精品| 亚洲精品欧洲| 91在线网站视频| 欧美孕妇性xxxⅹ精品hd| 亚洲人成在线观看一区二区| 亚洲欧洲日产国码无码久久99| 欧美视频免费看| 日韩激情视频在线播放| 三级在线观看免费大全| 久久中文精品| 国产精品影院在线观看| 日本精品一区二区在线观看| 国产精品久久久久久久久果冻传媒| 97在线国产视频| 美女视频一区| 日韩精品中文字幕在线| 永久久久久久久| 日本成人在线视频网站| 久久av免费观看| 怡红院在线播放| 欧美中文字幕一区二区三区| www男人天堂| 99久久夜色精品国产亚洲狼| 情事1991在线| www日本高清| 国产精品日韩成人| 亚洲人精品午夜射精日韩| 蜜桃精品一区二区三区| 精品国产一区二区三区久久狼5月| 69成人免费视频| 成人国产精品视频| 国产一二三区在线播放| 欧美9999| 这里只有精品久久| 中文无码av一区二区三区| 9久草视频在线视频精品| 久久久国内精品| 日本精品国产| 久久精品福利视频| 亚洲性在线观看| 国产午夜亚洲精品不卡| 免费毛片网站在线观看| 欧美人与性动交xxⅹxx| 亚洲精品国产精品自产a区红杏吧 亚洲精品国产精品乱码不99按摩 亚洲精品国产精品久久清纯直播 亚洲精品国产精品国自产在线 | 国产精品久久久久久妇女6080| 欧美在线观看视频网站| 一区二区美女| 国产精品大陆在线观看| 午夜视频在线播放| 图片区小说区区亚洲影院| 国产精品99久久久精品无码| 亚洲欧洲中文字幕| 成人在线小视频| av大全在线免费看| 色综合色综合色综合色综合色综合| japanese在线观看| 一区二区日韩免费看| 国产精品v欧美精品v日韩| av女在线播放| 亚洲美女www午夜| 中文字幕69页| 中文字幕免费不卡| 在线免费黄色网| 欧美日韩三区| 久久精品女人的天堂av| 日韩大尺度黄色| 在线精品国产成人综合| www.国产com| 91香蕉视频mp4| 亚洲小视频在线播放| 日日夜夜亚洲精品| 欧美激情在线有限公司| 头脑特工队2免费完整版在线观看| 欧美性猛交xxxx免费看久久久| 亚洲精品午夜视频| 精品一二线国产| 99er在线视频| 免费成人结看片| 91久久久久久国产精品| 欧美xxxx黑人又粗又长| 亚洲美女视频网| 97人人爽人人爽人人爽| 亚洲永久免费av| 精品成人av一区二区三区| 免费在线观看一区二区三区| 日本xxxxx18| 日韩av网址大全| 国产在线观看91精品一区| 在线āv视频| 亚洲精品短视频| 国产高清中文字幕| 91老师片黄在线观看| 五月婷婷之婷婷| 亚洲黄色天堂| 致1999电视剧免费观看策驰影院| 成人三级毛片| 91精品久久久久| 欧美巨大丰满猛性社交| 日韩中文有码在线视频| 性xxxx视频播放免费| 欧美日韩久久久一区| 日本学生初尝黑人巨免费视频| 91色porny蝌蚪| 日批视频在线看| 日韩高清一区二区| 精品人妻大屁股白浆无码| 国产一级成人av| 国产精品亚洲激情| 福利成人导航| 一区二区三区日韩在线| 狠狠人妻久久久久久综合麻豆| 欧美日韩中文精品| 二区视频在线观看| 亚洲成a人v欧美综合天堂| 日韩激情小视频| 91美女片黄在线| 折磨小男生性器羞耻的故事| 久久精品国产亚洲高清剧情介绍 | 日韩精品 欧美| 成人中文在线| 精品午夜一区二区| 日本在线一区二区三区| 国产成人福利视频| 九色porny丨入口在线| 九九久久久久99精品| av影片免费在线观看| 亚洲欧洲在线视频| 天天操天天干天天| 精品国产精品网麻豆系列| 国产精品探花视频| 欧美欧美欧美欧美| 懂色av蜜臀av粉嫩av喷吹| 欧美日韩亚洲一区二区| 日韩黄色一级大片| 午夜久久久久久电影| 九九热视频精品| 亚洲欧美日韩中文字幕一区二区三区 | 日本在线xxx| 亚洲国产一区二区三区a毛片| 男女h黄动漫啪啪无遮挡软件| 久久人人88| 亚洲欧美日产图| 久久免费av| 日韩高清国产一区在线观看| 久久九九精品视频| 国产精品视频xxx| av资源在线播放| 午夜精品在线视频| 免费高潮视频95在线观看网站| 久久久久久久久国产精品| 美洲精品一卡2卡三卡4卡四卡| 欧美激情亚洲自拍| 久久久男人天堂| 日韩av观看网址| 国产美女久久| 91在线观看免费高清| 日韩激情欧美| 国产乱码一区| 欧美日韩导航| 欧美亚洲免费在线| 九九亚洲精品| 日本一区二区三区免费观看| 成人羞羞在线观看网站| 干日本少妇视频| 在线看片日韩| 日本新janpanese乱熟| 捆绑调教美女网站视频一区| 欧美国产日韩在线视频| 白白色亚洲国产精品| 男人网站在线观看| 久久精品无码一区二区三区| 少妇大叫太粗太大爽一区二区| 成人性色生活片免费看爆迷你毛片| 一卡二卡三卡四卡五卡| 99久久er热在这里只有精品66| 麻豆av免费观看| 国产精品久久久久久一区二区三区| 国产中文av在线| 午夜视频在线观看一区二区| 亚洲色成人www永久网站| 欧美一区二区三区啪啪| 五月天福利视频| 色偷偷综合社区| 金瓶狂野欧美性猛交xxxx| 日韩av黄色在线观看| 精品自拍视频| 成人两性免费视频| 久久99成人| 欧美一区观看| 国产韩日影视精品| 欧美大片免费播放| 久久这里有精品15一区二区三区| 国产精品久久久久久久99| 久久久另类综合| 久久久久久久极品内射| 91福利视频网站| 国产欧美日韩综合精品一区二区三区| 精品国产一区久久| 女人天堂在线| 色综合五月天导航| 天堂√中文最新版在线| 91精品综合视频| 精品在线手机视频| 国产一级不卡视频| 老鸭窝毛片一区二区三区| 激情图片中文字幕| 成人三级在线视频| 欧美黄色激情视频| 亚洲精品免费在线| 亚洲欧美综合自拍| 精品国产乱码久久久久久浪潮| 日韩在线资源| 国产精品久久久久久久久久免费 | 国产成人免费观看| 日韩欧美午夜| 日韩av在线第一页| 久久www免费人成看片高清| 90岁老太婆乱淫| 午夜电影网一区| 国精产品一品二品国精品69xx| 一区二区中文字幕| 直接在线观看的三级网址| 国产日韩欧美成人| 精品72久久久久中文字幕| 女人帮男人橹视频播放| 国产成人在线看| 国产三级国产精品国产国在线观看| 久久久久国色av免费观看性色| 性xxxxfjsxxxxx欧美| 国产精品免费久久久久久| 亚洲性视频大全| 哪个网站能看毛片| 93久久精品日日躁夜夜躁欧美| 精品亚洲永久免费| 日韩精品一区二区三区中文不卡 | 噜噜爱69成人精品| 91av在线免费| 亚洲亚洲人成综合网络| 国产美女www爽爽爽视频| 日韩专区在线观看| 成人在线日韩| 动漫美女被爆操久久久| 欧美区日韩区| 爱爱免费小视频| 欧美日韩亚洲国产综合| 成a人片在线观看| 国产精品日韩欧美一区二区三区| 91久久亚洲| 国产传媒国产传媒| 欧美一区二区在线免费播放| 欧美卡一卡二| 欧美午夜欧美| 国内成人精品2018免费看| 日本免费在线播放| 亚洲视频电影图片偷拍一区| 亚洲我射av| 青青草国产精品视频| 国产欧美日韩中文久久| 国产特黄一级片| 51色欧美片视频在线观看| 日韩精品一区二区三区免费观看 | 一区二区在线免费播放| 怡红院av亚洲一区二区三区h| 国产拍揄自揄精品视频麻豆| 99在线小视频| 日本一本a高清免费不卡| 2023国产精品久久久精品双| 艳妇乳肉豪妇荡乳xxx| 欧美在线不卡视频| av福利在线导航| 亚洲欧美日韩精品在线| jizz一区二区| 97精品久久人人爽人人爽| 97av在线视频| 在线一区免费| 香蕉视频久久久| 日韩欧美成人免费视频| 丝袜国产在线| 五月天丁香综合久久国产| 粉嫩13p一区二区三区| 中文永久免费观看| 欧日韩不卡在线视频| 欧美日韩精品免费观看视频完整|