亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > Java > 正文

Quartz+Spring Boot實現動態管理定時任務

2024-07-14 08:42:18
字體:
來源:轉載
供稿:網友

項目實踐過程中碰到一個動態管理定時任務的需求:針對每個人員進行信息的定時更新,具體更新時間可隨時調整、啟動、暫定等。

思路

將每個人員信息的定時配置保存到數據庫中,這樣實現了任務的動態展示和管理。任務的每一次新增或變更,都會去數據庫變更信息。

設置一個統一的任務管理器,專門負責動態任務的增刪改查。

POM依賴

<?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.example</groupId>  <artifactId>dynamic-quartz</artifactId>  <version>0.0.1-SNAPSHOT</version>  <packaging>jar</packaging>  <name>dynamic-quartz</name>  <description>動態定時任務管理</description>  <parent>    <groupId>org.springframework.boot</groupId>    <artifactId>spring-boot-starter-parent</artifactId>    <version>2.0.2.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</artifactId>    </dependency>    <dependency>      <groupId>org.springframework</groupId>      <artifactId>spring-context-support</artifactId>    </dependency>    <dependency>      <groupId>org.springframework.boot</groupId>      <artifactId>spring-boot-starter-test</artifactId>      <scope>test</scope>    </dependency>    <dependency>      <groupId>org.mybatis.spring.boot</groupId>      <artifactId>mybatis-spring-boot-starter</artifactId>      <version>1.1.1</version>    </dependency>    <!-- jdbc driver -->    <dependency>      <groupId>mysql</groupId>      <artifactId>mysql-connector-java</artifactId>      <version>5.1.44</version>    </dependency>    <dependency>      <groupId>org.quartz-scheduler</groupId>      <artifactId>quartz</artifactId>      <version>2.3.0</version>    </dependency>  </dependencies><build>  <plugins>    <plugin>      <groupId>org.springframework.boot</groupId>      <artifactId>spring-boot-maven-plugin</artifactId>    </plugin>  </plugins></build></project>application.ymlspring: datasource:  url: jdbc:mysql://localhost:3306/wujiwen  username: root  password: root  driver-class-name: com.mysql.jdbc.Driver profiles:   active: devlogback-spring.xml<configuration>  <jmxConfigurator />  <appender name="stdout" class="ch.qos.logback.core.ConsoleAppender">    <layout class="ch.qos.logback.classic.PatternLayout">      <pattern>%date [%thread] %-5level %logger{80} - %msg%n</pattern>    </layout>  </appender>  <logger name="org.springframework">    <level value="ERROR" />  </logger>  <logger name="org.mybatis">    <level value="ERROR" />  </logger>  <logger name="java.sql.Connection">    <level value="DEBUG" />  </logger>  <logger name="java.sql.Statement">    <level value="DEBUG" />  </logger>  <logger name="java.sql.PreparedStatement">    <level value="DEBUG" />  </logger>  <logger name="java.sql.ResultSet">    <level value="DEBUG"/>  </logger>  <logger name="org.apache.http">    <level value="INFO" />  </logger>  <logger name="org.quartz">    <level value="INFO" />  </logger>  <springProfile name="dev,test">    <root>      <level value="DEBUG" />      <appender-ref ref="stdout" />    </root>  </springProfile></configuration>CronEntity.java保存在數據庫中的表達式管理器.package com.example.dynamicquartz.bean;import java.io.Serializable;import java.util.Date;/** * created with IntelliJ IDEA. * packageName : com.example.dynamicquartz.bean * author    : wujw * date     : 2018/9/9 16:23 * version   : 1.0.0 * description : TODO */public class CronEntity implements Serializable {  private static final long serialVersionUID = -3406421161273529348L;  private String id;  private String userId; //用戶標識  private String cron; //表達式  private String quarzName; //任務名稱  private String schedulerClass;//定時任務類  private Date time;  public String getId() {    return id;  }  public void setId(String id) {    this.id = id;  }  public String getUserId() {    return userId;  }  public void setUserId(String userId) {    this.userId = userId;  }  public String getCron() {    return cron;  }  public void setCron(String cron) {    this.cron = cron;  }  public String getQuarzName() {    return quarzName;  }  public void setQuarzName(String quarzName) {    this.quarzName = quarzName;  }  public String getSchedulerClass() {    return schedulerClass;  }  public void setSchedulerClass(String schedulerClass) {    this.schedulerClass = schedulerClass;  }  public Date getTime() {    return time;  }  public void setTime(Date time) {    this.time = time;  }  @Override  public String toString() {    return "CronEntity{" +        "id='" + id + '/'' +        ", userId='" + userId + '/'' +        ", cron='" + cron + '/'' +        ", quarzName='" + quarzName + '/'' +        ", schedulerClass='" + schedulerClass + '/'' +        ", time=" + time +        '}';  }}CronMapperpackage com.example.dynamicquartz.dao;import com.example.dynamicquartz.bean.CronEntity;import org.apache.ibatis.annotations.*;import java.util.List;/** * created with IntelliJ IDEA. * packageName : com.example.dynamicquartz * author    : wujw * date     : 2018/9/9 20:14 * version   : 1.0.0 * description : TODO */@Mapperpublic interface CronMapper{  @Select("select * from cron_table where id = #{id}")  @Results({      @Result(property = "id", column = "id"),      @Result(property = "userId", column = "user_id"),      @Result(property = "cron", column = "cron"),      @Result(property = "quarzName", column = "quarz_name"),      @Result(property = "schedulerClass", column = "scheduler_class"),      @Result(property = "time", column = "time")  })  CronEntity load(String id);  @Insert("insert into cron_table(id,userId,cron,quartzName,schedulerClass,time)" +      "values(#{id},#{user_id},#{cron},#{quartz_name},#{scheduler_class},#   {time})")  void insert(CronEntity cronEntity);  @Select("select * from cron_table")  @Results({      @Result(property = "id", column = "id"),      @Result(property = "userId", column = "user_id"),      @Result(property = "cron", column = "cron"),      @Result(property = "quarzName", column = "quarz_name"),      @Result(property = "schedulerClass", column = "scheduler_class"),      @Result(property = "time", column = "time")  })  List<CronEntity> queryAll();  @Update("update cron_table set cron=#{1} where id =#{0}")  void updateCron(String id,String cron);}ICronServicepackage com.example.dynamicquartz.serivce;import com.example.dynamicquartz.bean.CronEntity;import java.util.List;/** * created with IntelliJ IDEA. * packageName : com.example.dynamicquartz * author    : wujw * date     : 2018/9/9 19:54 * version   : 1.0.0 * description : TODO */public interface ICronService{  void sendEmail(String quartzName);  void sendSms(String quartzName);  CronEntity findByCronId(String id );  void update(CronEntity cronEntity);  List<CronEntity> findAll();}CronServiceImplpackage com.example.dynamicquartz.serivce;import com.example.dynamicquartz.bean.CronEntity;import com.example.dynamicquartz.dao.CronMapper;import org.springframework.beans.factory.annotation.Autowired;import org.springframework.stereotype.Service;import java.util.List;/** * created with IntelliJ IDEA. * packageName : com.example.dynamicquartz.serivce * author    : wujw * date     : 2018/9/9 19:55 * version   : 1.0.0 * description : TODO */@Servicepublic class CronServiceImpl implements ICronService{  @Autowired  private CronMapper cronMapper;  @Override  public void sendEmail(String quartzName) {    System.out.println(quartzName +" 正在發送郵件");  }  @Override  public void sendSms(String quartzName) {    System.out.println(quartzName +"正在發送短信");  }  @Override  public CronEntity findByCronId(String id) {    return this.cronMapper.load(id);  }  @Override  public void update(CronEntity cronEntity) {    this.cronMapper.insert(cronEntity);  }  @Override  public List<CronEntity> findAll() {    return this.cronMapper.queryAll();  }}QuartzManagerpackage com.example.dynamicquartz.serivce;import com.example.dynamicquartz.bean.CronEntity;import org.quartz.*;import org.springframework.beans.factory.annotation.Autowired;import org.springframework.context.annotation.Configuration;import java.util.Date;/** * created with IntelliJ IDEA. * packageName : com.example.dynamicquartz * author    : wujw * date     : 2018/9/9 19:31 * version   : 1.0.0 * description : TODO */@Configurationpublic class QuartzManager {  @Autowired  private Scheduler scheduler;  @Autowired  private ICronService iCronService;  public void start(String id) throws SchedulerException {    CronEntity cronEntity = iCronService.findByCronId(id);    if(cronEntity!= null){  startJob(scheduler,cronEntity.getQuarzName(),cronEntity.getCron(),cronEntity.getSchedulerClass());    }  }  private void startJob(Scheduler scheduler,String name,String cron,String className) throws SchedulerException {    // 通過JobBuilder構建JobDetail實例,JobDetail規定只能是實現Job接口的實例    // JobDetail 是具體Job實例    Class<Job> jobClass = null;    try {      //實例化具體的Job任務      jobClass = (Class<Job>) Class.forName(className);    } catch (ClassNotFoundException e) {      e.printStackTrace();    }    JobDetail jobDetail = JobBuilder.newJob(jobClass).withIdentity(name, "group1").build();    // 基于表達式構建觸發器    CronScheduleBuilder cronScheduleBuilder = CronScheduleBuilder.cronSchedule(cron);    // CronTrigger表達式觸發器 繼承于Trigger    // TriggerBuilder 用于構建觸發器實例    CronTrigger cronTrigger = TriggerBuilder.newTrigger().withIdentity(name, "group1")        .withSchedule(cronScheduleBuilder).build();    scheduler.scheduleJob(jobDetail, cronTrigger);  }  /**   * 獲取Job信息   *   * @param name   * @param group   * @return   * @throws SchedulerException   */  public String getJobInfo(String name, String group) throws SchedulerException {    TriggerKey triggerKey = new TriggerKey(name, group);    CronTrigger cronTrigger = (CronTrigger) scheduler.getTrigger(triggerKey);    return String.format("time:%s,state:%s", cronTrigger.getCronExpression(),        scheduler.getTriggerState(triggerKey).name());  }  /**   * 修改某個任務的執行時間   *   * @param name   * @param group   * @param time   * @return   * @throws SchedulerException   */  public boolean modifyJob(String name, String group, String time) throws SchedulerException {    Date date = null;    TriggerKey triggerKey = new TriggerKey(name, group);    CronTrigger cronTrigger = (CronTrigger) scheduler.getTrigger(triggerKey);    String oldTime = cronTrigger.getCronExpression();    if (!oldTime.equalsIgnoreCase(time)) {      CronScheduleBuilder cronScheduleBuilder = CronScheduleBuilder.cronSchedule(time);      CronTrigger trigger = TriggerBuilder.newTrigger().withIdentity(name, group)          .withSchedule(cronScheduleBuilder).build();      date = scheduler.rescheduleJob(triggerKey, trigger);    }    return date != null;  }  /**   * 暫停所有任務   *   * @throws SchedulerException   */  public void pauseAllJob() throws SchedulerException {    scheduler.pauseAll();  }  /**   * 暫停某個任務   *   * @param name   * @param group   * @throws SchedulerException   */  public void pauseJob(String name, String group) throws SchedulerException {    JobKey jobKey = new JobKey(name, group);    JobDetail jobDetail = scheduler.getJobDetail(jobKey);    if (jobDetail == null)      return;    scheduler.pauseJob(jobKey);  }  /**   * 恢復所有任務   *   * @throws SchedulerException   */  public void resumeAllJob() throws SchedulerException {    scheduler.resumeAll();  }  /**   * 恢復某個任務   *   * @param name   * @param group   * @throws SchedulerException   */  public void resumeJob(String name, String group) throws SchedulerException {    JobKey jobKey = new JobKey(name, group);    JobDetail jobDetail = scheduler.getJobDetail(jobKey);    if (jobDetail == null)      return;    scheduler.resumeJob(jobKey);  }  /**   * 刪除某個任務   *   * @param name   * @param group   * @throws SchedulerException   */  public void deleteJob(String name, String group) throws SchedulerException {    JobKey jobKey = new JobKey(name, group);    JobDetail jobDetail = scheduler.getJobDetail(jobKey);    if (jobDetail == null)      return;    scheduler.deleteJob(jobKey);  }}創建兩個Task類,分別執行不同的任務public class EmailTask implements Job {  private Logger logger = LoggerFactory.getLogger(EmailTask.class);  @Autowired  private ICronService iCronService;  @Override  public void execute(JobExecutionContext jobExecutionContext) throws JobExecutionException {    logger.info("EmailTask task start execute.");    //模擬任務執行    iCronService.sendEmail(jobExecutionContext.getJobDetail().getKey().getName());  }}public class SmsTask implements Job {  private Logger logger = LoggerFactory.getLogger(SmsTask.class);  @Autowired  private ICronService iCronService;  @Override  public void execute(JobExecutionContext jobExecutionContext) throws JobExecutionException {    logger.info("SmsTask task start execute.");    //模擬任務執行    iCronService.sendSms(jobExecutionContext.getJobDetail().getKey().getName());  }}SchedulerController@RestController@RequestMapping("/scheduler")public class SchedulerController{  @Autowired  QuartzManager quartzManager;  @RequestMapping(value = "/start", method = RequestMethod.GET)   @ResponseBody  public String start(@RequestParam(name = "id", defaultValue = "") String id) {    try {      quartzManager.start(id);    } catch (SchedulerException e) {      e.printStackTrace();    }    return "啟動成功";  }}cron_table.sqlCREATE TABLE `cron_table` ( `id` varchar(11) collate utf8_bin NOT NULL, `user_id` varchar(11) collate utf8_bin default NULL, `cron` varchar(255) collate utf8_bin default NULL, `quarz_name` varchar(255) collate utf8_bin default NULL, `scheduler_class` varchar(255) collate utf8_bin default NULL, `time` datetime default NULL, PRIMARY KEY (`id`)) ENGINE=MyISAM DEFAULT CHARSET=utf8 COLLATE=utf8_bin;-- ------------------------------ Records of cron_table-- ----------------------------INSERT INTO `cron_table` VALUES ('1', 'AAA', '0/5 * * * * ?', '用戶AAA', 'com.example.dynamicquartz.job.SmsTask', '2018-09-06 20:26:55');INSERT INTO `cron_table` VALUES ('2', 'BBB', '0/2 * * * * ?', '用戶BBB', 'com.example.dynamicquartz.job.EmailTask', '2018-09-09 21:02:08');測試結果http://localhost:8080/scheduler/start?id=1http://localhost:8080/scheduler/start?id=22018-09-09 21:05:08,386 [http-nio-8080-exec-2] DEBUG com.example.dynamicquartz.dao.CronMapper.load - ==> Preparing: select * from cron_table where id = ? 2018-09-09 21:05:08,408 [http-nio-8080-exec-2] DEBUG com.example.dynamicquartz.dao.CronMapper.load - ==> Parameters: 1(String)2018-09-09 21:05:08,427 [http-nio-8080-exec-2] DEBUG com.example.dynamicquartz.dao.CronMapper.load - <==   Total: 12018-09-09 21:05:10,036 [quartzScheduler_Worker-1] INFO com.example.dynamicquartz.job.SmsTask - SmsTask task start execute.用戶AAA正在發送短信2018-09-09 21:05:11,581 [http-nio-8080-exec-1] DEBUG com.example.dynamicquartz.dao.CronMapper.load - ==> Preparing: select * from cron_table where id = ? 2018-09-09 21:05:11,582 [http-nio-8080-exec-1] DEBUG com.example.dynamicquartz.dao.CronMapper.load - ==> Parameters: 2(String)2018-09-09 21:05:11,584 [http-nio-8080-exec-1] DEBUG com.example.dynamicquartz.dao.CronMapper.load - <==   Total: 12018-09-09 21:05:12,013 [quartzScheduler_Worker-2] INFO com.example.dynamicquartz.job.EmailTask - EmailTask task start execute.用戶BBB 正在發送郵件2018-09-09 21:05:14,002 [quartzScheduler_Worker-3] INFO com.example.dynamicquartz.job.EmailTask - EmailTask task start execute.用戶BBB 正在發送郵件2018-09-09 21:05:15,001 [quartzScheduler_Worker-4] INFO com.example.dynamicquartz.job.SmsTask - SmsTask task start execute.用戶AAA正在發送短信2018-09-09 21:05:16,001 [quartzScheduler_Worker-5] INFO com.example.dynamicquartz.job.EmailTask - EmailTask task start execute.用戶BBB 正在發送郵件2018-09-09 21:05:18,001 [quartzScheduler_Worker-6] INFO com.example.dynamicquartz.job.EmailTask - EmailTask task start execute.用戶BBB 正在發送郵件2018-09-09 21:05:20,000 [quartzScheduler_Worker-7] INFO com.example.dynamicquartz.job.SmsTask - SmsTask task start execute.用戶AAA正在發送短信2018-09-09 21:05:20,001 [quartzScheduler_Worker-8] INFO com.example.dynamicquartz.job.EmailTask - EmailTask task start execute.用戶BBB 正在發送郵件2018-09-09 21:05:22,001 [quartzScheduler_Worker-9] INFO com.example.dynamicquartz.job.EmailTask - EmailTask task start execute.用戶BBB 正在發送郵件2018-09-09 21:05:24,000 [quartzScheduler_Worker-10] INFO com.example.dynamicquartz.job.EmailTask - EmailTask task start execute.用戶BBB 正在發送郵件2018-09-09 21:05:25,001 [quartzScheduler_Worker-1] INFO com.example.dynamicquartz.job.SmsTask - SmsTask task start execute.用戶AAA正在發送短信2018-09-09 21:05:26,000 [quartzScheduler_Worker-2] INFO com.example.dynamicquartz.job.EmailTask - EmailTask task start execute.用戶BBB 正在發送郵件2018-09-09 21:05:28,001 [quartzScheduler_Worker-3] INFO com.example.dynamicquartz.job.EmailTask - EmailTask task start execute.

