色哟哟视频在线观看-色哟哟视频在线-色哟哟欧美15最新在线-色哟哟免费在线观看-国产l精品国产亚洲区在线观看-国产l精品国产亚洲区久久

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

【開發(fā)者說】鴻蒙原生應(yīng)用開發(fā)——分布式數(shù)據(jù)對象

HarmonyOS開發(fā)者 ? 來源:HarmonyOS開發(fā)者 ? 作者:HarmonyOS開發(fā)者 ? 2023-12-07 21:40 ? 次閱讀
# 開發(fā)者說 #

【開發(fā)者說】欄目是為HarmonyOS開發(fā)者提供的展示和分享平臺,在這里,大家可以發(fā)表自己的技術(shù)洞察和見解,也可以展示自己的開發(fā)心得和成果。

歡迎大家積極投稿,后臺回復(fù)【投稿】,即可獲得投稿渠道。期待你們的分享~

01

什么是分布式數(shù)據(jù)對象

可信組網(wǎng)環(huán)境下,多個相互組網(wǎng)認證的設(shè)備將各自創(chuàng)建的對象加入同一個sessionId,使得加入的多個數(shù)據(jù)對象之間可以同步數(shù)據(jù),也就是說,當某一數(shù)據(jù)對象屬性發(fā)生變更時,其他數(shù)據(jù)對象會檢測到這一變更,同時將自身屬性更新。

此時,該sessionId下的所有數(shù)據(jù)對象屬性相同,這樣的數(shù)據(jù)對象稱之為分布式數(shù)據(jù)對象。此外,分布式數(shù)據(jù)對象可以被動退出sessionId,當分布式數(shù)據(jù)對象退出sessionId后,該對象將檢測不到其他對象的變更。

02

分布式數(shù)據(jù)對象能力

1、分布式數(shù)據(jù)對象創(chuàng)建2、分布式數(shù)據(jù)對象查詢3、分布式數(shù)據(jù)對象修改4、分布式數(shù)據(jù)對象刪除5、分布式數(shù)據(jù)對象保存6、分布式數(shù)據(jù)對象訂閱(數(shù)據(jù)變更,上下線)

7、分布式數(shù)據(jù)對象加入、退出分布式組網(wǎng)

03

前提準備

1、開發(fā)工具:DevEco Studio 3.1.0.501

2、API9

3、SDK版本3.2.12.504

創(chuàng)建一個新的項目

新建項目,選擇API9版本,stage模型。

wKgZomVys6-AG0_1AAEXQ0yjzBI034.png05

權(quán)限申請

1、使用到的權(quán)限
  • ohos.permission.DISTRIBUTED_DATASYNC
  • 允許不同設(shè)備間的數(shù)據(jù)交換
  • 權(quán)限級別:normal
  • 授權(quán)方式:user_grant
  • ACL使能:TRUE

2、配置文件申明

首先,在項目的模塊級目錄下找到并打開module.json5文件,如下圖:

wKgZomVys6-Ac2AbAANDz2HtWlk721.png

在module下的對象里添加如下申明:

wKgZomVys6-ADikuAAB7_cWlh4w151.png

此時,配置文件中的權(quán)限申明就完成了,但是,此時我們還不能獲得這些權(quán)限。由于ohos.permission.DISTRIBUTED_DATASYNC權(quán)限是ACL使能為TRUE的權(quán)限,需要在簽名工具文件中說明一下。

如何找到對應(yīng)的簽名工具文件呢?我們在安裝DevEcoStudio的時候是下載好了OpenHarmony的SDK的,此時在OpenHarmony文件夾中,打開 “SdkOpenHarmony SDK版本 oolchainslib” 該路徑,此時在lib文件夾中,咱們可以找到兩個json文件,分別為UnsgnedDebugProfileTemplate.json和UnsgnedReleasedProfileTemplate.json,點擊并打開這兩個文件,添加如下權(quán)限:

wKgaomVys6-AEVe-AAB8i3XVu2I513.png

3、權(quán)限申請編碼

在申請ohos.permission.DISTRIBUTED_DATASYNC權(quán)限時,其文檔中將其標注為用戶手動授權(quán)的權(quán)限,此時需要我們動態(tài)申請權(quán)限,在項目中,我們新建一個ets文件,我這里取名為RequestPermission.ets。

首先,導(dǎo)入以下包:

import abilityAccessCtrl, { Permissions } from '@ohos.abilityAccessCtrl';
import bundleManager from '@ohos.bundle.bundleManager';
importcommonfrom'@ohos.app.ability.common';

(左右滑動查看更多)

獲取訪問控制模塊對象實例:

let atManager = abilityAccessCtrl.createAtManager();

(左右滑動查看更多

編寫如下方法(這里使用的是異步函數(shù)):

export async function checkAccessTokenID(permission: Array) {
  // 獲取應(yīng)用程序的accessTokenID
  let tokenId: number;
  let grantStatus: Array = []
  try {
    let bundleInfo: bundleManager.BundleInfo = await bundleManager.getBundleInfoForSelf(bundleManager.BundleFlag.GET_BUNDLE_INFO_WITH_APPLICATION);
    let appInfo: bundleManager.ApplicationInfo = bundleInfo.appInfo;
    tokenId = appInfo.accessTokenId;
  } catch (err) {
    console.error(`getBundleInfoForSelf failed, code is ${err.code}, message is ${err.message}`);
  }
  // 校驗應(yīng)用是否被授予權(quán)限,若申請多個權(quán)限,建議循環(huán)檢查多個權(quán)限
  for (let index = 0;index < permission.length; index++) {
    try {
      grantStatus.push(await atManager.checkAccessToken(tokenId, permission[index]))
    } catch (err) {
      console.error(`checkAccessToken failed, code is ${err.code}, message is ${err.message}`);
    }
  }
  return grantStatus;
}


export async function checkPermission(context: common.UIAbilityContext, permissions: Array) {
  let grantStatus: Array = await checkAccessTokenID(permissions)
  for (let i = 0; i < grantStatus.length; i++) {
    if (grantStatus[i] === abilityAccessCtrl.GrantStatus.PERMISSION_GRANTED) {
      console.info(`${permissions[i].toString()} 已授權(quán)`)
    } else {
      //申請權(quán)限
      console.info('開始向用戶申請權(quán)限')
      requestPermissionFromUser(context, permissions)
    }
  }
}
export async function requestPermissionFromUser(context: common.UIAbilityContext, permissions: Array) {
  // requestPermissionsFromUser會判斷權(quán)限的授權(quán)狀態(tài)來決定是否喚起彈窗
  atManager.requestPermissionsFromUser(context, permissions).then((data) => {
    let grantStatus: Array<number> = data.authResults
    let length: number = grantStatus.length
    for (let i = 0;i < length; i++) {
      if (grantStatus[i] === 0) {
        // 用戶授權(quán),可以繼續(xù)訪問目標操作
        console.info(`${permissions[i].toString()} 權(quán)限申請成功`)
      } else {
        // 用戶拒絕授權(quán),提示用戶必須授權(quán)才能訪問當前頁面的功能,并引導(dǎo)用戶到系統(tǒng)設(shè)置中打開相應(yīng)的權(quán)限
        console.info(`${permissions[i].toString()} 權(quán)限申請被用戶拒絕`)
      }
    }
    // 授權(quán)成功
  })
}

(左右滑動查看更多

此時,我們申請權(quán)限的方法就算編寫完成了,在應(yīng)用入口,即EntryAbility.ts文件中的

onCreate(want: Want, launchParam: AbilityConstant.LaunchParam)

方法中回調(diào)權(quán)限申請函數(shù):

requestPermissionFromUser(this.context,PERMISSIONS)

其中,PERMISSIONS定義如下:

const

PERMISSIONS:Array=['ohos.permission.DISTRIBUTED_DATASYNC']

到此,我們的權(quán)限申請就算完完全全完成啦,當用戶第一次安裝并打開應(yīng)用的時候,應(yīng)用會向用戶通過彈窗形式申請權(quán)限,用戶點擊授權(quán)即可賦予應(yīng)用相應(yīng)的權(quán)限啦~06

上手分布式數(shù)據(jù)對象代碼開發(fā)

登錄了同一華為帳號的HarmonyOS設(shè)備已經(jīng)默認了進行了組網(wǎng)認證,所以在進行分布式數(shù)據(jù)對象開發(fā)之前無需再進行多設(shè)備組網(wǎng)認證這一階段的開發(fā),開發(fā)變得相對簡單了起來。

首先,咱們制作一個簡易UI界面(UI界面僅供參考),如下圖所示:

wKgZomVys6-ADbPyAACVnGtFZXo950.png

相信對于有HarmonyOS開發(fā)經(jīng)驗的小伙伴們來說這樣的UI界面制作并不困難,其中紅色圓點、綠色圓點為設(shè)備狀態(tài),當設(shè)備狀態(tài)發(fā)生改變?nèi)缦戮€時,顏色變?yōu)榧t色,UI界面代碼如下:

import router from '@ohos.router'
import { DistributedDeviceManageFunc } from '../modules/DistributedDeviceManager/DistributedDeviceManagerFunctions'
import DistributedObjectFunc from '../modules/DistributedObject/DistributedObjectFunctions'
import { ContinuationDeviceManagerDialog } from '../view/ContinuationDeviceManagerDialog'
import { DistributedDeviceManagerDialog } from '../view/DistributedDeviceManagerDialog'


AppStorage.SetOrCreate('distributedDeviceList', [])
AppStorage.SetOrCreate('message', '分布式數(shù)據(jù)對象Demo測試')
AppStorage.SetOrCreate('statusColor', '#ff4fc100')
AppStorage.SetOrCreate('distributedColor', '#ffff0000')


@Entry
@Component
struct DistributedObjectDemo {
  @StorageLink('message') message: string = ''
  @StorageLink('statusColor') statusColor: string = ''
  @StorageLink('distributedColor') distributedColor: string = ''
  @StorageLink('distributedObj') distributedObj: DistributedObjectFunc = new DistributedObjectFunc()


  @Builder
  navigationTitle() {
    Row({ space: '10vp' }) {
      Button({ type: ButtonType.Normal }) {
        Image($rawfile('ic_public_back.svg'))
          .size({
            width: '24vp',
            height: '24vp'
          })
      }
      .width('36vp')
      .height('36vp')
      .backgroundColor(Color.White)
      .borderRadius('10vp')
      .onClick(() => {
        DistributedDeviceManageFunc.release()
        router.back()
      })


      Text('分布式數(shù)據(jù)對象測試')
        .fontWeight(FontWeight.Bold)
        .fontSize('20vp')
      Blank()
      Button({ type: ButtonType.Normal }) {
        Image($rawfile('ic_public_connection_filled.svg'))
          .size({
            width: '24vp',
            height: '24vp'
          })
      }
      .width('36vp')
      .height('36vp')
      .backgroundColor(Color.White)
      .borderRadius('10vp')
      .onClick(() => {
        this.distributedDeviceManagerDialogController.open()
      })
    }
    .padding('5vp')
    .width('90%')
  }


  build() {
    Navigation() {
      Column({ space: '20vp' }) {
        Row({ space: '20vp' }) {
          Text(`設(shè)備狀態(tài)`)
            .fontSize('20vp')
            .fontWeight(FontWeight.Bold)
          Circle()
            .width('25vp')
            .height('25vp')
            .fill(this.statusColor)
        }


        Row({ space: '20vp' }) {
          Text(`對端設(shè)備狀態(tài)`)
            .fontSize('20vp')
            .fontWeight(FontWeight.Bold)
          Circle()
            .width('25vp')
            .height('25vp')
            .fill(this.distributedColor)
        }


        Text(`SessionID:${this.distributedObj.getSessionId()}`)
          .fontSize('20vp')
          .fontWeight(FontWeight.Bold)
        Text(this.message)
          .fontSize('20vp')
          .fontWeight(FontWeight.Bold)
          .maxLines(2)
        Button('保存分布式數(shù)據(jù)對象')
          .buttonStyles()
          .onClick(() => {
            this.distributedObj.saveDistributedObject()
          })
        Button('修改分布式數(shù)據(jù)對象')
          .buttonStyles()
          .onClick(() => {
            this.distributedObj.updateDistributedObject()
          })
        Button('退出組網(wǎng)')
          .buttonStyles()
          .onClick(() => {
            this.distributedObj.exit()
            router.back()
          })
      }
      .width('100%')
    }
    .width('100%')
    .height('100%')
    .mode(NavigationMode.Auto)
    .titleMode(NavigationTitleMode.Mini)
    .hideBackButton(true)
    .title(this.navigationTitle())
  }
}


@Extend(Button) function buttonStyles() {
  .fontSize('20vp')
  .width('60%')
  .height('50vp')
}

