• <tr id="yyy80"></tr>
  • <sup id="yyy80"></sup>
  • <tfoot id="yyy80"><noscript id="yyy80"></noscript></tfoot>
  • 99热精品在线国产_美女午夜性视频免费_国产精品国产高清国产av_av欧美777_自拍偷自拍亚洲精品老妇_亚洲熟女精品中文字幕_www日本黄色视频网_国产精品野战在线观看 ?

    基于activiti多實例任務(wù)回退方案的研究與實現(xiàn)

    2018-11-01 03:04張超王萌任女爾
    電腦知識與技術(shù) 2018年19期
    關(guān)鍵詞:工作流

    張超 王萌 任女爾

    摘要:近年來,工作流技術(shù)日益成熟,會簽在流程系統(tǒng)中的出現(xiàn)也越來越頻繁。各大流程引擎也對會簽做了默認(rèn)支持。Activiti作為現(xiàn)今十分流行的開源流程引擎,通過多實例任務(wù)節(jié)點也對會簽做了支持,但是對多實例的回退卻沒做支持。為解決上述問題,該文通過Activiti提供的服務(wù)接口,并結(jié)合一定的算法,實現(xiàn)多實例任務(wù)的回退。

    關(guān)鍵詞:工作流;Activiti;多實例;回退

    中圖分類號:TP311 文獻標(biāo)識碼:A 文章編號:1009-3044(2018)19-0113-03

    伴隨著信息化技術(shù)的高速發(fā)展,企業(yè)信息化也得以逐漸深入,普通的辦公自動化系統(tǒng)已經(jīng)無法滿足日漸增多的企業(yè)流程需求。會簽作為工作流程中的一種常見的場景,可以讓多個人相互協(xié)同,共同完成某一個任務(wù),因而在流程的信息傳遞上更加自動化,在流程的信息處理上更加高效,在任務(wù)的完成上更加直觀。所以會簽使用的時間成本更低,安全性、封閉性更高,相應(yīng)的,效率也就更高。

    Activiti通過使用多實例任務(wù)節(jié)點,在業(yè)務(wù)流程中定義重復(fù)環(huán)節(jié),從而實現(xiàn)對會簽的支持。多實例任務(wù)節(jié)點通過給定的集合,對集合中的每一個元素執(zhí)行一次任務(wù),既可以順序同步執(zhí)行,也可以并發(fā)同時執(zhí)行這些任務(wù)。然后通過設(shè)置完成多實例任務(wù)的條件,決定會簽的后續(xù)走向。但是對于某些業(yè)務(wù)場景,多實例任務(wù)節(jié)點并不能滿足需求。比如:會簽中的某個參與者發(fā)現(xiàn)自己沒有參與會簽的資格,造成該現(xiàn)象的原因可能是在選擇會簽人員時的疏忽。

    針對該業(yè)務(wù)場景,本文對Activiti的多實例任務(wù)進行了擴展和延伸,使得會簽任務(wù)中的某一個子任務(wù)得以有修正的機會,從而降低出錯率,避免整個會簽任務(wù)的失敗。

    1 技術(shù)簡介

    1.1 Workflow

    1993年工作流管理聯(lián)盟(Workflow Management Coalition,WfMC)成立,作為工作流管理的標(biāo)準(zhǔn)化組織,對工作流給出了定義:工作流是指一類能夠完全自動執(zhí)行的經(jīng)營過程,根據(jù)一系列過程規(guī)則,將文檔、信息或任務(wù)在不同的執(zhí)行者之間進行傳遞與執(zhí)行。通俗點將,工作流是將一組任務(wù)以及任務(wù)相關(guān)的人組織起來以共同完成某一個業(yè)務(wù)過程。它定義了任務(wù)的順序以及后續(xù)任務(wù)的出發(fā)條件,每個任務(wù)可以由一個人來完成,也可以由多個人協(xié)同完成。

    工作流引擎指的是Workflow應(yīng)該作為應(yīng)用系統(tǒng)的一部分,并為之提供解決方案,這些方案包括:根據(jù)分工和條件的不同以及角色來決定信息傳遞路由、內(nèi)容等級等核心解決方案。工作流引擎包含了流程圖的繪制、流程節(jié)點的管理、流程流向的控制以及流程實例的管理等。目前市面上常見的流程引擎主要包含:JBPM、Activiti、SWF等。

    1.2 Activiti

    Activiti項目是一個開源的BPM平臺,提供了對BPMN2.0標(biāo)準(zhǔn)的支持。Activiti是一種BPM引擎,它輕量,并且可嵌入。為了可以被廣泛使用,Activiti提供了寬松的Apache許可2.0。同時,為了促進和BPMN2.0標(biāo)準(zhǔn)的匹配,該項目由OMG通過標(biāo)準(zhǔn)審定。

    Activiti項目的創(chuàng)始人之一Tom Baeyens,原先是JBoss jBPM的項目架構(gòu)師,因此,Activiti是基于JBPM4開發(fā)的,同時支持流程虛擬機技術(shù),并且對外提供了清洗的服務(wù)接口,可以很好地集成外部服務(wù)。關(guān)于Activiti的優(yōu)勢,Tom Baeyens曾說:“Activiti有非常大的影響力來改變目前BPM的生態(tài)。Activiti的Apache授權(quán),完整的功能,將使Activiti到達一個新的水平。Activiti將推動業(yè)界的創(chuàng)新,因為BPM技術(shù)可以廣泛而自由地被應(yīng)用。通過實現(xiàn)這些想法以及開源社區(qū)的努力,也讓Activiti成為事實上的 BPM和BPMN標(biāo)準(zhǔn)執(zhí)行”。SpringSource的首席技術(shù)官Adrian Coyler也說道:“這是一個對Spring開發(fā)人員和Java社區(qū)總體的發(fā)展非常令人興奮的事情,長期以來一直需要一個Apache許可的流程引擎,這對許多應(yīng)用系統(tǒng)非常實用的需求。我們認(rèn)為,Activiti作為新的應(yīng)用領(lǐng)域擴展到的Java和開源的發(fā)展,特別是在云架構(gòu)上”。

    2 系統(tǒng)架構(gòu)

    本課題涉及項目的軟件技術(shù)架構(gòu)使用JAVA語言,采用B/S架構(gòu),綜合SpringBoot、Hibernate、Shiro等框架進行業(yè)務(wù)邏輯開發(fā),采用Activiti工作流引擎處理業(yè)務(wù)流程,頁面則采用Html、Bootstrap、Ajax開發(fā)。整體系統(tǒng)架構(gòu)如下所示:

    本系統(tǒng)底層操作系統(tǒng)支持Windows、linux、Solaris等操作系統(tǒng),數(shù)據(jù)庫采用Oracle;在此基礎(chǔ)之上,通過JDBC與數(shù)據(jù)庫交互,通過XML和properties文件進行緩存、日志等的配置;上層數(shù)據(jù)層采用Hibernate和Spring提供的方法設(shè)計數(shù)據(jù)庫相關(guān)操作;業(yè)務(wù)層在數(shù)據(jù)庫操作的基礎(chǔ)之上對業(yè)務(wù)邏輯進行處理;控制層通過SpringMVC使得業(yè)務(wù)邏輯與前端UI系統(tǒng)進行交互,前端UI系統(tǒng)由html和jQuery, bootstrap,進行表現(xiàn)層的展示。系統(tǒng)嚴(yán)格按照MVC架構(gòu)模式進行設(shè)計和開發(fā),如下圖所示:

    2.1 多實例任務(wù)回退的設(shè)計與實現(xiàn)

    2.1.1 設(shè)計思想

    多實例任務(wù)回退的設(shè)計思想是當(dāng)多實例任務(wù)中的某個子任務(wù)要回退時,首先將該任務(wù)的處理人置空,這樣要回退的任務(wù)就不會出現(xiàn)在待辦列表里,也就不會被某個人完成,流程就會停留在多實例節(jié)點處,再通過利用Activiti提供的服務(wù)接口TaskService中的兩個方法:TaskService.newTask()和TaskService.saveTask()來創(chuàng)建回退的任務(wù)并保存到數(shù)據(jù)庫,由于創(chuàng)建的新任務(wù)不能關(guān)聯(lián)到某個具體的流程,所以這里采用一種折中的辦法:在任務(wù)的本地變量里設(shè)置相關(guān)的信息,同時添加兩個變量:MULTI_INSTANCE_ROLLBACK_和INSTANCE_ROLLBACK_ID_,分別表示新任務(wù)是一個多實例的回退任務(wù)以及原始任務(wù)ID,這樣,新任務(wù)就和原始任務(wù)有了關(guān)聯(lián),完成任務(wù)時,就可以重新指定子任務(wù)的處理人了。

    2.1.2 具體實現(xiàn)過程及相關(guān)代碼

    1) 流程設(shè)計圖

    在IDEA開發(fā)工具中,使用流程繪制插件按照BPMN2.0規(guī)范繪制流程圖,流程圖中包含一個多實例任務(wù)節(jié)點,流程文件部分代碼如下:

    2) 將設(shè)計好的流程部署,因為使用的springboot,將流程定義文件放置到src/main/resources/processes目錄下,項目啟動時會自動部署。

    3) 部署后就可以使用流程了。首先要發(fā)起一個流程實例,并設(shè)置流程發(fā)起人,代碼如下:

    ProcessInstance processInstance = null;

    try {

    identityService.setAuthenticatedUserId("user1");

    processInstance = runtimeService.startProcessInstanceByKey("MyMultiInstanceRollbackProcess");

    }finally {

    identityService.setAuthenticatedUserId(null);

    }

    發(fā)起流程后,就可以獲取相應(yīng)的待辦,并完成任務(wù)。首先,我們獲取用戶user1的待辦任務(wù),并完成,在完成的時候指定下一個多實例任務(wù)的集合,代碼如下:

    Task user1Task = taskService.createTaskQuery().taskAssignee("user1").singleResult();

    Map variables = new HashMap<>();

    String[] assignees = {"user21","user22","user23"};

    variables.put("assigneeCollection",Arrays.asList(assignees));

    taskService.complete(user1Task.getId(),variables);

    4) 簽收并完成任務(wù)。先讓use22和user23完成任務(wù),代碼如下:

    Task user22Task = taskService.createTaskQuery().taskAssignee("user22").singleResult();

    taskService.complete(user22Task.getId());

    Task user23Task = taskService.createTaskQuery().taskAssignee("user23").singleResult();

    taskService.complete(user23Task.getId());

    5) 回退多實例任務(wù)。user21查看到待辦任務(wù)后,發(fā)現(xiàn)該任務(wù)不應(yīng)該是自己處理的,于是回退給user1,代碼如下:

    Task user21Task = taskService.createTaskQuery().taskAssignee("user21").singleResult();

    taskService.setAssignee(user21Task.getId(),null);

    Task rollbackTask = taskService.newTask();

    rollbackTask.setAssignee("user1");

    Map rollbackTaskVariablesLocal = new HashMap<>();

    rollbackTaskVariablesLocal.put("MULTI_INSTANCE_ROLLBACK_",true);

    rollbackTaskVariablesLocal.put("INSTANCE_ROLLBACK_ID_",user21Task.getId());

    taskService.saveTask(rollbackTask);

    taskService.setVariablesLocal(rollbackTask.getId(),rollbackTaskVariablesLocal);

    6) user1重新分配任務(wù)

    user1Task = taskService.createTaskQuery().taskAssignee("user1").singleResult();

    Map user1TaskVariablesLocal = taskService.getVariablesLocal(user1Task.getId());

    if(user1TaskVariablesLocal.containsKey("MULTI_INSTANCE_ROLLBACK_")){

    boolean isRollbackTask = (boolean)user1TaskVariablesLocal.get("MULTI_INSTANCE_ROLLBACK_");

    if(isRollbackTask){

    String originalTaskId = (String)user1TaskVariablesLocal.get("INSTANCE_ROLLBACK_ID_");

    if(StringUtils.isEmpty(originalTaskId)){

    throw new Exception("the multi instance rollback task has no original task");}

    taskService.setAssignee(originalTaskId,"user24"); }}

    7) 新分配的用戶查看待辦并完成任務(wù),代碼如下:

    Task user24Task = taskService.createTaskQuery().taskAssignee("user24").singleResult();

    taskService.complete(originalTaskId);

    historyService.deleteHistoricTaskInstance(originalTaskId);

    8) 會簽任務(wù)結(jié)束,流程繼續(xù)

    3 結(jié)論

    本文利用Activiti技術(shù)并結(jié)合一定的算法實現(xiàn)了多實例會簽任務(wù)的回退,為多實例任務(wù)分發(fā)錯誤的情況提供了解決方案。這個方案通過使用Activiti自身提供的API,并結(jié)合任務(wù)的本地變量,從而擴展了Activiti的多實例任務(wù),讓分發(fā)錯誤的子實例得以修正,同時還不影響其他正確的子實例。但是由于時間、精力、知識水平的制約,本設(shè)計也有需要提高的地方,例如由于使用了變量,導(dǎo)致變量表的快速增加,對查詢性能存在影響。后續(xù)可以考慮將這些變量的內(nèi)容單獨存在一張表中。

    參考文獻:

    [1] 范玉順.工作流管理技術(shù)基礎(chǔ)[M].北京:清華大學(xué)出版社,2001.

    [2] 閆洪磊.Activiti實戰(zhàn)[M].北京:機械工業(yè)出版社,2014.

    [3] 顧大明.基于JBPM的工作流會簽設(shè)計[J].民營科技,2010(12).

    [4] 羅海濱,范玉順,吳澄.工作流技術(shù)綜述[J].軟件學(xué)報,2000,11(7):899-907.

    [5] 梅峰,于洋,衛(wèi)青延,等.基于開源工作流 Activiti的企業(yè)協(xié)同信息平臺研究[J].福建電腦,2012(11):125-127.

    [6] 張利君,馬駿,楊濤,等.基于工作流的動態(tài)任務(wù)調(diào)度研究與實現(xiàn)[J].計算機工程與設(shè)計,2009(10):2533-2537.

    [7] 王安慧,孫長銀.管理信息系統(tǒng)會簽管理模塊的設(shè)計與應(yīng)用[J].三峽大學(xué)學(xué)報,2001,23(5):454-457.

    [8] 馮天佑,梁立宇,李成華,等.基于Activiti工作流引擎技術(shù)的電力行業(yè)業(yè)務(wù)流程管理系統(tǒng)[J].信息通信,2013(8):57-59.

    [9] Chen W.Enterprise information management system basedon J2EE and MVC mode[C]//Proceedings of the 9th In-ternational Symposium on Linear Drives for Industry Appli-cations.2014,3:427-433.

    [10] 薛華成.管理信息系統(tǒng)[M].北京:清華大學(xué)出版社,1993.

    [11] WFMC-TC-1025,工作流過程定義接口———XML 過程定義語言[S].

    [12] 阿斯特.作流管理:模型、方法和系統(tǒng)[M].王建民,譯.北京:清華大學(xué)出版社,2004.

    [13] 葉小路,錢真坤.基于 Activiti5 的水司OA系統(tǒng)設(shè)計與實現(xiàn)[J].軟件導(dǎo)刊,2013,12(6):93-95.

    [14] Alexander Grosskopf,Gero Decker,Mathias Weske. The Process Business Process Modeling Using BPMN[M].Meghan-Kiffer Press,2009.

    猜你喜歡
    工作流
    支持節(jié)點協(xié)同的工作流模型構(gòu)建方法研究
    基于工作流2.0的智慧教室設(shè)計與研究
    工作流在電力生產(chǎn)管理信息系統(tǒng)中的設(shè)計和應(yīng)用
    基于J2EE的電子政務(wù)系統(tǒng)研究與應(yīng)用
    基于J2EE的電子政務(wù)系統(tǒng)研究與應(yīng)用
    中文字幕精品免费在线观看视频| 国产私拍福利视频在线观看| 欧美日本中文国产一区发布| 久久精品91蜜桃| 国产精品一区二区免费欧美| 99久久国产精品久久久| 99在线人妻在线中文字幕| 香蕉久久夜色| 国产精品久久久久久亚洲av鲁大| 美国免费a级毛片| 国产aⅴ精品一区二区三区波| 成人亚洲精品av一区二区| 国产精品日韩av在线免费观看 | 一进一出好大好爽视频| 亚洲精品一区av在线观看| 色哟哟哟哟哟哟| netflix在线观看网站| 精品午夜福利视频在线观看一区| 欧美久久黑人一区二区| 日日摸夜夜添夜夜添小说| 熟妇人妻久久中文字幕3abv| 国产激情久久老熟女| 久久狼人影院| 久久国产精品影院| 亚洲中文字幕日韩| 午夜精品国产一区二区电影| 亚洲三区欧美一区| www.www免费av| 免费女性裸体啪啪无遮挡网站| 1024香蕉在线观看| 午夜福利,免费看| 亚洲第一av免费看| 亚洲中文av在线| 亚洲精品久久国产高清桃花| www国产在线视频色| 亚洲av成人一区二区三| 久热爱精品视频在线9| 亚洲 欧美 日韩 在线 免费| 男人舔女人的私密视频| 男人舔女人的私密视频| 在线永久观看黄色视频| 极品教师在线免费播放| 十八禁人妻一区二区| 首页视频小说图片口味搜索| 最近最新中文字幕大全电影3 | 涩涩av久久男人的天堂| 久久人人精品亚洲av| 国产91精品成人一区二区三区| 久久中文字幕一级| 午夜福利免费观看在线| 国产91精品成人一区二区三区| 国产aⅴ精品一区二区三区波| 成年人黄色毛片网站| 国产精品国产高清国产av| 午夜久久久久精精品| 国产人伦9x9x在线观看| 50天的宝宝边吃奶边哭怎么回事| 成人18禁高潮啪啪吃奶动态图| 亚洲情色 制服丝袜| 中出人妻视频一区二区| 久久午夜亚洲精品久久| 午夜亚洲福利在线播放| 制服丝袜大香蕉在线| 亚洲国产精品成人综合色| 欧美成人一区二区免费高清观看 | 90打野战视频偷拍视频| 国产99白浆流出| 一级a爱视频在线免费观看| 欧美人与性动交α欧美精品济南到| 两个人视频免费观看高清| 国产伦人伦偷精品视频| 老汉色av国产亚洲站长工具| 夜夜爽天天搞| 久久久久国产一级毛片高清牌| 精品国产乱子伦一区二区三区| 国产精品一区二区精品视频观看| 国产精品久久久av美女十八| 国产欧美日韩精品亚洲av| 露出奶头的视频| 男女之事视频高清在线观看| 18美女黄网站色大片免费观看| 免费不卡黄色视频| 国产精品一区二区在线不卡| 国产亚洲欧美精品永久| 午夜老司机福利片| 中文字幕色久视频| 中文字幕最新亚洲高清| 国产精品爽爽va在线观看网站 | 人人妻人人澡人人看| 日韩欧美免费精品| 很黄的视频免费| 国产精品野战在线观看| 国产一区二区三区视频了| 精品一品国产午夜福利视频| cao死你这个sao货| 国产精品秋霞免费鲁丝片| 法律面前人人平等表现在哪些方面| 欧美乱色亚洲激情| 18禁观看日本| 国产精品二区激情视频| 亚洲av熟女| 可以在线观看的亚洲视频| 欧洲精品卡2卡3卡4卡5卡区| 日韩欧美国产在线观看| 免费观看精品视频网站| 中文字幕av电影在线播放| 日本撒尿小便嘘嘘汇集6| 午夜福利成人在线免费观看| 日本a在线网址| 黄色视频,在线免费观看| 别揉我奶头~嗯~啊~动态视频| 精品国产一区二区久久| 精品久久久久久成人av| xxx96com| 啦啦啦观看免费观看视频高清 | 国产亚洲av高清不卡| 国产一区在线观看成人免费| 亚洲av电影在线进入| 久久香蕉激情| 中文字幕久久专区| 动漫黄色视频在线观看| 国产又爽黄色视频| 叶爱在线成人免费视频播放| 成人国语在线视频| 日日摸夜夜添夜夜添小说| 老熟妇仑乱视频hdxx| ponron亚洲| 男女做爰动态图高潮gif福利片 | 色av中文字幕| 女人爽到高潮嗷嗷叫在线视频| 又黄又粗又硬又大视频| 亚洲国产精品999在线| 久久久久国产一级毛片高清牌| 久久久久久国产a免费观看| 女性生殖器流出的白浆| 亚洲av熟女| 欧美人与性动交α欧美精品济南到| 国产精品美女特级片免费视频播放器 | 国产视频一区二区在线看| 国产午夜福利久久久久久| 天天一区二区日本电影三级 | 色哟哟哟哟哟哟| 国产99白浆流出| 不卡一级毛片| 国产一级毛片七仙女欲春2 | 麻豆成人av在线观看| 欧美日韩瑟瑟在线播放| 搞女人的毛片| 777久久人妻少妇嫩草av网站| 精品少妇一区二区三区视频日本电影| 久久精品91蜜桃| 免费高清视频大片| 国产单亲对白刺激| 亚洲人成网站在线播放欧美日韩| 久久久久久久午夜电影| 自拍欧美九色日韩亚洲蝌蚪91| 亚洲av五月六月丁香网| 久久久久久久久久久久大奶| 亚洲成av人片免费观看| 涩涩av久久男人的天堂| 亚洲五月天丁香| 最新美女视频免费是黄的| 亚洲中文字幕一区二区三区有码在线看 | 欧美日韩瑟瑟在线播放| 国产单亲对白刺激| 欧美人与性动交α欧美精品济南到| 两性夫妻黄色片| 一进一出抽搐动态| 欧美色欧美亚洲另类二区 | 国产欧美日韩一区二区三区在线| 人人妻,人人澡人人爽秒播| 色在线成人网| 久久精品aⅴ一区二区三区四区| 久久中文看片网| av有码第一页| 免费观看人在逋| 一卡2卡三卡四卡精品乱码亚洲| 黄色成人免费大全| 国产一区二区三区综合在线观看| 欧美一级毛片孕妇| 欧美日韩黄片免| 亚洲无线在线观看| 丰满人妻熟妇乱又伦精品不卡| 女同久久另类99精品国产91| 免费高清在线观看日韩| 国产av一区在线观看免费| 亚洲一区二区三区色噜噜| 中文字幕人妻丝袜一区二区| www国产在线视频色| 女同久久另类99精品国产91| 欧美激情高清一区二区三区| 人人澡人人妻人| 纯流量卡能插随身wifi吗| 久久中文字幕一级| 人人澡人人妻人| 亚洲精品一区av在线观看| 亚洲av熟女| 我的亚洲天堂| 国产一区在线观看成人免费| 可以在线观看的亚洲视频| 无限看片的www在线观看| 亚洲激情在线av| 久99久视频精品免费| 亚洲自偷自拍图片 自拍| av视频免费观看在线观看| 精品欧美国产一区二区三| netflix在线观看网站| avwww免费| 欧美乱妇无乱码| 性欧美人与动物交配| 国产麻豆69| 日本 欧美在线| 午夜免费激情av| 亚洲人成电影免费在线| 精品无人区乱码1区二区| 日韩欧美在线二视频| 日日夜夜操网爽| 国产伦一二天堂av在线观看| 黄色成人免费大全| 黑人巨大精品欧美一区二区蜜桃| 中文字幕人成人乱码亚洲影| 国产精品一区二区三区四区久久 | 校园春色视频在线观看| 999久久久国产精品视频| 久久人妻熟女aⅴ| 国产aⅴ精品一区二区三区波| 大型黄色视频在线免费观看| 1024视频免费在线观看| 美国免费a级毛片| 亚洲视频免费观看视频| 国产精品亚洲av一区麻豆| 亚洲电影在线观看av| 日韩视频一区二区在线观看| 人人澡人人妻人| 在线视频色国产色| 精品熟女少妇八av免费久了| 国产精品亚洲一级av第二区| 国产成人精品久久二区二区91| 淫妇啪啪啪对白视频| av中文乱码字幕在线| 亚洲人成电影观看| 亚洲最大成人中文| 久久久久久大精品| 国产精品一区二区免费欧美| 日韩 欧美 亚洲 中文字幕| 69精品国产乱码久久久| 一二三四在线观看免费中文在| 19禁男女啪啪无遮挡网站| www国产在线视频色| 麻豆久久精品国产亚洲av| 一夜夜www| 一级毛片女人18水好多| 午夜免费观看网址| 自拍欧美九色日韩亚洲蝌蚪91| 老司机靠b影院| 日日干狠狠操夜夜爽| 国产日韩一区二区三区精品不卡| 国产一区在线观看成人免费| e午夜精品久久久久久久| 国产视频一区二区在线看| 俄罗斯特黄特色一大片| 真人做人爱边吃奶动态| 91精品三级在线观看| 欧美另类亚洲清纯唯美| 黄色 视频免费看| 黄色 视频免费看| 国产亚洲精品久久久久久毛片| 亚洲精品美女久久久久99蜜臀| 精品久久蜜臀av无| 成人国产一区最新在线观看| 给我免费播放毛片高清在线观看| 久久精品亚洲熟妇少妇任你| 亚洲性夜色夜夜综合| 午夜久久久久精精品| 人人妻人人澡欧美一区二区 | 日韩欧美国产一区二区入口| 真人一进一出gif抽搐免费| 亚洲va日本ⅴa欧美va伊人久久| 天堂动漫精品| 久久久久精品国产欧美久久久| 久久欧美精品欧美久久欧美| 亚洲一卡2卡3卡4卡5卡精品中文| 亚洲五月色婷婷综合| 亚洲狠狠婷婷综合久久图片| 多毛熟女@视频| 国产三级在线视频| 免费在线观看黄色视频的| aaaaa片日本免费| 99久久精品国产亚洲精品| 亚洲专区国产一区二区| 亚洲aⅴ乱码一区二区在线播放 | av天堂久久9| 丝袜在线中文字幕| 国产成人影院久久av| 国产精品亚洲美女久久久| 99国产精品免费福利视频| 老司机福利观看| ponron亚洲| 亚洲精品久久国产高清桃花| 手机成人av网站| 国产成人精品在线电影| 免费观看精品视频网站| 深夜精品福利| 亚洲天堂国产精品一区在线| 黄色女人牲交| 日本撒尿小便嘘嘘汇集6| 精品一区二区三区视频在线观看免费| 18美女黄网站色大片免费观看| 女人爽到高潮嗷嗷叫在线视频| 久久精品影院6| 国产高清videossex| 天天躁狠狠躁夜夜躁狠狠躁| aaaaa片日本免费| 老司机靠b影院| 亚洲精华国产精华精| 欧美性长视频在线观看| 18禁国产床啪视频网站| 三级毛片av免费| 成人特级黄色片久久久久久久| 美女高潮到喷水免费观看| 日韩一卡2卡3卡4卡2021年| 国产一区二区三区视频了| 亚洲精华国产精华精| 国产精品乱码一区二三区的特点 | 色婷婷久久久亚洲欧美| 亚洲性夜色夜夜综合| 久久青草综合色| 午夜a级毛片| 欧美色视频一区免费| 亚洲欧美精品综合一区二区三区| 亚洲国产精品成人综合色| 美国免费a级毛片| 视频区欧美日本亚洲| 黄色a级毛片大全视频| 色综合亚洲欧美另类图片| 成熟少妇高潮喷水视频| 日本欧美视频一区| 精品久久蜜臀av无| 国产真人三级小视频在线观看| 免费在线观看亚洲国产| 国产av在哪里看| 中文字幕人妻熟女乱码| 女人被躁到高潮嗷嗷叫费观| 日本 欧美在线| 激情在线观看视频在线高清| 母亲3免费完整高清在线观看| 美国免费a级毛片| 嫩草影院精品99| 中文字幕av电影在线播放| 岛国视频午夜一区免费看| 91麻豆av在线| 国产又色又爽无遮挡免费看| 成人三级做爰电影| 美女午夜性视频免费| 国产成人欧美在线观看| 成人三级黄色视频| 色av中文字幕| 午夜a级毛片| 成熟少妇高潮喷水视频| 亚洲精品久久成人aⅴ小说| 久久草成人影院| av中文乱码字幕在线| 免费在线观看亚洲国产| 91成人精品电影| 精品一区二区三区四区五区乱码| 亚洲av成人不卡在线观看播放网| 三级毛片av免费| 久久人人97超碰香蕉20202| 久久午夜亚洲精品久久| 亚洲精品中文字幕在线视频| 久久香蕉激情| 一区二区三区高清视频在线| 午夜精品久久久久久毛片777| 亚洲电影在线观看av| 久久久久国内视频| 亚洲中文字幕日韩| 禁无遮挡网站| 一区二区三区高清视频在线| 一进一出抽搐动态| 午夜免费成人在线视频| 国产区一区二久久| 国产xxxxx性猛交| 亚洲一区高清亚洲精品| 伊人久久大香线蕉亚洲五| 少妇裸体淫交视频免费看高清 | 国产午夜精品久久久久久| 两个人看的免费小视频| 亚洲成av片中文字幕在线观看| 正在播放国产对白刺激| 免费av毛片视频| 高清在线国产一区| 91麻豆精品激情在线观看国产| 日本三级黄在线观看| 精品一品国产午夜福利视频| 亚洲天堂国产精品一区在线| 免费高清视频大片| 国产成人精品久久二区二区免费| 日韩视频一区二区在线观看| 不卡av一区二区三区| 亚洲一码二码三码区别大吗| 午夜激情av网站| 久久精品91无色码中文字幕| 精品国产超薄肉色丝袜足j| 国产精华一区二区三区| 国产高清视频在线播放一区| 99久久国产精品久久久| 日本五十路高清| 97超级碰碰碰精品色视频在线观看| 91成人精品电影| 成年女人毛片免费观看观看9| 精品久久久久久,| 成人国语在线视频| 国产精品香港三级国产av潘金莲| 日本在线视频免费播放| 99精品欧美一区二区三区四区| 啦啦啦观看免费观看视频高清 | 欧美国产精品va在线观看不卡| 搡老妇女老女人老熟妇| 亚洲专区国产一区二区| 国产av又大| 亚洲成人久久性| 99精品久久久久人妻精品| 欧美+亚洲+日韩+国产| 精品无人区乱码1区二区| 午夜福利18| 色av中文字幕| 亚洲第一青青草原| 看片在线看免费视频| 国产成人精品在线电影| 不卡av一区二区三区| 久久久久久久久久久久大奶| 在线观看www视频免费| 久久午夜亚洲精品久久| 久久欧美精品欧美久久欧美| 婷婷丁香在线五月| 久久婷婷人人爽人人干人人爱 | 大陆偷拍与自拍| 天天一区二区日本电影三级 | ponron亚洲| 日韩一卡2卡3卡4卡2021年| 在线十欧美十亚洲十日本专区| 欧美激情高清一区二区三区| 97人妻天天添夜夜摸| 在线观看午夜福利视频| 不卡一级毛片| aaaaa片日本免费| 久久国产精品男人的天堂亚洲| 亚洲国产精品久久男人天堂| 亚洲久久久国产精品| 看片在线看免费视频| 丝袜美腿诱惑在线| 亚洲av五月六月丁香网| 国产色视频综合| 女人被躁到高潮嗷嗷叫费观| 亚洲一区高清亚洲精品| 国产蜜桃级精品一区二区三区| 久久影院123| 国产一区二区在线av高清观看| 色综合婷婷激情| 香蕉丝袜av| 亚洲午夜精品一区,二区,三区| 99riav亚洲国产免费| 成人av一区二区三区在线看| 日本vs欧美在线观看视频| 日韩成人在线观看一区二区三区| 欧美中文综合在线视频| 国产成年人精品一区二区| 男男h啪啪无遮挡| 久久人妻福利社区极品人妻图片| 欧美不卡视频在线免费观看 | videosex国产| 天天一区二区日本电影三级 | 欧美一区二区精品小视频在线| 日本撒尿小便嘘嘘汇集6| 国产又色又爽无遮挡免费看| 精品一区二区三区av网在线观看| 亚洲无线在线观看| 曰老女人黄片| 久久九九热精品免费| 男人舔女人的私密视频| www国产在线视频色| 他把我摸到了高潮在线观看| 看片在线看免费视频| 精品免费久久久久久久清纯| 亚洲熟女毛片儿| 热99re8久久精品国产| 亚洲精品在线观看二区| 亚洲男人的天堂狠狠| 99re在线观看精品视频| 国产单亲对白刺激| 久久欧美精品欧美久久欧美| av福利片在线| 亚洲国产欧美日韩在线播放| 大香蕉久久成人网| 一级黄色大片毛片| 电影成人av| 老司机深夜福利视频在线观看| 久久久久久久午夜电影| 精品国产乱子伦一区二区三区| 精品乱码久久久久久99久播| 日本三级黄在线观看| 国产精品香港三级国产av潘金莲| 国产单亲对白刺激| 两个人视频免费观看高清| 韩国av一区二区三区四区| 变态另类丝袜制服| 窝窝影院91人妻| 日本精品一区二区三区蜜桃| www.精华液| 欧美黑人精品巨大| www.精华液| 一区二区日韩欧美中文字幕| 国产亚洲欧美精品永久| 亚洲第一av免费看| 国产精品亚洲av一区麻豆| 国产亚洲精品第一综合不卡| 午夜老司机福利片| 国产av在哪里看| www.熟女人妻精品国产| 淫秽高清视频在线观看| 久热爱精品视频在线9| 黄色片一级片一级黄色片| 美女免费视频网站| 国产在线精品亚洲第一网站| 中文字幕另类日韩欧美亚洲嫩草| 少妇 在线观看| 久久久精品国产亚洲av高清涩受| 男人舔女人下体高潮全视频| 欧美大码av| 99国产精品免费福利视频| 精品国产乱子伦一区二区三区| 午夜福利,免费看| 50天的宝宝边吃奶边哭怎么回事| 99国产精品免费福利视频| 久久青草综合色| 国产三级黄色录像| 精品国产国语对白av| 俄罗斯特黄特色一大片| 久久精品亚洲熟妇少妇任你| 制服诱惑二区| 欧美在线黄色| 一级毛片精品| 99国产精品一区二区蜜桃av| 久久婷婷成人综合色麻豆| 精品欧美一区二区三区在线| 长腿黑丝高跟| 成人国产综合亚洲| 国产国语露脸激情在线看| 国产主播在线观看一区二区| 中文字幕av电影在线播放| 国产精品久久久久久人妻精品电影| 黄色 视频免费看| 人妻久久中文字幕网| 亚洲熟妇中文字幕五十中出| www日本在线高清视频| 两性夫妻黄色片| 丁香欧美五月| 国内精品久久久久精免费| 最近最新中文字幕大全免费视频| 一区二区三区高清视频在线| 国产激情久久老熟女| 19禁男女啪啪无遮挡网站| 国产乱人伦免费视频| 国产精品秋霞免费鲁丝片| 日韩欧美一区视频在线观看| 国产1区2区3区精品| 国产精品久久视频播放| 国产精品久久久久久亚洲av鲁大| 亚洲欧洲精品一区二区精品久久久| 国产精品日韩av在线免费观看 | 日韩大码丰满熟妇| 无遮挡黄片免费观看| 狂野欧美激情性xxxx| 搡老岳熟女国产| 国产精品 欧美亚洲| 欧美激情 高清一区二区三区| 无限看片的www在线观看| tocl精华| 精品一品国产午夜福利视频| 丝袜美足系列| 禁无遮挡网站| 日韩 欧美 亚洲 中文字幕| 国产成人免费无遮挡视频| 老鸭窝网址在线观看| 好男人电影高清在线观看| √禁漫天堂资源中文www| 天天添夜夜摸| 亚洲精品国产区一区二| 亚洲男人的天堂狠狠| 日韩视频一区二区在线观看| 激情视频va一区二区三区| 久久精品国产99精品国产亚洲性色 | 亚洲精品久久国产高清桃花| 亚洲美女黄片视频| 怎么达到女性高潮| 一级片免费观看大全| 乱人伦中国视频| 亚洲情色 制服丝袜| 日本a在线网址| 日韩免费av在线播放| av天堂久久9| 亚洲av第一区精品v没综合| 日本免费一区二区三区高清不卡 | 亚洲av日韩精品久久久久久密| 一二三四在线观看免费中文在| 亚洲免费av在线视频| 老汉色av国产亚洲站长工具| av免费在线观看网站| 成人国语在线视频| 欧美激情极品国产一区二区三区| 97人妻天天添夜夜摸| 亚洲免费av在线视频| 国产黄a三级三级三级人| 九色亚洲精品在线播放| 97超级碰碰碰精品色视频在线观看|