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

    基于Spring MVC的大數(shù)據(jù)交易集市平臺(tái)①

    2022-05-10 12:11:48
    關(guān)鍵詞:商城集市交易

    滕 飛

    (武警工程大學(xué) 裝備管理與保障學(xué)院,西安 710086)

    大數(shù)據(jù)(big data),指無(wú)法在一定時(shí)間范圍內(nèi)用常規(guī)軟件工具進(jìn)行捕捉、管理和處理的數(shù)據(jù)集合,是需要新處理模式才能具有更強(qiáng)的決策力、洞察發(fā)現(xiàn)力和流程優(yōu)化能力的海量、高增長(zhǎng)率和多樣化的信息資產(chǎn).大數(shù)據(jù)具有以下特點(diǎn):(1) 數(shù)據(jù)體量巨大.可以達(dá)到TB、PB 級(jí)別;(2) 數(shù)據(jù)類型繁多,例如網(wǎng)絡(luò)日志、視頻、圖片、地理位置信息等;(3) 處理速度快;(4) 商業(yè)價(jià)值,只要利用合理的分析手段,可以挖掘出數(shù)據(jù)中潛在的商業(yè)價(jià)值.在大數(shù)據(jù)時(shí)代,如何充分挖掘出蘊(yùn)藏于數(shù)據(jù)資源中的價(jià)值正在成為各國(guó) IT 業(yè)界,學(xué)術(shù)界和政府共同關(guān)注的焦點(diǎn)[1].2015年中國(guó)大數(shù)據(jù)市場(chǎng)規(guī)模達(dá)到33.85 億元,2020年大數(shù)據(jù)交易市場(chǎng)規(guī)模達(dá)到540 億元.大數(shù)據(jù)市場(chǎng)不僅規(guī)模大,并且呈現(xiàn)快速增長(zhǎng)趨勢(shì),為了更好地運(yùn)用數(shù)據(jù)資源,目前具有的大數(shù)據(jù)交易平臺(tái)有日本富士通公司的大數(shù)據(jù)交易集市Data plaza、BDEX、貴陽(yáng)大數(shù)據(jù)交易所、數(shù)據(jù)堂等,開發(fā)大數(shù)據(jù)交易平臺(tái)具有重大意義.為解決大數(shù)據(jù)交易中存在的自身數(shù)據(jù)不出門、數(shù)據(jù)交換受制約等問(wèn)題,并為用戶提供查看樣本數(shù)據(jù)、根據(jù)需求篩選數(shù)據(jù)集內(nèi)容等功能,同時(shí)創(chuàng)客可以利用平臺(tái)購(gòu)買數(shù)據(jù)開發(fā)相關(guān)的應(yīng)用,并發(fā)布在本平臺(tái),本文設(shè)計(jì)了一種大數(shù)據(jù)交易集市平臺(tái),并利用Spring MVC 構(gòu)建后臺(tái)整體架構(gòu)開發(fā)出相應(yīng)的原型系統(tǒng).

    1 系統(tǒng)設(shè)計(jì)

    1.1 系統(tǒng)總體規(guī)劃

    目前的大數(shù)據(jù)交易平臺(tái)主要的模式有:

    (1)提供交易平臺(tái),發(fā)布數(shù)據(jù)目錄,不直接提供數(shù)據(jù).

    (2)發(fā)布數(shù)據(jù)目錄,數(shù)據(jù)提供方上傳數(shù)據(jù)并保存.

    (3)發(fā)布數(shù)據(jù)目錄,發(fā)布銷售數(shù)據(jù).

    (4)提供采集工具,采集公開網(wǎng)頁(yè)數(shù)據(jù),收取服務(wù)費(fèi).

    在現(xiàn)有的交易模式中,私有數(shù)據(jù)所有者出于數(shù)據(jù)安全的考慮,擔(dān)心隱私泄露、數(shù)據(jù)被濫用、數(shù)據(jù)被競(jìng)爭(zhēng)對(duì)手利用,往往不愿意交換自己擁有的數(shù)據(jù).同時(shí)在不同的行業(yè)和專業(yè)領(lǐng)域之間,彼此難以相互了解對(duì)方的數(shù)據(jù),靠數(shù)據(jù)目錄使得數(shù)據(jù)難以發(fā)揮自身的價(jià)值.本文提出的大數(shù)據(jù)交易集市平臺(tái)是基于各方的分布式數(shù)據(jù)和應(yīng)用建立和運(yùn)營(yíng)一個(gè)公信的數(shù)據(jù)和應(yīng)用服務(wù)交易平臺(tái),本系統(tǒng)可以為數(shù)據(jù)機(jī)構(gòu)提供數(shù)據(jù)和應(yīng)用交易樞紐代理,如圖1所示.主要特點(diǎn)如下.

    圖1 數(shù)據(jù)和應(yīng)用交易樞紐圖

    (1)數(shù)據(jù)由提供者存儲(chǔ)和管理:數(shù)據(jù)交易集市不直接管理數(shù)據(jù),誰(shuí)的數(shù)據(jù)誰(shuí)控制,數(shù)據(jù)請(qǐng)求發(fā)生時(shí)由數(shù)據(jù)代理根據(jù)需求從數(shù)據(jù)所有者獲取數(shù)據(jù)交給需求方.數(shù)據(jù)提供者可將數(shù)據(jù)保存自己公司的服務(wù)器上,或保存到本系統(tǒng)提供的Hive 集群中,當(dāng)發(fā)生交易時(shí),系統(tǒng)擁有權(quán)限,通過(guò)相應(yīng)的API 接口獲取服務(wù)器中的數(shù)據(jù)集.

    (2)提供數(shù)據(jù)樣本數(shù)據(jù):用戶可以在數(shù)據(jù)商城查看樣本數(shù)據(jù)集,進(jìn)一步了解數(shù)據(jù)商品.

    (3)篩選數(shù)據(jù)集內(nèi)容功能:用戶可以根據(jù)需求選擇需要的字段,過(guò)濾掉數(shù)據(jù)集中無(wú)價(jià)值的信息.

    (4)數(shù)據(jù)應(yīng)用可開發(fā):提供數(shù)據(jù)應(yīng)用開發(fā)環(huán)境,滿足基于大數(shù)據(jù)的創(chuàng)新應(yīng)用需求.

    大數(shù)據(jù)交易集市原型系統(tǒng)的總體規(guī)劃如圖2所示.

    圖2 系統(tǒng)總體規(guī)劃圖

    使用大數(shù)據(jù)交易集市平臺(tái)的有數(shù)據(jù)機(jī)構(gòu)(數(shù)據(jù)商品的提供方)、創(chuàng)客(應(yīng)用程序的開發(fā)者)、客戶.

    數(shù)據(jù)機(jī)構(gòu)可以將擁有的數(shù)據(jù)發(fā)布到平臺(tái)的數(shù)據(jù)商城中進(jìn)行交易,同時(shí)把數(shù)據(jù)集中部分?jǐn)?shù)據(jù)作為樣本數(shù)據(jù)加入到平臺(tái)的樣本庫(kù)中,創(chuàng)客通過(guò)查看樣本數(shù)據(jù),決定是否購(gòu)買相應(yīng)的數(shù)據(jù)集.數(shù)據(jù)機(jī)構(gòu)也可以利用自身?yè)碛械臄?shù)據(jù)的優(yōu)勢(shì)開發(fā)應(yīng)用程序,開發(fā)出的應(yīng)用程序可以發(fā)布到平臺(tái)的應(yīng)用商城中,客戶通過(guò)應(yīng)用商城購(gòu)買需要的應(yīng)用.

    交易平臺(tái)會(huì)對(duì)數(shù)據(jù)機(jī)構(gòu)提供的數(shù)據(jù)集、應(yīng)用程序進(jìn)行審核,審核通過(guò)后才會(huì)發(fā)布到商城中交易,這樣有效避免數(shù)據(jù)集中存在違法數(shù)據(jù)等問(wèn)題.

    1.2 軟件架構(gòu)設(shè)計(jì)

    大數(shù)據(jù)交易集市平臺(tái)的軟件架構(gòu)設(shè)計(jì)如圖3所示.軟件架構(gòu)從上至下可以分為3 層,分別是SaaS 層[2]、PaaS 層[3]和IaaS 層[4],下面進(jìn)行詳細(xì)的介紹.

    圖3 軟件架構(gòu)圖

    SaaS 層:給用戶提供的能力是使用在云基礎(chǔ)架構(gòu)上運(yùn)行的云服務(wù)提供商的應(yīng)用程序.本系統(tǒng)的SasS 層中包含前臺(tái)、后臺(tái)管理系統(tǒng)、應(yīng)用沙箱.

    PaaS 層:平臺(tái)即服務(wù)作為云計(jì)算的一種,是將基礎(chǔ)設(shè)施平臺(tái)作為一種服務(wù)呈現(xiàn)給用戶的商業(yè)模式,是一種低成本的方案[5].可以讓用戶使用由云服務(wù)提供商支持的編程語(yǔ)言、庫(kù)和開發(fā)工具等開發(fā)應(yīng)用程序,并在相應(yīng)的基礎(chǔ)設(shè)施上部署.本系統(tǒng)的PaaS 層主要包含緩存模塊、文件上傳下載模塊等.

    IaaS 層:它將硬件資源以服務(wù)的方式提供給云平臺(tái)服務(wù)開發(fā)商,這樣就對(duì)后者屏蔽了基礎(chǔ)設(shè)施的異構(gòu)性[6].用戶可以在云服務(wù)提供商提供的基礎(chǔ)設(shè)施上部署和運(yùn)行任何軟件.本系統(tǒng)的IaaS 層主要實(shí)現(xiàn)虛擬化、資源調(diào)度、安全管理等功能,硬件上有X86 集群、小型集群等.

    1.3 主要功能設(shè)計(jì)

    下面介紹大數(shù)據(jù)交易集市主要的兩個(gè)業(yè)務(wù)場(chǎng)景.

    業(yè)務(wù)場(chǎng)景一:數(shù)據(jù)發(fā)布和服務(wù)代理請(qǐng)求數(shù)據(jù),如圖4所示.本系統(tǒng)實(shí)現(xiàn)該功能可以分為以下幾步.

    圖4 數(shù)據(jù)發(fā)布和服務(wù)代理請(qǐng)求調(diào)用數(shù)據(jù)圖

    (1)數(shù)據(jù)交易集市為數(shù)據(jù)機(jī)構(gòu)A和B 部署交易端,包括數(shù)據(jù)應(yīng)用運(yùn)行容器及數(shù)據(jù)審計(jì)網(wǎng)關(guān);

    (2)數(shù)據(jù)機(jī)構(gòu)A和B 開發(fā)可交易數(shù)據(jù)接口;

    (3)數(shù)據(jù)機(jī)構(gòu)A和B 通過(guò)代理注冊(cè)可交易的數(shù)據(jù),并通過(guò)數(shù)據(jù)采集接口提供樣本數(shù)據(jù);

    (4)數(shù)據(jù)請(qǐng)求方通過(guò)注冊(cè)功能進(jìn)行數(shù)據(jù)檢索、察看樣本,找到需求數(shù)據(jù);

    (5)請(qǐng)求方接受數(shù)據(jù)使用條款;

    (6)代理將數(shù)據(jù)提取應(yīng)用部署至數(shù)據(jù)所有者側(cè)A和B,啟動(dòng)應(yīng)用對(duì)數(shù)據(jù)進(jìn)行處理;

    (7)處理結(jié)果經(jīng)A和B 過(guò)濾、審計(jì)后再傳回代理;

    (8)如果有多個(gè)數(shù)據(jù)源返回結(jié)果,代理對(duì)結(jié)果進(jìn)行過(guò)濾、融合處理(過(guò)濾和審計(jì)操作按交易條件可選);

    (9)代理將結(jié)果傳回請(qǐng)求方.

    業(yè)務(wù)場(chǎng)景二:應(yīng)用的測(cè)試發(fā)布、數(shù)據(jù)和應(yīng)用服務(wù)請(qǐng)求及處理,如圖5.本系統(tǒng)實(shí)現(xiàn)該功能步驟如下.

    圖5 應(yīng)用的測(cè)試發(fā)布、數(shù)據(jù)和應(yīng)用服務(wù)請(qǐng)求及處理圖

    (1) 開發(fā)者提出開發(fā)請(qǐng)求;

    (2)開發(fā)者利用樣本數(shù)據(jù)在應(yīng)用沙盒中進(jìn)行數(shù)據(jù)處理功能和安全性測(cè)試;

    (3)數(shù)據(jù)交易集市對(duì)提交的應(yīng)用進(jìn)行安全和可用性測(cè)試后發(fā)布至應(yīng)用商店;

    (4)數(shù)據(jù)交易代理將該應(yīng)用部署至數(shù)據(jù)所有者側(cè)并完成初始化,等待用戶調(diào)用.

    2 相關(guān)技術(shù)

    2.1 Spring MVC

    Spring MVC 框架實(shí)際上是Spring 框架中的Spring Web MVC 模塊[7].其作為Spring Framework的后續(xù)產(chǎn)品,融合在Spring Web Flow 里面.Spring MVC可以提供MVC (model view controller)軟件開發(fā)模式,并且支持IOC和AOP.

    2.2 Hive

    Hive 由Facebook 開發(fā),是一種構(gòu)建于 Hadoop[8]集群之上的數(shù)據(jù)倉(cāng)庫(kù)應(yīng)用,旨在實(shí)現(xiàn) Hadoop 上的數(shù)據(jù)操作與傳統(tǒng) SQL的結(jié)合[9].在Hadoop 中用來(lái)處理結(jié)構(gòu)化數(shù)據(jù).開發(fā)人員直接使用Hadoop 會(huì)面臨學(xué)習(xí)成本太高、項(xiàng)目周期要求太短、MapReduce[10]實(shí)現(xiàn)復(fù)雜查詢邏輯開發(fā)難度大等問(wèn)題.Hive 通過(guò)將結(jié)構(gòu)化的數(shù)據(jù)文件映射為一張數(shù)據(jù)庫(kù)表,并提供類 SQL 查詢接口,本質(zhì)是將 SQL 轉(zhuǎn)換為MapReduce 程序,提供快速開發(fā)的能力,有效減少開發(fā)人員的學(xué)習(xí)成本.

    3 系統(tǒng)實(shí)現(xiàn)

    3.1 總體模塊設(shè)計(jì)

    在本文提出的大數(shù)據(jù)交易模式中,由數(shù)據(jù)提供方在大數(shù)據(jù)交易集市平臺(tái)上發(fā)布數(shù)據(jù)及相關(guān)的應(yīng)用,數(shù)據(jù)需求方根據(jù)需要在平臺(tái)購(gòu)買相應(yīng)的數(shù)據(jù)集或服務(wù),如圖6所示.

    圖6 總體實(shí)施方案圖

    數(shù)據(jù)交易集市有前臺(tái)和后臺(tái)管理系統(tǒng)組成.前臺(tái)主要模塊是門戶模塊,該模塊又可以分為多個(gè)子模塊,下面詳細(xì)介紹幾個(gè)主要的功能模塊.

    (1)數(shù)據(jù)商城模塊實(shí)現(xiàn)數(shù)據(jù)商城列表、商品詳情.展示數(shù)據(jù)機(jī)構(gòu)發(fā)布的所有數(shù)據(jù)商品,方便有需求的買家挑選購(gòu)買.

    (2)應(yīng)用商城模塊實(shí)現(xiàn)應(yīng)用商城列表、商品詳情.展示創(chuàng)客發(fā)布的所有應(yīng)用商品,方便有需求的買家挑選購(gòu)買.

    (3)API 商城模塊實(shí)現(xiàn)API 商城列表、商品詳情.展示商家發(fā)布的所有API 商品,方便有需求的買家挑選購(gòu)買.

    (4)個(gè)人中心模塊實(shí)現(xiàn)個(gè)人信息、用戶認(rèn)證、賬戶安全、白名單管理、消息通知等功能.

    (5)購(gòu)物車模塊,用戶購(gòu)物活動(dòng)中的購(gòu)物車,類似在淘寶、京東中的作用.

    (6)買家中心模塊實(shí)現(xiàn)管理已購(gòu)數(shù)據(jù)、已購(gòu)應(yīng)用、已購(gòu)API.

    (7)賣家中心功能有統(tǒng)計(jì)分析、已售數(shù)據(jù)、已售應(yīng)用、已售API、數(shù)據(jù)發(fā)布、應(yīng)用發(fā)布、API 發(fā)布、應(yīng)用鑒權(quán)等.

    (8)數(shù)據(jù)和應(yīng)用發(fā)布,展現(xiàn)賣家發(fā)布的數(shù)據(jù)和應(yīng)用商品情況列表,支持用戶發(fā)布數(shù)據(jù)和應(yīng)用商品,通過(guò)審核以及數(shù)據(jù)機(jī)構(gòu)應(yīng)用鑒權(quán)后,可上架銷售.

    后臺(tái)管理系統(tǒng)由3 部分組成,其中數(shù)據(jù)及應(yīng)用注冊(cè)模塊,主要實(shí)現(xiàn)數(shù)據(jù)集及應(yīng)用的定義及發(fā)布、元數(shù)據(jù)管理、抽樣數(shù)據(jù)管理、數(shù)據(jù)交易記錄等功能.數(shù)據(jù)代理模塊,數(shù)據(jù)代理是數(shù)據(jù)交易的核心功能,主要實(shí)現(xiàn)數(shù)據(jù)應(yīng)用的部署及清理、需求數(shù)據(jù)獲取及返回結(jié)果過(guò)濾或合并等.

    應(yīng)用管理模塊,主要為應(yīng)用開發(fā)者提供開發(fā)環(huán)境及上線應(yīng)用的管理等功能.其中應(yīng)用沙箱主要用于應(yīng)用開發(fā),開發(fā)者可以在應(yīng)用沙箱中利用樣本數(shù)據(jù)進(jìn)行應(yīng)用開發(fā),測(cè)試完成的應(yīng)用可通過(guò)發(fā)布功能在應(yīng)用商店進(jìn)行發(fā)布.

    3.2 開發(fā)環(huán)境

    編程語(yǔ)言:Java;開發(fā)工具:STS (Spring tools suite);操作系統(tǒng):Windows 10;數(shù)據(jù)庫(kù):MySQL 5.7;JDK 版本:JDK 1.8 版本;瀏覽器:Google Chrome;機(jī)器:Lenovo ThinkPad T470;內(nèi)存:4 GB 以上;硬盤:500 GB 以上;集群環(huán)境:Hadoop/Hive 集群是由 5 臺(tái)與單機(jī)服務(wù)器組成.每臺(tái)服務(wù)器上安裝Ubuntu 系統(tǒng),并安裝配置Hadoop-2.7.3和Hive1.2.

    3.3 項(xiàng)目架構(gòu)

    數(shù)據(jù)交易集市平臺(tái)采用前端分離的模式開發(fā),整個(gè)系統(tǒng)有3 個(gè)子項(xiàng)目組成,datamarket (大數(shù)據(jù)交易集市門戶系統(tǒng))、bjmarketportal (大數(shù)據(jù)交易集市后臺(tái)管理系統(tǒng))、datamarketReact (大數(shù)據(jù)交易集市前端頁(yè)面).如圖7,datamarket和bjmarketportal 通過(guò)RESTful API和datamarketReact 頁(yè)面進(jìn)行交互.后臺(tái)使用Java 語(yǔ)言在STS 中開發(fā).前端頁(yè)面系統(tǒng)datamarketReact 采用React 框架[11]開發(fā),使用webpack 前端構(gòu)建工具,采用es2016 新一代JavaScript 編碼模式,頁(yè)面中的圖表展示使用到echarts,前端可以通過(guò)后臺(tái)的RESTful API與后臺(tái)進(jìn)行交互.

    圖7 工程架構(gòu)圖

    后臺(tái)部分使用Spring MVC 框架構(gòu)建項(xiàng)目整體架構(gòu),并采用了經(jīng)典的Web 3 層架構(gòu)模型,MVC 模式把應(yīng)用程序拆分成3 個(gè)部分:模型,視圖和控制器[12].即從高到低次是Controller 層、Service 層和Dao 層,下面進(jìn)行詳細(xì)的介紹.

    本項(xiàng)目在開發(fā)中,通過(guò)在STS 中配置maven-3.5.0實(shí)現(xiàn)對(duì)Jar 包的管理,并在maven[13]的配置文件settings.xml 中完成指定本地倉(cāng)庫(kù)地址,設(shè)置阿里云鏡像,部分代碼如下所示.通過(guò)maven 避免了開發(fā)人員手工添加Jar 包和Jar 包版本沖突的問(wèn)題.

    <mirror><id>alimaven</id><name>aliyun maven</name><url>http://maven.aliyun.com/nexus/content/groups/public/</url><mirrorOf>central</mirrorOf></mirror>

    在傳統(tǒng)的單體架構(gòu)[14]中,登錄用戶的信息往往保存在session[15]中,當(dāng)?shù)卿浻脩粼龆嗖粌H會(huì)增加服務(wù)器的壓力,同時(shí)在分布式應(yīng)用上,會(huì)限制負(fù)載均衡器的能力和應(yīng)用的擴(kuò)展性,本項(xiàng)目采用基于JWT (JSON Web token)[16]的認(rèn)證方式,通過(guò)pom.xml 文件實(shí)現(xiàn)在Spring MVC 框架中集成JWT.

    在數(shù)據(jù)庫(kù)的操作方面,MyBatis的優(yōu)勢(shì)在于利用配置文件,不需要在代碼中編寫SQL 語(yǔ)句[17].MyBatis Generator 插件可以根據(jù)表結(jié)構(gòu)生成JavaBean.本系統(tǒng)實(shí)現(xiàn)了Spring MVC和MyBatis、MyBatis Generator的集成.pom.xml 配置文件部分代碼如下:

    <dependency><groupId>org.mybatis</groupId><artifactId>mybatis-spring</artifactId><version>${mybatis.spring.version}</version></dependency>

    大數(shù)據(jù)集往往需求較大的存儲(chǔ)空間,為滿足業(yè)務(wù)需求,本系統(tǒng)使用MySQL 保存用戶信息、商品詳情、樣本數(shù)據(jù)等信息,使用Hive 保存存儲(chǔ)數(shù)據(jù)公司提供的數(shù)據(jù)集.

    在接口測(cè)試方面,實(shí)現(xiàn)了Spring MVC和Swagger框架的集成,Swagger是一個(gè)簡(jiǎn)單又強(qiáng)大的RESTful 風(fēng)格的API 生成文檔工具.pom.xml 配置文件部分代碼如下:

    ?

    項(xiàng)目在Spring MVC 框架中還集成了分頁(yè)插件pagehelper、lombok、Redis 等技術(shù).

    3.4 高訪問(wèn)機(jī)制

    在大數(shù)據(jù)交易集市平臺(tái)中,用戶瀏覽數(shù)據(jù)商城,查看樣本數(shù)據(jù)集,以及查看個(gè)人信息等操作都會(huì)涉及到對(duì)數(shù)據(jù)庫(kù)進(jìn)行I/O 操作.當(dāng)用戶訪問(wèn)量增大,對(duì)數(shù)據(jù)庫(kù)會(huì)進(jìn)行頻繁的讀寫操作,系統(tǒng)在性能上會(huì)出現(xiàn)瓶頸,本文采用NoSQL 技術(shù)解決這一問(wèn)題.Redis[18]是現(xiàn)在最受歡迎的NoSQL 數(shù)據(jù)庫(kù)[19]之一,Redis 包含多種數(shù)據(jù)結(jié)構(gòu)、支持網(wǎng)絡(luò)、基于內(nèi)存、可選持久性的鍵值對(duì)存儲(chǔ)數(shù)據(jù)庫(kù).本文采用Redis 實(shí)現(xiàn)系統(tǒng)的高訪問(wèn)機(jī)制,當(dāng)用戶從系統(tǒng)獲取數(shù)據(jù)時(shí),系統(tǒng)會(huì)首先從Redis 中查找,如果沒(méi)有找到,再?gòu)臄?shù)據(jù)庫(kù)中讀取,有效提高系統(tǒng)讀取數(shù)據(jù)的性能,緩解數(shù)據(jù)庫(kù)訪問(wèn)壓力,過(guò)程如圖8所示.

    圖8 Redis 緩存機(jī)制

    3.5 基于RESTful的API 接口設(shè)計(jì)

    3.5.1 RESTful API 介紹

    API (application programming interface,應(yīng)用程序編程接口)[20]用來(lái)提供應(yīng)用程序與開發(fā)人員基于某軟件得以訪問(wèn)的一組例程,而開發(fā)人員無(wú)需關(guān)心其內(nèi)部工作機(jī)制的細(xì)節(jié).在REST (representational state transfer)中每個(gè)資源由URI 標(biāo)識(shí),RESTful[21]是一種架構(gòu)的規(guī)范與約束,通過(guò)POST,GET,PUT,DELETE 操作對(duì)資源進(jìn)行CRUD[22]操作.

    3.5.2 權(quán)限驗(yàn)證流程

    系統(tǒng)提供的所有API 必須通過(guò)認(rèn)證鑒權(quán)才可使用.權(quán)限驗(yàn)證流程如圖9所示.用戶登錄系統(tǒng)時(shí),前端會(huì)向后端傳入登錄驗(yàn)證信息,如表1所示.

    表1 用戶登錄信息表

    圖9 權(quán)限驗(yàn)證流程圖

    驗(yàn)證成功后,服務(wù)器端會(huì)生成Token.之后將Token和該用戶的權(quán)限保存到Redis 中,如表2所示.

    表2 Token 信息表

    本系統(tǒng)的Token 由隨機(jī)字符串、用戶名稱、時(shí)間戳拼接后md5 摘要生成,60 min 過(guò)期.

    3.5.3 接口設(shè)計(jì)

    接口數(shù)據(jù)傳輸采用HTTP 協(xié)議,提交和返回?cái)?shù)據(jù)都為JSON 格式[23],并統(tǒng)一采用UTF-8 字符編碼.Spring MVC 框架中使用@RequestBody 注解把前端發(fā)送的JSON 字符串轉(zhuǎn)為Java 對(duì)象,使用@ResponseBody注解把后臺(tái)Java 對(duì)象轉(zhuǎn)換JSON 字符串.在返回?cái)?shù)據(jù)方面,失敗時(shí)re_message 字段返回失敗原因.下面通過(guò)本系統(tǒng)的后臺(tái)管理bjmarketportal 項(xiàng)目中數(shù)據(jù)商品管理模塊詳細(xì)介紹API 接口的設(shè)計(jì).數(shù)據(jù)商品管理模塊主要實(shí)現(xiàn)數(shù)據(jù)商品信息維護(hù),數(shù)據(jù)商品審核、發(fā)布等功能.數(shù)據(jù)商品管信息管理模塊的API 接口設(shè)計(jì)如表3.

    表3 數(shù)據(jù)商品管理模塊接口

    下面重點(diǎn)介紹其中的根據(jù)id 查詢數(shù)據(jù)商品詳情,接口鏈接地址:/api/v1/ datacommodity{id},id是用戶從前端提交的請(qǐng)求參數(shù),請(qǐng)求方式是GET 類型,后端根據(jù)商品的id 從數(shù)據(jù)庫(kù)中查找商品詳情信息,如表4.

    表4 數(shù)據(jù)商品表

    查詢結(jié)果會(huì)以成JSON 格式發(fā)送到前端頁(yè)面,當(dāng)查詢成功時(shí)返回結(jié)果如下所示:

    {“data_commodity_id”:12,“data_set_commodity_name”:全國(guó)天氣數(shù)據(jù)集,“data_charge_type_code”:“2”,“img”:“nofile”,“file”:“nofile”,“data_charge_price”:“950”,“data_desc1”:“全國(guó)天氣數(shù)據(jù)集簡(jiǎn)介”,“data_desc2”:“可以按照日期和城市查詢天氣數(shù)據(jù)”,“data_desc3”:“天氣預(yù)報(bào),應(yīng)急救災(zāi)”,“data_desc4”:“數(shù)據(jù)分析,機(jī)器學(xué)習(xí)”,“example_is_download”:“1”,“data_type”:“txt 文本”,“data_single”:“1”,“sale_counts”:150}

    后臺(tái)執(zhí)行成功,將數(shù)據(jù)添加到數(shù)據(jù)庫(kù)中,如果執(zhí)行失敗,會(huì)將失敗信息以JSON 格式發(fā)送到前端,如下:

    ?

    3.6 數(shù)據(jù)集購(gòu)買

    數(shù)據(jù)集購(gòu)買功能位于datamarket 項(xiàng)目的數(shù)據(jù)商城模塊中,數(shù)據(jù)商品可以按照行業(yè)分為政府、醫(yī)療、金融、電商、汽車、房地產(chǎn)、教育、旅游等.大數(shù)據(jù)具有量大、價(jià)值密度低的特點(diǎn),用戶在使用數(shù)據(jù)集進(jìn)行數(shù)據(jù)分析、開發(fā)應(yīng)用軟件時(shí),往往不會(huì)使用到數(shù)據(jù)集中的所有數(shù)據(jù),需要清除掉無(wú)價(jià)值的信息,本系統(tǒng)在購(gòu)買數(shù)據(jù)商品功能基礎(chǔ)上,提供查看樣本數(shù)據(jù)、按照字段篩選數(shù)據(jù)等功能.

    數(shù)據(jù)機(jī)構(gòu)首先上傳數(shù)據(jù)商品的詳情信息和樣本數(shù)據(jù),后臺(tái)管理員審核通過(guò)后,會(huì)將數(shù)據(jù)商品發(fā)布到數(shù)據(jù)商城中.創(chuàng)客根據(jù)自身需求,查看數(shù)據(jù)商品詳情和樣本數(shù)據(jù),選擇合適的數(shù)據(jù)商品,完成支付后,可以下載相應(yīng)的數(shù)據(jù)集,并且可以使用數(shù)據(jù)商城提供的數(shù)據(jù)篩選功能去除數(shù)據(jù)集中無(wú)價(jià)值的信息.下面通過(guò)數(shù)據(jù)機(jī)構(gòu)A 提供的全國(guó)天氣數(shù)據(jù)集National_weather_data 詳細(xì)介紹數(shù)據(jù)商品購(gòu)買功能.

    全國(guó)天氣數(shù)據(jù)集National_weather_data 記錄了2000年到2018年全國(guó)各個(gè)城市每一天的天氣數(shù)據(jù),每條記錄字段包含:城市、日期、天氣狀況、最高氣溫、最低氣溫、風(fēng)力風(fēng)向,如表5所示.

    表5 全國(guó)天氣數(shù)據(jù)樣例表

    數(shù)據(jù)機(jī)構(gòu)A 首先上傳該數(shù)據(jù)集的詳情信息和對(duì)應(yīng)的樣本數(shù)據(jù).數(shù)據(jù)機(jī)構(gòu)首先創(chuàng)建樣本數(shù)據(jù)集對(duì)應(yīng)的表結(jié)構(gòu),填寫每個(gè)字段名稱、字段的數(shù)據(jù)類型等,如圖10.

    圖10 設(shè)置樣本數(shù)據(jù)集

    數(shù)據(jù)機(jī)構(gòu)A 提交信息后,后臺(tái)會(huì)在MySQL 數(shù)據(jù)庫(kù)中創(chuàng)建對(duì)應(yīng)的表,使用MyBatis 框架實(shí)現(xiàn)動(dòng)態(tài)創(chuàng)建表結(jié)構(gòu),把樣本數(shù)據(jù)名稱作為表名,字段名稱和數(shù)據(jù)類型作為表的屬性和相應(yīng)的數(shù)據(jù)類型.之后數(shù)據(jù)機(jī)構(gòu)A 在系統(tǒng)中填寫樣本數(shù)據(jù)表記錄,樣本數(shù)據(jù)表的記錄行數(shù)一般在10-50 行之間,部分代碼如下:

    ?

    系統(tǒng)管理員會(huì)對(duì)數(shù)據(jù)商品的介紹信息和樣本數(shù)據(jù)內(nèi)容進(jìn)行審核,檢查數(shù)據(jù)商品是否符合商城的規(guī)定,有無(wú)違法信息,審核通過(guò)后授權(quán)數(shù)據(jù)機(jī)構(gòu)向Hive 集群上傳數(shù)據(jù)商品.

    為確保數(shù)據(jù)提供者的數(shù)據(jù)安全性,系統(tǒng)會(huì)向數(shù)據(jù)提供者提供Hive 集群資源,數(shù)據(jù)提供者可以上傳、修改、查看、刪除數(shù)據(jù)集,數(shù)據(jù)機(jī)構(gòu)和客戶達(dá)成購(gòu)買協(xié)議,并完成交易后,數(shù)據(jù)交易集市才可以獲得相應(yīng)數(shù)據(jù)集的獲取權(quán)限,數(shù)據(jù)代理根據(jù)需求從數(shù)據(jù)所有者獲取數(shù)據(jù)交給客戶.下面通過(guò)national_weather_data 數(shù)據(jù)集進(jìn)行詳細(xì)介紹.

    數(shù)據(jù)機(jī)構(gòu)A 將數(shù)據(jù)集中的數(shù)據(jù)保存到txt 文件中,命名為national_weather_data.txt,文件中每一行代表一條數(shù)據(jù)記錄,每條數(shù)據(jù)記錄中的一列代表一個(gè)屬性值,每個(gè)屬性之間用英文逗號(hào)隔開.當(dāng)數(shù)據(jù)商品詳情和樣本數(shù)據(jù)被后臺(tái)管理員審核通過(guò)后,會(huì)通過(guò)數(shù)據(jù)商城的API 接口將national_weather_data.txt 中的數(shù)據(jù)導(dǎo)入到Hive 集群中管理,過(guò)程如圖11所示.

    圖11 數(shù)據(jù)機(jī)構(gòu)上傳數(shù)據(jù)商品圖

    Hive 集群保存數(shù)據(jù)集的過(guò)程如下:

    (1)表名以及表中的字段名稱和樣本數(shù)據(jù)表national_weather_data 相對(duì)應(yīng),MySQL 中的字段數(shù)據(jù)類型,VARCHAR和FLOAT 分別對(duì)應(yīng)Hive 中的string和int 類型.

    (2)為保證數(shù)據(jù)集內(nèi)容的充足性,系統(tǒng)輸出審計(jì)功能會(huì)檢查txt 文件的行數(shù),當(dāng)行數(shù)小于100 行時(shí),停止上傳數(shù)據(jù),并反饋數(shù)據(jù)機(jī)構(gòu)數(shù)據(jù)量過(guò)小,不符合要求.同時(shí)隨機(jī)抽取其中5 行記錄供管理員查看,審查其內(nèi)容是否符合數(shù)據(jù)商品的詳情描述,部分代碼如下:

    if [${BEFOR_VALUE}-lt 100 ];then echo "`date`-FAILURE count(*)=$BEFOR_VALUE"echo "FAILURE"

    (3)數(shù)據(jù)機(jī)構(gòu)向管理員提供Hive 表的分區(qū)字段,national_weather_data 表的分區(qū)字段是year和city.

    (4)后臺(tái)程序生成建表語(yǔ)句,如下所示,在Hive 集群中建立表結(jié)構(gòu).

    create table national_weather_data(year string,date string,city string,maximum_temperature int,minimum_temperature int,weather string,wind_direction string,wind_rating int,)PARTITIONED BY (`year` string,`city` string)ROW FORMAT DELIMITED FIELDS TERMINATED BY '|' NULL DEFINED AS ''STORED AS TEXTFILE;

    (5)執(zhí)行導(dǎo)數(shù)腳本,把txt 文件中保存的數(shù)據(jù)導(dǎo)入到Hive 集群中,執(zhí)行腳本時(shí)需要傳遞3 個(gè)參數(shù),table_name表名,year年份,city 城市.

    LOAD DATA LOCAL INPATH '${FILE_NAME}' OVERWRITE INTO TABLE ${table_name} partition (year='${YEAR}',city='${CITY }');"

    (6)數(shù)據(jù)集上傳結(jié)束后,為確保數(shù)據(jù)集上傳成功,系統(tǒng)審計(jì)功能會(huì)檢查上傳到Hive 中的數(shù)據(jù)集行數(shù),如果小于txt 文件的行數(shù),則向數(shù)據(jù)機(jī)構(gòu)反饋,數(shù)據(jù)上傳失敗.部分代碼如下:

    echo "hive table rows:$AFTER_VALUE"if [$AFTER_VALUE-ne $BEFOR_VALUE ];then echo "`date`-FAILURE:AFTER_VALUE(*)=$AFTER_VALUE<>BEFOR_VALUE(*)=$BEFOR_VALUE "echo "FAILURE"current_2=`date+%s`current_dura=`expr $current_2-$current_1`

    數(shù)據(jù)商城提供數(shù)據(jù)集的信息篩選功能,客戶可以根據(jù)數(shù)據(jù)集的字段選擇需要的數(shù)據(jù),去除無(wú)用的數(shù)據(jù)項(xiàng),如圖12所示.后臺(tái)系統(tǒng)會(huì)根據(jù)用戶選擇的字段生成HQL[24]語(yǔ)句,從Hive 集群中將相應(yīng)的數(shù)據(jù)導(dǎo)出到txt 文件中,之后用戶可以下載相應(yīng)的txt 文件.在商品支付方面,創(chuàng)客可以通過(guò)支付寶、微信、網(wǎng)銀等手段完成支付,這個(gè)過(guò)程類似淘寶、京東等網(wǎng)站商城.

    圖12 選擇需要的字段

    3.7 模塊企業(yè)注冊(cè)功能

    用戶注冊(cè)如果想要成為買家、賣家、創(chuàng)客等,就需要進(jìn)一步認(rèn)證.認(rèn)證通過(guò)后,用戶就擁有購(gòu)買、使用商品的權(quán)限,可以發(fā)布、管理商品,甚至成為一名平臺(tái)創(chuàng)客,申請(qǐng)創(chuàng)客空間資源,開發(fā)、測(cè)試、運(yùn)行應(yīng)用.認(rèn)證分為個(gè)人認(rèn)證和企業(yè)認(rèn)證.

    企業(yè)認(rèn)證需要用戶提供公司名稱、地址、三證合一號(hào)碼、營(yíng)業(yè)執(zhí)照副本,以及運(yùn)營(yíng)者姓名、身份證號(hào)、聯(lián)系方式、持證照正反面等信息,如圖13所示,如確認(rèn)用戶信息真實(shí)有效,提出申請(qǐng)后7 個(gè)工作日內(nèi)就會(huì)得到回復(fù).如被駁回,按照駁回原因,重新修改提交.

    圖13 企業(yè)認(rèn)證

    下面詳細(xì)介紹企業(yè)認(rèn)證功能的實(shí)現(xiàn).用戶點(diǎn)擊提交按鈕后,前端會(huì)調(diào)用bjmarketportal 項(xiàng)目中的企業(yè)認(rèn)證接口,接口地址是/api/v1/enterprisecertification,訪問(wèn)方式是POST,表單中的數(shù)據(jù)會(huì)以JSON 格式發(fā)送到后臺(tái).bjmarketportal 中實(shí)現(xiàn)企業(yè)認(rèn)證功能的代碼由Controller層、Service 層、Dao 層、Pojo (plain ordinary Java object)、Vo (value object)等幾部分組成,下面詳細(xì)介紹后臺(tái)企業(yè)認(rèn)證功能的實(shí)現(xiàn).

    Pojo:Pojo 類可方便開發(fā)人員使用數(shù)據(jù)庫(kù)中的數(shù)據(jù)表.通過(guò)MyBatis Generator 插件從MySQL 數(shù)據(jù)庫(kù)中生成企業(yè)認(rèn)證信息表對(duì)應(yīng)的Pojo 類—CorporateInformation.

    Vo:常用于業(yè)務(wù)層之間的數(shù)據(jù)傳遞,可以用于封裝從頁(yè)面表單提交的數(shù)據(jù).該模塊中Enterprise CertificationVo類用于封裝企業(yè)認(rèn)證表單數(shù)據(jù).

    Controller 層:接收客戶端的請(qǐng)求,然后調(diào)用Service層業(yè)務(wù)邏輯,獲取到數(shù)據(jù),傳遞數(shù)據(jù)給視圖.Corporate Information Controller 類對(duì)應(yīng)該模塊Controller 層代碼.類中使用@Autowired 注解實(shí)現(xiàn)Service 層Corporate Information Service 對(duì)象的自動(dòng)裝配;并創(chuàng)建enterprise Certification 方法實(shí)現(xiàn)企業(yè)認(rèn)證功能,通過(guò)@Request Mapping 注解,設(shè)置該方法的訪問(wèn)路徑/api/v1/user Center/enterprisecertification,訪問(wèn)方式是POST.

    Service 層:用于實(shí)現(xiàn)模塊中的業(yè)務(wù)邏輯Corporate-InformationService 類對(duì)應(yīng)該模塊的Service 層代碼,通過(guò)@Service 注解聲明其是一個(gè)Service 類,并自動(dòng)注冊(cè)到Spring 容器中;通過(guò)@Autowired 獲取Dao 層CorporateInformationMapper 對(duì)象;certification 方法實(shí)現(xiàn)企業(yè)認(rèn)證功能.

    Dao 層:負(fù)責(zé)模塊中數(shù)據(jù)庫(kù)操作,CorporateInformationMapper 類對(duì)應(yīng)該模塊中的Dao 層代碼,采用MyBatis 框架實(shí)現(xiàn),通過(guò)@Mapper 注解其是一個(gè)Dao層類,并交給Spring 容器管理,同時(shí)省去了mapper 映射文件的書寫.該模塊部分代碼如下:

    @Controller@RequestMapping(value="/mail/userCenter")public class CorporateInformationController extends BaseController<Object>{@Autowired private SandboxieService sandboxieService;@Autowired private CorporateInformationService corporateInformationService;@Autowired private DataShopService dataShopService;@RequestMapping(value="enterprisecertification",method=RequestMethod.POST)@ResponseBody public String enterpriseCertification(EnterpriseCertificationVo enterpriseCertificationVo,HttpServletResponse response) throws Exception {String enterpriseName=enterpriseCertificationVo.getEnterpriseName();

    if (corporateInformationService.isEnterprise(enterpriseName)) {…}…}

    4 結(jié)論與展望

    本文設(shè)計(jì)的大數(shù)據(jù)交易集市平臺(tái),通過(guò)向數(shù)據(jù)機(jī)構(gòu)提供公用的Hive 集群資源,實(shí)現(xiàn)數(shù)據(jù)交易集市不存儲(chǔ)數(shù)據(jù),數(shù)據(jù)由提供者存儲(chǔ)和管理,在商城發(fā)布數(shù)據(jù)商品的詳情信息、樣例數(shù)據(jù)供客戶查看,由數(shù)據(jù)代理獲取數(shù)據(jù)交給需求方,有效解決了數(shù)據(jù)交易中私有數(shù)據(jù)持有者擔(dān)心數(shù)據(jù)泄露,不愿意分享數(shù)據(jù)的問(wèn)題.同時(shí)設(shè)計(jì)出數(shù)據(jù)發(fā)布和服務(wù)代理請(qǐng)求數(shù)據(jù)、應(yīng)用的測(cè)試發(fā)布、應(yīng)用服務(wù)請(qǐng)求業(yè)務(wù)流程.并在此基礎(chǔ)上使用Spring MVC 框架,并集成了MyBatis、Swagger 等技術(shù)開發(fā)實(shí)現(xiàn)了大數(shù)據(jù)交易集市平臺(tái),利用Redis 解決系統(tǒng)在高并發(fā)下中性能下降問(wèn)題,采用基于RESTful 風(fēng)格的API 接口設(shè)計(jì),最后通過(guò)數(shù)據(jù)集購(gòu)買功能和企業(yè)認(rèn)證功能詳細(xì)介紹了項(xiàng)目的實(shí)現(xiàn),并且系統(tǒng)具有前后端分離、低耦合高內(nèi)聚以及易擴(kuò)展性.

    猜你喜歡
    商城集市交易
    熱鬧的集市
    探訪于山“相親集市”
    海峽姐妹(2018年12期)2018-12-23 02:39:20
    商城
    汽車之友(2017年6期)2017-04-26 10:08:21
    悅居商城
    悅居商城shop
    51,商城
    交易流轉(zhuǎn)應(yīng)有新規(guī)
    大宗交易
    熱鬧的集市
    《吃飯的交易》
    成人精品一区二区免费| 国产欧美日韩一区二区精品| 成年女人看的毛片在线观看| 成人一区二区视频在线观看| 精品免费久久久久久久清纯| 亚洲美女视频黄频| 欧美绝顶高潮抽搐喷水| 亚洲第一欧美日韩一区二区三区| 女生性感内裤真人,穿戴方法视频| 国产一级毛片七仙女欲春2| 亚洲精品456在线播放app | 成人午夜高清在线视频| 国产精品av视频在线免费观看| 久久国产精品影院| 久久伊人香网站| а√天堂www在线а√下载| 国产真人三级小视频在线观看| 天堂av国产一区二区熟女人妻| 色视频www国产| 亚洲黑人精品在线| 亚洲精品色激情综合| 国产免费一级a男人的天堂| 天堂av国产一区二区熟女人妻| av女优亚洲男人天堂| 国产高清视频在线观看网站| 精品电影一区二区在线| 亚洲av日韩精品久久久久久密| 一个人看的www免费观看视频| 国产探花在线观看一区二区| 老司机午夜十八禁免费视频| 热99在线观看视频| 白带黄色成豆腐渣| 国产激情偷乱视频一区二区| 亚洲精品456在线播放app | 亚洲片人在线观看| 又黄又粗又硬又大视频| 午夜精品久久久久久毛片777| 最新中文字幕久久久久| 不卡一级毛片| 99久久精品一区二区三区| 欧美中文日本在线观看视频| 亚洲内射少妇av| 亚洲成人中文字幕在线播放| 日韩欧美在线乱码| 国产 一区 欧美 日韩| 18禁裸乳无遮挡免费网站照片| 国产国拍精品亚洲av在线观看 | 中文资源天堂在线| 精品午夜福利视频在线观看一区| 熟女人妻精品中文字幕| 久久久国产精品麻豆| 日韩人妻高清精品专区| 久久精品亚洲精品国产色婷小说| 51国产日韩欧美| 久久精品综合一区二区三区| 国产高潮美女av| 欧美日韩国产亚洲二区| 美女高潮的动态| 综合色av麻豆| 日韩国内少妇激情av| 国产中年淑女户外野战色| 亚洲精品色激情综合| 中文字幕av成人在线电影| 国产 一区 欧美 日韩| 亚洲欧美日韩高清专用| 国产欧美日韩一区二区三| 在线视频色国产色| 欧美三级亚洲精品| 免费一级毛片在线播放高清视频| 99精品久久久久人妻精品| 在线观看美女被高潮喷水网站 | 亚洲天堂国产精品一区在线| 欧美中文日本在线观看视频| 国产精品野战在线观看| 在线十欧美十亚洲十日本专区| 日本成人三级电影网站| 久久国产乱子伦精品免费另类| 99热只有精品国产| 亚洲精品国产精品久久久不卡| 国产精品日韩av在线免费观看| 两个人视频免费观看高清| 亚洲成av人片免费观看| 性欧美人与动物交配| 精品久久久久久久久久久久久| 国产精品一区二区免费欧美| 天天一区二区日本电影三级| 欧美日韩黄片免| 亚洲电影在线观看av| 亚洲成人久久性| 好男人电影高清在线观看| 国产一区在线观看成人免费| 成年女人永久免费观看视频| 香蕉丝袜av| 欧美黑人巨大hd| 久久亚洲真实| 国产精品嫩草影院av在线观看 | 白带黄色成豆腐渣| 国产高清视频在线播放一区| 一a级毛片在线观看| 他把我摸到了高潮在线观看| 男女之事视频高清在线观看| 在线观看午夜福利视频| 亚洲人成伊人成综合网2020| 亚洲av成人精品一区久久| 免费av观看视频| 国内久久婷婷六月综合欲色啪| 国产av一区在线观看免费| 免费av观看视频| 夜夜看夜夜爽夜夜摸| 欧美av亚洲av综合av国产av| 国产欧美日韩精品亚洲av| 亚洲av一区综合| 日韩av在线大香蕉| xxxwww97欧美| 亚洲av成人精品一区久久| 国产伦在线观看视频一区| 特级一级黄色大片| 久久欧美精品欧美久久欧美| 国内揄拍国产精品人妻在线| 两个人视频免费观看高清| 亚洲欧美日韩高清专用| 欧美另类亚洲清纯唯美| 日韩精品中文字幕看吧| 又粗又爽又猛毛片免费看| 久久亚洲精品不卡| 观看美女的网站| 免费人成视频x8x8入口观看| 免费在线观看亚洲国产| 啦啦啦韩国在线观看视频| 色老头精品视频在线观看| 亚洲一区二区三区色噜噜| 无遮挡黄片免费观看| 亚洲精品粉嫩美女一区| 亚洲最大成人手机在线| 黄色丝袜av网址大全| 国产伦一二天堂av在线观看| 久久欧美精品欧美久久欧美| 国内精品美女久久久久久| 日韩免费av在线播放| 国产精品久久久久久精品电影| 琪琪午夜伦伦电影理论片6080| 成人特级av手机在线观看| 久久久久国内视频| 法律面前人人平等表现在哪些方面| 日韩欧美在线乱码| 老熟妇仑乱视频hdxx| 精品乱码久久久久久99久播| 老鸭窝网址在线观看| 首页视频小说图片口味搜索| 亚洲午夜理论影院| 欧美一区二区精品小视频在线| 国产不卡一卡二| 69av精品久久久久久| 亚洲av不卡在线观看| 在线观看舔阴道视频| 亚洲va日本ⅴa欧美va伊人久久| 色哟哟哟哟哟哟| 悠悠久久av| 久久精品国产亚洲av香蕉五月| 久久久久久久精品吃奶| 欧美大码av| 久久国产精品影院| 99在线人妻在线中文字幕| 在线观看日韩欧美| 搡老熟女国产l中国老女人| 精品人妻偷拍中文字幕| 琪琪午夜伦伦电影理论片6080| 欧美成人a在线观看| 很黄的视频免费| 免费在线观看日本一区| 91字幕亚洲| 免费av毛片视频| 天天躁日日操中文字幕| 欧美极品一区二区三区四区| 久久精品国产亚洲av涩爱 | 亚洲美女黄片视频| 一个人免费在线观看电影| 国内精品久久久久久久电影| 午夜视频国产福利| 国产精品影院久久| 极品教师在线免费播放| 少妇的丰满在线观看| 久久久久久久久中文| 国产免费一级a男人的天堂| 18禁国产床啪视频网站| 色精品久久人妻99蜜桃| 国内久久婷婷六月综合欲色啪| 又爽又黄无遮挡网站| a级一级毛片免费在线观看| 欧美+日韩+精品| 久久国产精品影院| 久久精品国产亚洲av香蕉五月| 国产亚洲欧美在线一区二区| 欧美成狂野欧美在线观看| 在线播放国产精品三级| 久久精品国产综合久久久| 亚洲中文字幕一区二区三区有码在线看| 亚洲乱码一区二区免费版| 十八禁网站免费在线| 亚洲黑人精品在线| 日本在线视频免费播放| 日韩精品中文字幕看吧| 少妇人妻一区二区三区视频| 偷拍熟女少妇极品色| 给我免费播放毛片高清在线观看| 国产探花在线观看一区二区| 在线观看免费视频日本深夜| 亚洲美女黄片视频| 久久久精品欧美日韩精品| 国产淫片久久久久久久久 | 欧美乱妇无乱码| 丰满人妻熟妇乱又伦精品不卡| 色老头精品视频在线观看| 日韩欧美精品v在线| or卡值多少钱| 国产69精品久久久久777片| 一区二区三区国产精品乱码| 久久国产精品影院| 色噜噜av男人的天堂激情| 舔av片在线| 观看美女的网站| 毛片女人毛片| 久久国产精品人妻蜜桃| 国产精品一区二区三区四区免费观看 | 欧洲精品卡2卡3卡4卡5卡区| 熟妇人妻久久中文字幕3abv| 日本与韩国留学比较| 综合色av麻豆| 91麻豆av在线| 精品不卡国产一区二区三区| 一二三四社区在线视频社区8| 99精品久久久久人妻精品| 99久久精品一区二区三区| 国产精品影院久久| 亚洲国产欧美人成| 18禁裸乳无遮挡免费网站照片| 色尼玛亚洲综合影院| 亚洲av中文字字幕乱码综合| 国产精品1区2区在线观看.| 日韩欧美国产一区二区入口| 久久精品综合一区二区三区| 一本一本综合久久| www.熟女人妻精品国产| 内射极品少妇av片p| 国产精品综合久久久久久久免费| 波多野结衣高清作品| 日本 欧美在线| 少妇的丰满在线观看| 99久久精品一区二区三区| 国语自产精品视频在线第100页| 亚洲精品在线观看二区| 黄色女人牲交| 制服丝袜大香蕉在线| 一本久久中文字幕| 97超级碰碰碰精品色视频在线观看| 欧美日韩亚洲国产一区二区在线观看| 啦啦啦韩国在线观看视频| 又紧又爽又黄一区二区| eeuss影院久久| 亚洲欧美一区二区三区黑人| 国产精品永久免费网站| 波野结衣二区三区在线 | 亚洲五月婷婷丁香| 尤物成人国产欧美一区二区三区| 日韩精品中文字幕看吧| 国产精品免费一区二区三区在线| 青草久久国产| 淫妇啪啪啪对白视频| 亚洲精品在线美女| АⅤ资源中文在线天堂| 非洲黑人性xxxx精品又粗又长| 免费av观看视频| 亚洲国产精品sss在线观看| 一夜夜www| 99热这里只有精品一区| 香蕉久久夜色| 欧美在线黄色| 毛片女人毛片| 亚洲va日本ⅴa欧美va伊人久久| 国产三级在线视频| 变态另类丝袜制服| 日本撒尿小便嘘嘘汇集6| 天天一区二区日本电影三级| 日韩欧美三级三区| 女警被强在线播放| 老司机深夜福利视频在线观看| 91字幕亚洲| 制服丝袜大香蕉在线| 99久久综合精品五月天人人| 999久久久精品免费观看国产| 国产真人三级小视频在线观看| 狠狠狠狠99中文字幕| 一本精品99久久精品77| 国产乱人视频| 一本久久中文字幕| 久久精品国产综合久久久| 国产真人三级小视频在线观看| 真人一进一出gif抽搐免费| 熟妇人妻久久中文字幕3abv| 日韩成人在线观看一区二区三区| 久久久色成人| av天堂中文字幕网| 搡女人真爽免费视频火全软件 | eeuss影院久久| 变态另类丝袜制服| 91麻豆av在线| 国产一级毛片七仙女欲春2| 色综合站精品国产| 精品久久久久久久久久久久久| 夜夜看夜夜爽夜夜摸| 宅男免费午夜| 51国产日韩欧美| 国产成+人综合+亚洲专区| 亚洲精品日韩av片在线观看 | 欧美黑人欧美精品刺激| 老司机深夜福利视频在线观看| netflix在线观看网站| 欧美精品啪啪一区二区三区| 国产乱人视频| 在线免费观看不下载黄p国产 | 亚洲av第一区精品v没综合| 日本a在线网址| 天堂√8在线中文| 18禁裸乳无遮挡免费网站照片| 久久久久免费精品人妻一区二区| 在线免费观看的www视频| 成人无遮挡网站| 熟女少妇亚洲综合色aaa.| 亚洲午夜理论影院| 中文字幕人妻丝袜一区二区| 少妇人妻精品综合一区二区 | 欧美在线一区亚洲| 久久久精品大字幕| 日本 av在线| 国产亚洲精品久久久com| 天天一区二区日本电影三级| 久久香蕉国产精品| 国产精品亚洲av一区麻豆| 国产免费一级a男人的天堂| 我要搜黄色片| 国产av麻豆久久久久久久| 国产成人系列免费观看| 午夜激情欧美在线| 日韩精品中文字幕看吧| 俄罗斯特黄特色一大片| 真实男女啪啪啪动态图| 国产精品香港三级国产av潘金莲| 日韩亚洲欧美综合| 在线a可以看的网站| 波多野结衣高清作品| 亚洲人成电影免费在线| 国产精品1区2区在线观看.| 亚洲国产欧洲综合997久久,| 亚洲久久久久久中文字幕| 亚洲成人久久性| 午夜老司机福利剧场| 亚洲av中文字字幕乱码综合| 婷婷六月久久综合丁香| 亚洲人成网站在线播| 亚洲中文字幕日韩| a在线观看视频网站| 午夜日韩欧美国产| 丰满乱子伦码专区| 国产成人啪精品午夜网站| 国产午夜精品久久久久久一区二区三区 | 久久婷婷人人爽人人干人人爱| 免费在线观看亚洲国产| 国产老妇女一区| 男女之事视频高清在线观看| 国产综合懂色| 国产男靠女视频免费网站| 青草久久国产| 又黄又爽又免费观看的视频| 成人午夜高清在线视频| 看黄色毛片网站| 一二三四社区在线视频社区8| 国产v大片淫在线免费观看| 日韩中文字幕欧美一区二区| www.www免费av| 国产精品电影一区二区三区| 亚洲精品日韩av片在线观看 | 亚洲成a人片在线一区二区| 欧美一区二区精品小视频在线| 天美传媒精品一区二区| 在线观看舔阴道视频| 丰满的人妻完整版| 久久久久精品国产欧美久久久| 亚洲精品亚洲一区二区| 18禁黄网站禁片午夜丰满| 国产毛片a区久久久久| 精品久久久久久久毛片微露脸| 日本在线视频免费播放| 欧美在线黄色| 色视频www国产| 精品人妻偷拍中文字幕| 一本久久中文字幕| 国产激情欧美一区二区| 国产精品,欧美在线| 日韩有码中文字幕| 国内精品美女久久久久久| 日本免费a在线| 好看av亚洲va欧美ⅴa在| 欧美黑人欧美精品刺激| 午夜精品一区二区三区免费看| 亚洲成人精品中文字幕电影| 成人鲁丝片一二三区免费| 亚洲精品在线美女| 高清毛片免费观看视频网站| 欧美乱码精品一区二区三区| 久久久精品欧美日韩精品| 欧美大码av| 麻豆成人av在线观看| 啪啪无遮挡十八禁网站| 一进一出抽搐动态| 91久久精品电影网| 精品久久久久久久毛片微露脸| 免费人成在线观看视频色| 少妇丰满av| 俺也久久电影网| 国产探花极品一区二区| 97超视频在线观看视频| 高潮久久久久久久久久久不卡| 好男人电影高清在线观看| 亚洲人成电影免费在线| 全区人妻精品视频| 欧美成人a在线观看| 香蕉久久夜色| 欧美日韩乱码在线| 小蜜桃在线观看免费完整版高清| 成人特级av手机在线观看| 国产高清videossex| 久久亚洲精品不卡| 国产精品亚洲av一区麻豆| 亚洲成人精品中文字幕电影| 久久久精品大字幕| 亚洲真实伦在线观看| 午夜精品在线福利| 久久久久国产精品人妻aⅴ院| 亚洲欧美一区二区三区黑人| 国产精品野战在线观看| 久久久国产精品麻豆| 小蜜桃在线观看免费完整版高清| 日韩 欧美 亚洲 中文字幕| 一本一本综合久久| 午夜福利在线观看免费完整高清在 | 欧美一区二区精品小视频在线| 久久性视频一级片| 亚洲av二区三区四区| 啪啪无遮挡十八禁网站| 国产亚洲精品av在线| 欧美一区二区亚洲| 国产伦精品一区二区三区四那| 变态另类丝袜制服| 两个人看的免费小视频| 五月玫瑰六月丁香| 熟女少妇亚洲综合色aaa.| 亚洲乱码一区二区免费版| 国产精华一区二区三区| 国内精品美女久久久久久| 国产高清有码在线观看视频| 久久精品国产综合久久久| 天堂动漫精品| 日日摸夜夜添夜夜添小说| 99热只有精品国产| 国产精品野战在线观看| 日韩成人在线观看一区二区三区| 美女cb高潮喷水在线观看| 欧美日韩亚洲国产一区二区在线观看| 中国美女看黄片| 亚洲国产精品久久男人天堂| 国产精品1区2区在线观看.| 老司机深夜福利视频在线观看| 99久久久亚洲精品蜜臀av| 欧美一区二区精品小视频在线| 黄色女人牲交| 亚洲aⅴ乱码一区二区在线播放| 一进一出抽搐动态| a级一级毛片免费在线观看| 亚洲美女黄片视频| 久久久久久久精品吃奶| 一本精品99久久精品77| 好男人电影高清在线观看| 欧美日韩乱码在线| 国产高清videossex| 久久欧美精品欧美久久欧美| 亚洲av第一区精品v没综合| 久久国产精品人妻蜜桃| 精华霜和精华液先用哪个| 性色av乱码一区二区三区2| 老师上课跳d突然被开到最大视频 久久午夜综合久久蜜桃 | 国产伦人伦偷精品视频| 精品久久久久久成人av| 精品电影一区二区在线| 久久6这里有精品| 精品久久久久久成人av| 国产一级毛片七仙女欲春2| 亚洲av美国av| 成年免费大片在线观看| 少妇高潮的动态图| 国产精品一区二区三区四区久久| 在线免费观看不下载黄p国产 | aaaaa片日本免费| 全区人妻精品视频| 色精品久久人妻99蜜桃| 国产老妇女一区| 亚洲国产精品成人综合色| 中文字幕高清在线视频| 国产一区二区三区在线臀色熟女| 在线观看舔阴道视频| 久久精品综合一区二区三区| 久久精品国产亚洲av涩爱 | 午夜福利免费观看在线| 色综合婷婷激情| av国产免费在线观看| 久久伊人香网站| 亚洲美女视频黄频| 欧美一级a爱片免费观看看| 一进一出好大好爽视频| 免费观看精品视频网站| 亚洲国产欧洲综合997久久,| 少妇的逼水好多| 亚洲熟妇熟女久久| 国产亚洲精品综合一区在线观看| 免费高清视频大片| 亚洲一区二区三区不卡视频| 偷拍熟女少妇极品色| 一个人看的www免费观看视频| 亚洲av一区综合| 亚洲专区国产一区二区| 久久6这里有精品| 午夜两性在线视频| 最近最新免费中文字幕在线| 精品一区二区三区人妻视频| 国产中年淑女户外野战色| 国产男靠女视频免费网站| 熟女人妻精品中文字幕| 一级毛片高清免费大全| 成人三级黄色视频| 欧美av亚洲av综合av国产av| 国产毛片a区久久久久| 久久精品影院6| 国产成人a区在线观看| 在线观看一区二区三区| 精品日产1卡2卡| 亚洲精品在线观看二区| 久久久国产成人免费| 国产精品乱码一区二三区的特点| 国产私拍福利视频在线观看| 色av中文字幕| 国产精品综合久久久久久久免费| 俺也久久电影网| 又黄又粗又硬又大视频| 国产免费av片在线观看野外av| 亚洲av电影不卡..在线观看| 美女大奶头视频| 国产精品亚洲av一区麻豆| 久久久久久九九精品二区国产| 美女cb高潮喷水在线观看| av天堂中文字幕网| 最后的刺客免费高清国语| 国产aⅴ精品一区二区三区波| 国产精品久久久久久亚洲av鲁大| 国产淫片久久久久久久久 | 国产一区二区三区在线臀色熟女| 男女那种视频在线观看| 久久久久久九九精品二区国产| 在线观看免费午夜福利视频| 亚洲成人免费电影在线观看| 国产精品久久视频播放| 特级一级黄色大片| 欧美一区二区国产精品久久精品| 一级毛片女人18水好多| 国产精品久久久人人做人人爽| 午夜福利成人在线免费观看| 每晚都被弄得嗷嗷叫到高潮| 亚洲欧美日韩卡通动漫| 免费一级毛片在线播放高清视频| 久久中文看片网| 国产高清videossex| 18禁黄网站禁片免费观看直播| 国产精品美女特级片免费视频播放器| 亚洲成人久久性| 18禁裸乳无遮挡免费网站照片| 色老头精品视频在线观看| 丰满乱子伦码专区| 精品99又大又爽又粗少妇毛片 | 一边摸一边抽搐一进一小说| 色老头精品视频在线观看| 亚洲av日韩精品久久久久久密| 91麻豆av在线| 美女免费视频网站| 成人性生交大片免费视频hd| 免费av观看视频| 久久精品影院6| 亚洲国产精品久久男人天堂| 成人三级黄色视频| 在线免费观看不下载黄p国产 | 成年版毛片免费区| 丝袜美腿在线中文| 久久久久免费精品人妻一区二区| 深爱激情五月婷婷| 国产av麻豆久久久久久久| 18美女黄网站色大片免费观看| 脱女人内裤的视频| 亚洲国产欧洲综合997久久,| www.熟女人妻精品国产| av天堂在线播放| 在线免费观看不下载黄p国产 | 国产乱人伦免费视频| 亚洲欧美日韩东京热| 制服丝袜大香蕉在线| 天堂av国产一区二区熟女人妻| 在线免费观看的www视频| 亚洲精品影视一区二区三区av| 色综合婷婷激情|