成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

HarmonyOS服務卡片開發知識總結

開發 前端 OpenHarmony
服務卡片的征文活動也已經接近尾聲,在這段時間里,論壇里有許多優秀的服務卡片作品和相關的文章涌現。我拜讀了專欄中幾乎所有的服務卡片的開發分享文章,從每一篇文章中提取并汲取精華,整合到本文中。

[[418958]]

想了解更多內容,請訪問:

51CTO和華為官方合作共建的鴻蒙技術社區

https://harmonyos.51cto.com

前言

服務卡片的征文活動也已經接近尾聲,在這段時間里,論壇里有許多優秀的服務卡片作品和相關的文章涌現。我拜讀了專欄中幾乎所有的服務卡片的開發分享文章,從每一篇文章中提取并汲取精華,整合到本文中。一些較為顯然的介紹性的內容在本文中將會被省略(如卡片有多少種尺寸之類),但是一些即使在很多文章都已經說明過的,而我又認為比較重要的內容,我仍然會再次記錄下來(例如卡片的框架)。另外,作為學習筆記,我會記錄下一些我在學習種遇到的新的名詞的概念,這些概念可能是大家已經熟知的,這部分大家可以直接忽略;文章的內容整合自論壇種的眾多文章,所以大家可能會在本文中看到自己文章的影子。

服務卡片的框架

服務卡片整體框架主要包含三部分:卡片使用方、卡片管理服務和卡片提供方。其概念分別如下:

● 卡片使用方:顯示卡片內容的宿主應用,控制卡片在宿主中展示的位置,如桌面、服務中心、搜索等。

● 卡片管理服務:用于管理系統中所添加卡片的常駐代理服務,包括卡片對象的管理與使用,以及卡片周期性刷新等。

● 卡片提供方:提供卡片顯示內容的HarmonyOS應用或原子化服務,控制卡片的顯示內容、控件布局以及控件點擊事件。

卡片的運行框架有如下示意圖:

學習筆記——HarmonyOS服務卡片開發知識總結-鴻蒙HarmonyOS技術社區

簡明版示意圖

學習筆記——HarmonyOS服務卡片開發知識總結-鴻蒙HarmonyOS技術社區

詳細版示意圖

卡片的常用功能

Java卡片與JS卡片功能的對比圖

學習筆記——HarmonyOS服務卡片開發知識總結-鴻蒙HarmonyOS技術社區

MainAbility的自動生成函數解析

在新建服務卡片的時候,在MainAbility類中將會生成一些回調方法,具體方法及其回調條件如下圖,在后面的具體的卡片操作中,也會再次聲明所調用的回調方法。

學習筆記——HarmonyOS服務卡片開發知識總結-鴻蒙HarmonyOS技術社區

在onCreatForm(Intent)方法中,卡片提供方被拉起后intent會攜帶卡片相關信息,具體如下:

學習筆記——HarmonyOS服務卡片開發知識總結-鴻蒙HarmonyOS技術社區

服務卡片生命周期回調函數時序如下:

學習筆記——HarmonyOS服務卡片開發知識總結-鴻蒙HarmonyOS技術社區

配置卡片編輯功能