可以看出,AAA的間隔時間時5s,BBB的間隔時間時2s.

到這里我們的測試已經一本完成了,接下來就是針對任務的更新,停止和啟動了,只需要調用 QuartzManager 對應的方法即可,必要時更新一下數據庫就好啦。

總結

以上所述是小編給大家介紹的Quartz+Spring Boot實現動態管理定時任務,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對VeVb武林網網站的支持!


注:相關教程知識閱讀請移步到JAVA教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲一区二区三区视频| 欧美激情综合色综合啪啪五月| 91精品久久久久久久久青青| 97欧美精品一区二区三区| 国产精品欧美风情| 国产精品无码专区在线观看| 欧美中文字幕在线播放| 最近中文字幕mv在线一区二区三区四区| 亚洲精品日韩久久久| 色与欲影视天天看综合网| xx视频.9999.com| 日韩美女在线看| 久久影视电视剧免费网站| 日本乱人伦a精品| 成人免费视频a| 欧美成人激情图片网| 国产精品一区二区在线| 欧美大学生性色视频| 中文字幕日韩在线观看| 久久91精品国产| 国产亚洲精品久久久优势| 国产一区二区三区视频在线观看| 日韩成人激情视频| 欧美制服第一页| 日本91av在线播放| 91免费国产网站| 国产一区二区香蕉| 欧美夫妻性生活xx| 久久久www成人免费精品张筱雨| 欧美亚洲在线视频| 亚洲四色影视在线观看| 久久99国产综合精品女同| 亚洲电影免费观看高清| 亚洲电影免费观看高清| 欧美人与性动交| 欧美一区二区三区精品电影| 97视频在线观看视频免费视频| 亚洲综合在线小说| 久久久精品欧美| 欧美激情喷水视频| 国产精品亚洲激情| 国产日韩欧美在线观看| 欧美日韩亚洲一区二区| 美女精品视频一区| 成人国内精品久久久久一区| 精品视频久久久久久久| 久久久久久成人精品| 久久久久久成人精品| 亚洲一区二区中文| 性日韩欧美在线视频| 91在线视频精品| 中日韩美女免费视频网站在线观看| 欧美巨大黑人极品精男| 久久国产精品首页| 亚洲天堂视频在线观看| 亚洲欧美制服丝袜| 日韩成人中文字幕| 国产精品自产拍高潮在线观看| 亚洲最大成人网色| 亚洲欧美日韩中文视频| 欧美成人午夜视频| 日韩精品极品视频| 午夜精品一区二区三区在线| 久久精品久久久久| 欧美二区乱c黑人| 精品国产依人香蕉在线精品| 欧美一级淫片播放口| 久久综合国产精品台湾中文娱乐网| 国产精品人成电影| 亚洲二区中文字幕| 国产精品自产拍高潮在线观看| 亚洲精品一区在线观看香蕉| 永久555www成人免费| 亚洲国产97在线精品一区| 亚洲精品理论电影| 国产一区二区在线免费视频| 国产精品中文字幕在线观看| 日韩精品在线免费播放| 日韩欧美亚洲一二三区| 91在线观看免费| 国产精品久久久久一区二区| 精品久久中文字幕久久av| 夜夜狂射影院欧美极品| 亚洲视频自拍偷拍| 亚洲天堂免费视频| 亚洲视频在线看| 91热精品视频| 九九久久国产精品| 92看片淫黄大片欧美看国产片| 91系列在线观看| 欧美激情性做爰免费视频| 亚洲电影免费观看高清完整版| 国产欧美一区二区三区四区| 国产91精品久久久久| 欧美在线视频一区二区| 麻豆一区二区在线观看| 欧美日韩国产999| 韩国三级日本三级少妇99| 国产精品视频不卡| www.久久草.com| 色偷偷噜噜噜亚洲男人的天堂| 日韩中文字幕在线| 国产精品爱久久久久久久| 国产精品视频永久免费播放| 国产一区二区三区在线视频| 在线视频日韩精品| 欧美丰满少妇xxxxx做受| 中文综合在线观看| 久久精品中文字幕免费mv| 亚洲国产另类久久精品| 久久九九有精品国产23| 亚洲国产日韩欧美在线图片| 九九久久精品一区| 日韩av电影在线免费播放| 国产精品扒开腿做爽爽爽男男| 美女撒尿一区二区三区| 97久久久久久| 欧美高清自拍一区| 精品亚洲一区二区三区| 亚洲综合日韩中文字幕v在线| 欧美电影第一页| 欧美大片欧美激情性色a∨久久| 成人羞羞国产免费| 欧美人与性动交| 日韩网站在线观看| 最近2019中文字幕在线高清| 2019中文字幕免费视频| 欧美精品第一页在线播放| 91精品久久久久久久久久久久久久| 亚洲精品福利视频| 日韩中文字幕国产精品| 日韩电影视频免费| 日韩av在线播放资源| 久久亚洲电影天堂| 日韩a**站在线观看| 日本老师69xxx| 91日韩在线视频| 亚洲国产欧美一区二区丝袜黑人| 亚洲欧美999| 国产精品福利观看| 久久综合久久88| 青草青草久热精品视频在线网站| 国产精品69av| 亚洲石原莉奈一区二区在线观看| 日韩av在线精品| 精品中文字幕视频| 日韩av日韩在线观看| 成人免费观看a| 欧美亚洲国产视频| 日韩精品在线免费观看视频| 亚洲视频一区二区三区| 日韩在线观看视频免费| 亚洲第一偷拍网| 久久久999成人| 欧美大全免费观看电视剧大泉洋| 国产精品第一视频| 欧美国产亚洲精品久久久8v| 91精品久久久久久久久| 成人黄色免费在线观看| 5566日本婷婷色中文字幕97| 久久久久久久久久久久av| 91久久精品日日躁夜夜躁国产| 91国偷自产一区二区三区的观看方式| 亚洲精品一区中文|