(左右滑動查看更多

現(xiàn)在,我們的頁面制作就完成啦,下面開始重頭戲——分布式數(shù)據(jù)對象開發(fā)流程

1、導(dǎo)入模塊


	
import distributedObject from '@ohos.data.distributedDataObject'

(左右滑動查看更多

2、初始化distributedObject. DataObject對象

定義一個distributedObject. DataObject類型的變量。


	
mDistributedObject: distributedObject.DataObject

(左右滑動查看更多

調(diào)用distributedObject. Create()函數(shù)創(chuàng)建一個distributedObject. DataObject對象,并將其返回給定義的變量mDistributedObject。


	
this.mDistributedObject = distributedObject.create(globalThis.context, {
  name: 'jack',
  age: 18,
  isVis: false
})

(左右滑動查看更多

在create()方法中存在兩個參數(shù),context和resource,context的類型為Context,resource類型為object,在這里我是在entryAbility.ts文件下的onWindowStageCreate()方法里面定義了一個全局變量globalThis.context。


	
globalThis.context = this.context

(左右滑動查看更多

3、設(shè)置組網(wǎng)sessionId


	
this.mDistributedObject.setSessionId(this.mSessionId)

(左右滑動查看更多

在setSessionId()函數(shù)中,參數(shù)sessionId為string類型,表示分布式對象組網(wǎng)唯一標識符,設(shè)置同步的sessionId,當可信組網(wǎng)中有多個設(shè)備時,多個設(shè)備間的對象如果設(shè)置為同一個sessionId,就能自動同步。

4、開啟設(shè)備狀態(tài)監(jiān)聽

globalThis.statusCallback = (sessionId: string, networkId: string, status: string) => {
  AppStorage.Set('message', `組網(wǎng)設(shè)備狀況變更,id:${sessionId} status:${status} networkId:${networkId}`)
  if (status == 'online') {
    AppStorage.Set('distributedColor', '#ff4fc100')
  } else if (status == 'offline') {
    AppStorage.Set('distributedColor', '#ffff0000')
  }
}
this.mDistributedObject.on("status",globalThis.statusCallback)

(左右滑動查看更多

(sessionId: string,networkId: string, status: string)為callback回調(diào)函數(shù)返回的值,我們可以使用這些返回值判斷設(shè)備上下線狀態(tài),其中status參數(shù)返回值為online或者offline,表示設(shè)備對端設(shè)備上下線。

5、開啟分布式數(shù)據(jù)對象同步監(jiān)聽

globalThis.changeCallback = (sessionId: string, fields: Array<string>) => {
  console.info('分布式數(shù)據(jù)對象發(fā)生變化')
  if (fields != null && fields != undefined) {
    AppStorage.Set('message', `data change:${fields} sessionId:${sessionId}`)
  }
}
this.mDistributedObject.on("change",globalThis.changeCallback)

(左右滑動查看更多

當同一組網(wǎng)內(nèi)分布式數(shù)據(jù)對象發(fā)生改變時,同一組網(wǎng)中的所有分布式數(shù)據(jù)對象同步發(fā)生變化,變化后的值為某一分布式數(shù)據(jù)對象改變后的值(sessionId: string, fields: Array)為callback回調(diào)函數(shù)返回值,其中,sessionId為組網(wǎng)唯一標識符,field為分布式數(shù)據(jù)對象的數(shù)據(jù)變更列表。

此時此刻,分布式數(shù)據(jù)對象就基本上開發(fā)完成啦。

如果有小伙伴想要修改分布式數(shù)據(jù)對象的屬性,可以直接修改


	
// @ts-ignore
this.mDistributedObject.name = 'lucy'
// @ts-ignore
this.mDistributedObject.age=25

(左右滑動查看更多

注意:根據(jù)當前版本IDE的編碼插件情況,不能直接寫this.mDistributedObject.age = 25,此時咱們需要加上//@ts-ignore就可以啦。

最后,使用完分布式數(shù)據(jù)對象后大家要記得釋放資源哦(注銷所有監(jiān)聽,退出組網(wǎng)sessionId,將分布式數(shù)據(jù)對象設(shè)置為空值)


	
this.mDistributedObject.off("change")
this.mDistributedObject.off("status")
this.mDistributedObject.setSessionId()
this.mDistributedObject = null
this.mSessionId=null

(左右滑動查看更多

如果有小伙伴有兩部或兩部以上的華為設(shè)備,可以將程序燒錄到設(shè)備中,體驗一下分布式數(shù)據(jù)對象能力的快樂~


聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學習之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 應(yīng)用開發(fā)
    +關(guān)注

    關(guān)注

    0

    文章

    58

    瀏覽量

    9357
  • HarmonyOS
    +關(guān)注

    關(guān)注

    79

    文章

    1973

    瀏覽量

    30143
收藏 人收藏

    評論

    相關(guān)推薦

    鴻蒙千帆起】《開心消消樂》完成鴻蒙原生應(yīng)用開發(fā),創(chuàng)新多端聯(lián)動用戶體驗

    更優(yōu)質(zhì)的用戶體驗,基于強大的 AI 能力還可以實現(xiàn)精準識別、精確投放,為伙伴提供新流量,并共享全場景服務(wù)分發(fā),助力生態(tài)共贏。數(shù)據(jù)顯示,截至今年 8 月份,鴻蒙生態(tài)的設(shè)備數(shù)已超過 7 億,鴻蒙生態(tài)
    發(fā)表于 01-03 10:22

    HarmonyOS SDK,助力開發(fā)者打造煥然一新的鴻蒙原生應(yīng)用

    六大領(lǐng)域的開發(fā)能力,為開發(fā)者帶來簡潔、高效的開發(fā)體驗,開發(fā)者只需通過 API 調(diào)用即可實現(xiàn)豐富的鴻蒙
    發(fā)表于 01-19 10:31

    鴻蒙開發(fā)者預(yù)覽版如何?

    原生智能、原生互聯(lián),6大極致原生體驗。 我初步閱讀了鴻蒙的源碼后,基本上可以確定是全自研底座,已經(jīng)看不到Android的身影了。作為開發(fā)者
    發(fā)表于 02-17 21:54

    華為鴻蒙—時代的開啟

    總線技術(shù)”通過公共通信平臺,分布式數(shù)據(jù)管理,分布式能力調(diào)度和虛擬外設(shè)四大能力。將相應(yīng)分布式應(yīng)用的底層技術(shù)實現(xiàn)難度對應(yīng)用開發(fā)者屏蔽,使
    發(fā)表于 09-03 11:19

    HarmonyOS應(yīng)用開發(fā)-分布式設(shè)計

    不同終端設(shè)備之間的極速連接、硬件協(xié)同、資源共享,為用戶提供最佳的場景體驗。分布式設(shè)計指南可以幫助應(yīng)用開發(fā)者了解如何充分發(fā)揮“One Super Device”的能力,提供獨特的跨設(shè)備交互體驗。說明:本設(shè)計指南后續(xù)舉例中將包括手機、智慧屏、手表等多種設(shè)備,其中手機均指 EM
    發(fā)表于 09-22 17:11

    HarmonyOS分布式數(shù)據(jù)庫,為啥這么牛?

    HarmonyOS 2.0 重要的三大核心技術(shù)底座之一:HarmonyOS 分布式數(shù)據(jù)管理平臺,也同步對開發(fā)者進行了細致的宣講,我作為開發(fā)者有幸參與聆聽了相關(guān)議題介紹。
    發(fā)表于 11-19 15:38

    絕對干貨!HarmonyOS開發(fā)者日資料全公開,鴻蒙開發(fā)者都在看

    應(yīng)用開發(fā)模板,分布式調(diào)試調(diào)優(yōu),上架開發(fā)規(guī)范解讀等。6、HarmonyOS 分布式應(yīng)用框架深入解讀:該主題深度解析HarmonyOS分布式應(yīng)用
    發(fā)表于 08-04 14:36

    鴻蒙、iOS、安卓的開發(fā)者數(shù)量,APP數(shù)量大對比,差距有多大呢?

    ,只要開發(fā)者數(shù)量多了,APP就多了,生態(tài)就起來了。那么我們對比一下當前華為鴻蒙、蘋果iOS、谷歌安卓的開發(fā)者數(shù)量、APP數(shù)量,大家來看一看,差距到底有多大。先說蘋果,按照蘋果今年在WWDC上公布的
    發(fā)表于 08-30 14:27

    分布式數(shù)據(jù)對象:超級終端的"全局變量"

    設(shè)備訪問這些變量就能像操作本地變量一樣,數(shù)據(jù)就能夠自動高效、便捷地實現(xiàn)多端同步了。為此,本次 OpenHarmony v3.1 Release 版本新增了分布式數(shù)據(jù)對象特性。
    發(fā)表于 06-09 15:18

    開發(fā)者】XstoryMaker快速書寫劇本場景動畫

    。 我在開發(fā)XstoryMaker關(guān)于視覺小說的分布式流轉(zhuǎn)的時候根本沒有感受到這是兩臺設(shè)備在做數(shù)據(jù)傳輸?shù)?b class='flag-5'>開發(fā),兩個端的開發(fā)代碼只需要按照一個
    發(fā)表于 09-14 12:04

    鴻蒙原生應(yīng)用/元服務(wù)開發(fā)-開發(fā)者如何進行真機測試

    前提條件:已經(jīng)完成鴻蒙原生應(yīng)用/元服務(wù)開發(fā),已經(jīng)能相對熟練使用DevEco Studio,開發(fā)者自己有鴻蒙4.0及以上的真機設(shè)備。 真機測試
    發(fā)表于 11-30 09:46

    鴻蒙原生應(yīng)用開發(fā)——分布式數(shù)據(jù)對象

    01、什么是分布式數(shù)據(jù)對象 在可信組網(wǎng)環(huán)境下,多個相互組網(wǎng)認證的設(shè)備將各自創(chuàng)建的對象加入同一個 sessionId,使得加入的多個數(shù)據(jù)
    發(fā)表于 12-08 10:01

    HarmonyOS分布式應(yīng)用評分工具定位于幫助開發(fā)者本地快速測試

    HarmonyOS是新一代的智能終端操作系統(tǒng),給開發(fā)者提供了設(shè)備發(fā)現(xiàn)、設(shè)備連接、跨設(shè)備調(diào)用等豐富的分布式API。隨著越來越多的開發(fā)者投入到HarmonyOS分布式應(yīng)用
    的頭像 發(fā)表于 12-17 13:50 ?1456次閱讀

    分布式數(shù)據(jù)對象的產(chǎn)生背景、原理及開發(fā)案例

    在3月底發(fā)布的OpenHarmony v3.1 Release版本中,新增了分布式數(shù)據(jù)對象特性。什么是分布式數(shù)據(jù)
    的頭像 發(fā)表于 04-27 15:01 ?1218次閱讀
    <b class='flag-5'>分布式</b><b class='flag-5'>數(shù)據(jù)</b><b class='flag-5'>對象</b>的產(chǎn)生背景、原理及<b class='flag-5'>開發(fā)</b>案例

    華為開發(fā)者大會2022主題演講:分布式安全

    華為開發(fā)者大會2022主題演講:分布式安全:分布式(設(shè)備}安全、分布式(數(shù)據(jù)}安全、分布式{協(xié)同
    的頭像 發(fā)表于 11-04 15:20 ?910次閱讀
    華為<b class='flag-5'>開發(fā)者</b>大會2022主題演講:<b class='flag-5'>分布式</b>安全
    主站蜘蛛池模板: 久久才是精品亚洲国产| 久久久无码精品亚洲A片软件| 国产真实女人一级毛片| 两个洞一起插哦!好刺激| 求个av网站| 亚洲日本在线不卡二区| 99精品电影一区二区免费看| 国产精品自在在线午夜精品| 美目盼兮amy198281| 午夜神器18以下不能进免费| 在线观看中文字幕码2021不用下载| 边做边爱播放3免费观看| 国产亚洲精品久久久久久线投注| 奶水太多h室友| 亚洲高清一区二区三区电影| GOGOGO高清在线播放韩国| 黄色免费网址在线观看| 日本老妇一级特黄aa大片| 影音先锋av电影| 国产精品久久久久久久人人看| 美女内射少妇一区二区四区| 亚洲成A人片在线观看中文不卡| 99re.05久久热最新地址| 黑人特黄AA完整性大片| 色琪琪丁香婷婷综合久久| 中文中幕无码亚洲视频| 国产午夜精品福利久久| 青青草原国产在线观看| 永久免费的无码中文字幕| 国产成人免费手机在线观看视频| 麻豆精品乱码WWW久久密| 亚洲国产AV精品卡一卡二| 成人无码国产AV免费看| 麻豆国产精品va在线观看约| 亚洲成AV人片一区二区不卡| 国产99久久九九免费精品无码| 欧美wwwvideos在线观看| 在线a亚洲视频| 狠狠国产欧美在线视频| 偷拍自偷拍亚洲精品| 草莓视频在线播放视频|