有些服務卡片需要具備可編輯能力,如天氣App需要編輯所在城市。具體實現方法如下:在config.json中,對某一個form的配置增加formConfigAbility的屬性配置,可實現編輯功能。formConfigAbility的值是一個url格式的Ability名稱。若不配置formConfigAbility,則不顯示編輯菜單。示例代碼如下:(摘抄自[一文看懂HarmonyOS服務卡片運行原理和開發方法])(https://harmonyos.oss-cn-beijing.aliyuncs.com/images/202106/830a107135e5fa06fa1714ebaa9fa523833da2.jpg?x-oss-process=image/resize,w_1080,h_478)

學習筆記——HarmonyOS服務卡片開發知識總結-鴻蒙HarmonyOS技術社區

卡片的定點/定時刷新:將回調updateForm()方法

運作機制示意圖如下:

學習筆記——HarmonyOS服務卡片開發知識總結-鴻蒙HarmonyOS技術社區

注意:定時刷新和定點刷新都配置的情況下,定時刷新優先。

JS卡片的定點更新步驟:

1.關閉定時更新:updateDuration”修改為0,以關閉定時刷新(config.json文件中)

2.設定“scheduledUpdateTime”的時刻

3.在具體的xxxxlmpl中重寫updateFormData()方法

4.把需要刷新的數據存入一個ZSONObject實例中

5.將這個實例封裝在一個FormBindingData的實例bindingData中

6.調用MainAbility的方法updateForm(),并將bindingData作為第二個實參。

JS卡片重寫updateFormData()方法的代碼如下:

學習筆記——HarmonyOS服務卡片開發知識總結-鴻蒙HarmonyOS技術社區

JAVA卡片的定點更新步驟:

1.前三步與JS卡片相同

2.構造一個ComponentProvider的實例,用于表示一個Java卡片實例,傳入的第一個實參是根據卡片尺寸得到的布局文件。然后,調用方法setText()修改卡片的標題;最后,調用MainAbility的方法updateForm(),并將componentProvider作為第二個實參。

JAVA卡片重寫updateFormData()方法的代碼如下:

學習筆記——HarmonyOS服務卡片開發知識總結-鴻蒙HarmonyOS技術社區

卡片的定時刷新

卡片的定時刷新的最小單位時間是三十分鐘,這就帶來了兩個問題:

1.創建卡片后的最初的三十分鐘是不會進行卡片刷新的,所以需要進行手動的刷新。

2.如果是編寫刷新間隔小于三十分的卡片(如時鐘卡片每一秒刷新一次),那么需要自己重新創建一個timer實例來設定刷新時間。

添加手動刷新:用onCreateForm()調用onUpdateForm(formId)即可,代碼摘抄自亮子力的嗶哩嗶哩卡片

  1. @Override 
  2. protected ProviderFormInfo onCreateForm(Intent intent) { 
  3.     ... ... 
  4.  
  5.     //初始化時先在線更新一下卡片 
  6.     onUpdateForm(formId); 
  7.  
  8.     return formController.bindFormData(); 

 重新編寫刷新時間的代碼為代碼摘抄自Codelabs 之 時鐘FA卡片開發樣例

  1. private void startTimer() { 
  2.         Timer timer = new Timer(); 
  3.         timer.schedule( 
  4.                 new TimerTask() { 
  5.                     @Override 
  6.                     public void run() { 
  7.                         updateForms(); 
  8.                     } 
  9.                 }, 
  10.                 0, 
  11.                 SEND_PERIOD); 
  12.     } 
  1. private void updateForms() { 
  2.         // 從數據庫中獲取卡片信息 
  3.         HiLog.info(LABEL, "從數據庫中獲取卡片"); 
  4.         OrmPredicates ormPredicates = new OrmPredicates(Form.class); 
  5.         List<Form> formList = connect.query(ormPredicates); 
  6.         int layoutId=0; 
  7.         // 更新時分秒 
  8.         if (formList.size() <= 0) { 
  9.             return
  10.         } 
  11.         HiLog.info(LABEL, "遍歷卡片列表,逐個更新"); 
  12.         for (Form form : formList) { 
  13.             // 遍歷卡片列表更新卡片 
  14.             ComponentProvider componentProvider = ComponentProviderUtils.getComponentProvider(form, this); 
  15.             try { 
  16.                 Long updateFormId = form.getFormId(); 
  17.                 HiLog.info(LABEL, "updateForm,更新卡片[:"+updateFormId+"] 的數據,并非數據庫操作" ); 
  18.                 //更新卡片數據 
  19.                 boolean isSucc=updateForm(updateFormId, componentProvider); 
  20.                 HiLog.info(LABEL, "更新卡片數據完成,"+isSucc); 
  21.             } catch (FormException e) { 
  22.                 // 刪除不存在的卡片 
  23.                 DatabaseUtils.deleteFormData(form.getFormId(), connect); 
  24.                 HiLog.error(LABEL, "更新卡片異常,刪除數據庫中不存在的卡片"); 
  25.             } 
  26.         } 
  27.     }

JAVA與JS卡片定點定時更新的對比總結

由上可見,兩者的大體思路是相同的:即先在config.json文件中修改配置,然后對具體的xxxxlmpl中的updateFormData()進行重寫。不同的是,JS卡片式通過創建一個ZSONOject實例,然后封裝在FormBindingData的實例中的辦法更新數據;而JAVA卡片則是通過創建ComponentProvider的實例,通過它來更新數據。因而,在調用MainAbility的方法updateForm()的時候,JS卡片的第二個實參是bingding Data,而JAVA卡片是componentProvider。

卡片的跳轉事件:

運作機制示意圖如下:

學習筆記——HarmonyOS服務卡片開發知識總結-鴻蒙HarmonyOS技術社區

JS卡片的跳轉事件步驟

1.在對應卡片的index.json文件中添加跳轉配置

學習筆記——HarmonyOS服務卡片開發知識總結-鴻蒙HarmonyOS技術社區

相關參數意義具體如下:

學習筆記——HarmonyOS服務卡片開發知識總結-鴻蒙HarmonyOS技術社區

2.在index.hml中,在標簽image中添加一個屬性onclick,并將值設置為剛剛在index.json中定義的action的名稱“startSecondAbility”

3.根據key的值“params”獲得一個字符串格式的JSON數據;然后,調用ZSONObject.stringToZSON()將其轉換為一個ZSONObject的實例data;最后,從data中分別獲得”param1”和”param2”這兩個key對應的value。

學習筆記——HarmonyOS服務卡片開發知識總結-鴻蒙HarmonyOS技術社區

JAVA卡片的跳轉事件步驟

1.打開MainWidget3Impl,在方法bindFormData()中,當卡片尺寸為2*4時,調用componentProvider的方法setIntentAgent(),傳入的第一個實參是標題在布局文件中的id,第二個實參是用于頁面跳轉的IntentAgent實例。代碼如下所示:

學習筆記——HarmonyOS服務卡片開發知識總結-鴻蒙HarmonyOS技術社區

2.定義方法getStartAbilityIntentAgent()的具體實現,代碼如下:

學習筆記——HarmonyOS服務卡片開發知識總結-鴻蒙HarmonyOS技術社區

總結

Java卡片要通過IntentAgent來設置事件,相比之下JS似乎顯得要方便一些。

卡片的消息事件

JS卡片的消息事件步驟

1.在對應卡片的index.json文件中添加信息事件配置

學習筆記——HarmonyOS服務卡片開發知識總結-鴻蒙HarmonyOS技術社區

相關參數意義具體如下:

學習筆記——HarmonyOS服務卡片開發知識總結-鴻蒙HarmonyOS技術社區

2.重寫方法onTriggerFormEvent(),代碼如下:

學習筆記——HarmonyOS服務卡片開發知識總結-鴻蒙HarmonyOS技術社區

message是一個字符串格式的JSON數據;然后,調用ZSONObject.stringToZSON()將message轉換為一個ZSONObject的實例data;最后,從data中分別獲得”p1”和”p2”這兩個key對應的value。

服務卡片常用到的數據庫

數據持久化

概念:數據持久化就是將內存中的數據模型轉換為存儲模型,以及將存儲模型轉換為內存中的數據模型的統稱

好處:

1、程序代碼重用性強,即使更換數據庫,只需要更改配置文件,不必重寫程序代碼。

2、業務邏輯代碼可讀性強,在代碼中不會有大量的SQL語言,提高程序的可讀性。

3、持久化技術可以自動優化,以減少對數據庫的訪問量,提高程序運行效率。

數據持久化對象的基本操作有:保存、更新、刪除、查詢等。

輕量級偏好數據庫

輕量級數據庫官方文檔鏈接

輕量級偏好數據庫在服務卡片開發中的使用場景

根據輕量級偏好數據庫的特點,在服務卡片的開發中,涉及到保存網絡上的內容時,可以使用輕量級偏好數據庫來存儲cookie信息。

輕量級偏好數據庫的創建(獲取preference實例)

  1. context = getContext(); 
  2. databaseHelper = new DatabaseHelper(context); 
  3. filename = "preference_db";//文件名,不能為空,也不能包含路徑 
  4. preferences = databaseHelper.getPreferences(filename); 

輕量級偏好數據庫的插入,刪除,修改,查詢

插入與修改:

首先獲取指定文件對應的Preferences實例,然后借助Preferences API將數據寫入Preferences實例,通過flush或者flushSync將Preferences實例持久化。其中flush為異步地寫入,flushSync為同步寫入。flush()會立即更改內存中的Preferences對象,但會將更新異步寫入磁盤。flushSync()更改內存中的數據的同時會將數據同步寫入磁盤。由于flushSync()是同步的,建議不要從主線程調用它,以避免界面卡頓。

異步寫入代碼:

  1. preferences.putInt("number",number); 
  2. preferences.putString("fruit","apple"); 
  3. preferences.flush(); 

同步寫入的代碼:

  1. preferences.putInt("intKey", 3); 
  2. preferences.putString("StringKey""String value"); 
  3. bool result = preferences.flushSync(); 

查詢:

  1. int value = preferences.getInt("intKey", 0); 

刪除:

1.刪除preferen單實例

  1. DatabaseHelper databaseHelper = new DatabaseHelper(context); 
  2. String fileName = "name"; // fileName表示文件名,其取值不能為空,也不能包含路徑。 
  3. databaseHelper.removePreferencesFromCache(fileName); 

2.刪除指定文件

  1. DatabaseHelper databaseHelper = new DatabaseHelper(context); 
  2. String fileName = "name"; // fileName表示文件名,其取值不能為空,也不能包含路徑。 
  3. boolean result = databaseHelper.deletePreferences(fileName); 

注冊觀察者

  1. private class PreferencesObserverImpl implements Preferences.PreferencesObserver { 
  2.     
  3.     @Override     
  4.     public void onChange(Preferences preferences, String key) { 
  5.         if ("intKey".equals(key)) { 
  6.            HiLog.info(LABLE, "Change Received:[key=value]");         
  7.         }     
  8.     } 
  9.  
  10. // 向preferences實例注冊觀察者 
  11. PreferencesObserverImpl observer = new PreferencesObserverImpl(); 
  12. preferences.registerObserver(observer); 
  13. // 修改數據 
  14. preferences.putInt("intKey", 3); 
  15. preferences.flush(); 
  16. // 修改數據后,observer的onChange方法會被回調 
  17. // 向preferences實例注銷觀察者 
  18. preferences.unRegisterObserver(observer); 

輕量級數據庫在服務卡片中的使用例子:(摘抄自亮子力的嗶哩嗶哩卡片

  1. /** 
  2.    * Map[保存]到偏好型數據庫 
  3.    * @param preferences  數據庫的Preferences實例 
  4.    * @param map  要保存的map 
  5.    */ 
  6.   public static void SaveMap(Preferences preferences,Map<String,String> map){ 
  7.       // 遍歷map 
  8.       for (Map.Entry<String, String> entry : map.entrySet()) { 
  9.           HiLog.info(TAG,entry.getKey() + "=" + entry.getValue()); 
  10.           preferences.putString(entry.getKey(),entry.getValue());//3.將數據寫入Preferences實例, 
  11.       } 
  12.       preferences.flushSync();//4.通過flush()或者flushSync()將Preferences實例持久化。 
  13.   } 
  14.  
  15.   /** 
  16.    *  從偏好型數據庫[讀取]Map 
  17.    * @param preferences  數據庫的Preferences實例 
  18.    * @return  要讀取的map 
  19.    */ 
  20.   public static Map<String,?> GetCookieMap(Preferences preferences){ 
  21.       Map<String, ?> map = new HashMap<>(); 
  22.       map = preferences.getAll();//3.讀取數據 
  23.       return map; 
  24.   } 

對象關系映射數據庫

對象關系映射數據庫官方文檔

對象關系數據庫在服務卡片中的應用

對象關系數據庫在服務卡片中主要用作存儲卡片的信息,如卡片id,卡片名字,卡片大小等。

對象關系數據庫的創建

1.配置“build.gradle”文件,這里僅展示使用注解處理器的模塊為“com.huawei.ohos.hap”模塊,則需要在模塊的“build.gradle”文件的ohos節點中添加以下配置:

  1. compileOptions{         
  2.     annotationEnabled true     
  3. }  

2.構造對象關系映射數據庫:創建數據庫類并配置對應的屬性

  1. //數據庫有三個表,User,Book, AllDataType三個表,版本號為1 
  2. @Database(entities = {User.class, Book.class, AllDataType.class}, version = 1)  
  3. public abstract class BookStore extends OrmDatabase {  

3.構造數據表,即創建數據庫實體類并配置對應的屬性(如對應表的主鍵,外鍵等)。數據表必須與其所在的數據庫在同一個模塊中。

  1. @Entity(tableName = "user", ignoredColumns = {"ignoredColumn1""ignoredColumn2"}, 
  2.     indices = {@Index(value = {"firstName""lastName"}, name = "name_index"unique = true)})  
  3. public class User extends OrmObject {  
  4.     // 此處將userId設為了自增的主鍵。注意只有在數據類型為包裝類型時,自增主鍵才能生效。 
  5.     @PrimaryKey(autoGenerate = true)  
  6.     private Integer userId;    
  7.     private String firstName;    
  8.     private String lastName;    
  9.     private int age;    
  10.     private double balance;    
  11.     private int ignoredColumn1;  
  12.     private int ignoredColumn2;  
  13.   
  14.     // 需添加各字段的getter和setter方法。  

4.使用對象數據操作接口OrmContext創建數據庫。

  1. // context入參類型為ohos.app.Context,注意不要使用slice.getContext()來獲取context,請直接傳入slice,否則會出現找不到類的報錯。 
  2. DatabaseHelper helper = new DatabaseHelper(this);  
  3.  
  4. OrmContext context = helper.getOrmContext("BookStore""BookStore.db", BookStore.class);  

5.對象關系映射數據庫的增刪改查

查詢數據:

  1. OrmPredicates query = context.where(User.class).equalTo("lastName""San");  
  2. List<User> users = context.query(query); 

更新數據:更新數據有兩種方法,這里僅貼出其中一種

  1. // 更新數據 
  2. OrmPredicates predicates = context.where(User.class); 
  3. predicates.equalTo("age", 29); 
  4. List<User> users = context.query(predicates); 
  5. User user = users.get(0); 
  6. user.setFirstName("Li"); 
  7. context.update(user); 
  8. context.flush(); 

刪除數據:刪除數據也有兩種方法,這里也僅貼出其中一種,另一種方法可以到官方文檔查看

  1. // 刪除數據 
  2. OrmPredicates predicates = context.where(User.class); 
  3. predicates.equalTo("age", 29); 
  4. List<User> users = context.query(predicates); 
  5. User user = users.get(0); 
  6. context.delete(user); 
  7. context.flush(); 

6.注冊觀察者

  1. // 定義一個觀察者類。 
  2. private class CustomedOrmObjectObserver implements OrmObjectObserver { 
  3.     @Override     
  4.     public void onChange(OrmContext changeContext, AllChangeToTarget subAllChange) { 
  5.         // 用戶可以在此處定義觀察者行為 
  6.     } 
  7.  
  8. // 調用registerEntityObserver方法注冊一個觀察者observer。 
  9. CustomedOrmObjectObserver observer = new CustomedOrmObjectObserver(); 
  10. context.registerEntityObserver("user", observer); 
  11.  
  12. // 當以下方法被調用,并flush成功時,觀察者observer的onChange方法會被觸發。其中,方法的入參必須為User類的對象。 
  13. public <T extends OrmObject> boolean insert(T object) 
  14. public <T extends OrmObject> boolean update(T object) 
  15. public <T extends OrmObject> boolean delete(T object) 

對象關系映射數據庫在服務卡片中的應用實例

  1. @Entity(tableName = "form"
  2. public class Form extends OrmObject { 
  3.     @PrimaryKey() 
  4.     // 卡片id 
  5.     private Long formId; 
  6.  
  7.     // 卡片名稱 
  8.     private String formName; 
  9.  
  10.     // 卡片名稱 
  11.     private int dimension; 
  12.  
  13.     /** 
  14.      * 有參構造 
  15.      * 
  16.      * @param formId 卡片id 
  17.      * @param formName 卡片名 
  18.      * @param dimension 卡片規格 
  19.      */ 
  20.     public Form(Long formId, String formName, int dimension) { 
  21.         this.formId = formId; 
  22.         this.formName = formName; 
  23.         this.dimension = dimension; 
  24.     } 
  1. protected ProviderFormInfo onCreateForm(Intent intent) { 
  2.         HiLog.info(TAG, "onCreateForm"); 
  3.         long formId = intent.getLongParam(AbilitySlice.PARAM_FORM_IDENTITY_KEY, INVALID_FORM_ID); 
  4.         String formName = intent.getStringParam(AbilitySlice.PARAM_FORM_NAME_KEY); 
  5.         int dimension = intent.getIntParam(AbilitySlice.PARAM_FORM_DIMENSION_KEY, DEFAULT_DIMENSION_2X2); 
  6.         HiLog.info(TAG, "onCreateForm: formId=" + formId + ",formName=" + formName); 
  7.         FormControllerManager formControllerManager = FormControllerManager.getInstance(this); 
  8.         FormController formController = formControllerManager.getController(formId); 
  9.         formController = (formController == null) ? formControllerManager.createFormController(formId, 
  10.                 formName, dimension) : formController; 
  11.         if (formController == null) { 
  12.             HiLog.error(TAG, "Get null controller. formId: " + formId + ", formName: " + formName); 
  13.             return null
  14.         } 
  15.  
  16.         //初始化時先在線更新一下卡片 
  17.         onUpdateForm(formId); 
  18.  
  19.         // TODO 獲取添加到桌面的服務卡片ID 
  20.  
  21.         // 存儲卡片信息。對象關系映射數據庫2.通過對象數據操作接口OrmContext,創建一個別名為“FormDatabase”,數據庫文件名為“FormDatabase.db”的數據庫 
  22.         ormContext = databaseHelper.getOrmContext("FormDatabase""FormDatabase.db", MyOrmDatabase.class); 
  23.         // 對象關系映射數據庫3.實例化數據表 
  24.         HiLog.info(TAG, "存儲卡片信息: formId=" + formId + ",formName=" + formName + ",dimension=" + dimension); 
  25.         Form form = new Form(formId, formName, dimension); 
  26.         // 對象關系映射數據庫4.添加方法 
  27.         ormContext.insert(form); 
  28.         ormContext.flush(); 
  29.  
  30.  
  31.         return formController.bindFormData(); 
  32.     } 

網絡編程的相關知識

這部分在我平時的學習未曾接觸過,在大家眼中很平常的概念,在我這里都是全新的知識,所以會有較多的概念記錄。

WebView組件的使用

WebView組件官方文檔

WebView提供在應用中集成Web頁面的能力。

服務卡片的開發中一般只需要加載Web頁面,則常用操作如下:

1.配置應用的網絡權限(如未配置網絡權限的話)

  1.   ... 
  2.   "module": { 
  3.     ... 
  4.     "reqPermissions": [ 
  5.       { 
  6.         "name""ohos.permission.INTERNET" 
  7.       } 
  8.     ], 
  9.     ... 
  10.   } 

2.使用load方法加載Web頁面

這里僅貼出使用xml方式布局的代碼,使用代碼方式布局可參看官方文檔

  1. WebView webView = (WebView) findComponentById(ResourceTable.Id_webview); 
  2. webView.getWebConfig().setJavaScriptPermit(true);  // 如果網頁需要使用JavaScript,增加此行;如何使用JavaScript下文有詳細介紹   
  3. final String url = EXAMPLE_URL; // EXAMPLE_URL由開發者自定義 
  4. webView.load(url); 

什么是JSON文件

JSON的全稱為JavaScript Object Notation,是輕量級的文本數據交換格式,JSON實際上是JavaScript的一個子集。重要的是,許多API請求返回值都是josn格式的結果。

JSON生成Java實體類

網上有很多相關的工具,如何自己編寫我暫且還未學會,就決定先應用現有的工具了

什么是Cookie

由于HTTP是一種無狀態協議,服務器沒有辦法單單從網絡連接上面知道訪問者的身份,因此就使用Cookie作為辨識訪問者的一種標志。

Cookie是一段不超過4KB的小型文本數據,由一個名稱(Name)、一個值(Value)和其它幾個用于控制Cookie有效期、安全性、使用范圍的可選屬性組成。

運作機制如下圖:

學習筆記——HarmonyOS服務卡片開發知識總結-鴻蒙HarmonyOS技術社區

客戶端請求服務器,如果服務器需要記錄該用戶狀態,就使用response向客戶端瀏覽器頒發一個Cookie,客戶端瀏覽器會把Cookie保存起來。當瀏覽器再請求該網站時,瀏覽器把請求的網址連同該Cookie一同提交給服務器。服務器檢查該Cookie,

以此來辨認用戶狀態。服務器還可以根據需要修改Cookie的內容。

實際就是頒發一個通行證,每人一個,無論誰訪問都必須攜帶自己通行證。這樣服務器就能從通行證上確認客戶身份了。這就是Cookie的工作原理。

cookie 可以讓服務端程序跟蹤每個客戶端的訪問,但是每次客戶端的訪問都必須傳回這些Cookie,如果 Cookie 很多,這無形地增加了客戶端與服務端的數據傳輸量。

Cookie相關方法

CookieStore官方文檔

學習筆記——HarmonyOS服務卡片開發知識總結-鴻蒙HarmonyOS技術社區
學習筆記——HarmonyOS服務卡片開發知識總結-鴻蒙HarmonyOS技術社區

卡片開發的基本步驟總結

1.選擇已有的卡片模板,或者自行繪制卡片樣式

2.對卡片進行初始化的設置

3.建立數據庫(對象關系映射數據庫存儲卡片信息,涉及網絡的可以用輕量級數據庫存儲cookie

4.給卡片上面的組件添加響應的事件

5.實現卡片的功能

想了解更多內容,請訪問:

51CTO和華為官方合作共建的鴻蒙技術社區

https://harmonyos.51cto.com

 

責任編輯:jianghua 來源: 鴻蒙社區
相關推薦

2021-08-18 10:06:33

鴻蒙HarmonyOS應用

2021-09-15 10:19:15

鴻蒙HarmonyOS應用

2021-07-28 14:59:08

鴻蒙HarmonyOS應用

2021-06-30 09:27:58

鴻蒙HarmonyOS應用

2021-06-21 15:21:52

鴻蒙HarmonyOS應用開發

2021-07-22 08:45:47

鴻蒙HarmonyOS應用

2023-08-04 17:24:43

2011-08-15 10:35:43

iPhone開發Atomicnonatomic

2011-08-15 10:45:11

iPhone開發delegate

2009-01-11 09:14:45

Javascript開發總結

2023-09-13 15:27:14

鴻蒙應用元服務

2021-09-18 09:57:20

鴻蒙HarmonyOS應用

2022-05-09 11:52:38

Java卡片服務卡片

2010-03-18 14:24:31

云計算

2023-04-07 09:20:55

2022-04-24 15:26:38

服務卡鴻蒙

2013-01-06 09:52:43

SQLite

2013-04-09 16:04:06

iOS開發SQLite知識總結

2021-07-20 09:58:16

鴻蒙HarmonyOS應用

2021-06-23 16:05:05

鴻蒙HarmonyOS應用
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 亚洲午夜av久久乱码 | 欧美一区二区三区视频 | 国产男女视频网站 | 999精品在线观看 | 午夜视频一区二区三区 | 亚洲国产成人久久久 | 国产午夜精品一区二区三区四区 | 99视频在线| 最新中文字幕在线 | 亚洲一区二区欧美 | 成人一区av偷拍 | 成人欧美一区二区三区在线播放 | 黄页网址在线观看 | 中文字幕av亚洲精品一部二部 | 日韩成人一区 | 国产精品国产成人国产三级 | 天天精品在线 | 毛片免费看的 | 国产精品美女一区二区 | www.国产91| av网站免费在线观看 | 亚洲欧美视频一区 | 亚洲欧美一区二区三区在线 | 伊人免费在线观看高清 | 日韩av电影在线观看 | 在线观看成人小视频 | 欧产日产国产精品v | 国产高清精品一区二区三区 | 91最新在线视频 | 日韩成人在线免费观看 | 男人av在线 | 亚洲一区二区三区免费观看 | 成人性视频在线 | 热re99久久精品国99热观看 | 小h片免费观看久久久久 | 影音先锋中文在线 | 久久99精品久久久 | 欧美亚洲国产一区二区三区 | 成人在线播放网站 | 婷婷免费在线 | 一区二区免费视频 |