那曲檬骨新材料有限公司

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

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

3天內不再提示

鴻蒙開發電話服務:ohos.telephony.sms之短信服務

jf_46214456 ? 來源:jf_46214456 ? 作者:jf_46214456 ? 2024-06-17 15:57 ? 次閱讀

短信服務

說明:
開發前請熟悉鴻蒙開發指導文檔 :[gitee.com/li-shizhen-skin/harmony-os/blob/master/README.md]

本模塊首批接口從API version 6開始支持。后續版本的新增接口,采用上角標單獨標記接口的起始版本。

導入模塊

import sms from '@ohos.telephony.sms';

sms.createMessage

createMessage(pdu: Array, specification: string, callback: AsyncCallback): void

根據協議數據單元(PDU)和指定的短信協議創建短信實例,使用callback方式作為異步方法。

系統能力 :SystemCapability.Telephony.SmsMms

參數

參數名類型必填說明
pduArray協議數據單元,從收到的信息中獲取。
specificationstring短信協議類型。 - 3gpp表示GSM/UMTS/LTE SMS - 3gpp2表示CDMA SMS
callbackAsyncCallback<[ShortMessage]>回調函數。

示例:

const specification = '3gpp';
// 以數組的形式顯示協議數據單元(PDU),類型為number,例如[0x08, 0x91, ...]
const pdu = [0x08, 0x91];
sms.createMessage(pdu, specification, (err, data) = > {
    console.log(`callback: err- >${JSON.stringify(err)}, data- >${JSON.stringify(data)}`);
});

sms.createMessage

createMessage(pdu: Array, specification: string): Promise

根據協議數據單元(PDU)和指定的短信協議創建短信實例,使用Promise方式作為異步方法。

系統能力 :SystemCapability.Telephony.SmsMms

參數:

參數名類型必填說明
pduArray協議數據單元,從收到的信息中獲取。
specificationstring短信協議類型。 - 3gpp表示GSM/UMTS/LTE SMS - 3gpp2表示CDMA SMS

返回值:

類型說明
Promise<[ShortMessage]>以Promise形式返回創建的短信實例。

示例:

const specification = '3gpp';
// 以數組的形式顯示協議數據單元(PDU),類型為number,例如[0x08, 0x91, ...]
const pdu = [0x08, 0x91];
let promise = sms.createMessage(pdu, specification);
promise.then(data = > {
    console.log(`createMessage success, promise: data- >${JSON.stringify(data)}`);
}).catch(err = > {
    console.error(`createMessage fail, promise: err- >${JSON.stringify(err)}`);
});

sms.sendMessage

sendMessage(options: SendMessageOptions): void

發送短信。

需要權限 :ohos.permission.SEND_MESSAGES

系統能力 :SystemCapability.Telephony.SmsMms

參數:

參數名類型必填說明
options[SendMessageOptions]發送短信的參數和回調,參考[SendMessageOptions]。

示例:

let sendCallback = function (err, data) {    
    console.log(`sendCallback: err- >${JSON.stringify(err)}, data- >${JSON.stringify(data)}`); 
}
let deliveryCallback = function (err, data) {    
    console.log(`deliveryCallback: err- >${JSON.stringify(err)}, data- >${JSON.stringify(data)}`); 
}
let slotId = 0;
let content = '短信內容';
let destinationHost = '+861xxxxxxxxxx';
let serviceCenter = '+861xxxxxxxxxx';
let destinationPort = 1000;
let options = {slotId, content, destinationHost, serviceCenter, destinationPort, sendCallback, deliveryCallback};
sms.sendMessage(options);

sms.getDefaultSmsSlotId7+

getDefaultSmsSlotId(callback: AsyncCallback): void

獲取發送短信的默認SIM卡槽ID,使用callback方式作為異步方法。

系統能力 :SystemCapability.Telephony.SmsMms

參數:

參數名類型必填說明
callbackAsyncCallback回調函數。 - 0:卡槽1 - 1:卡槽2

示例:

sms.getDefaultSmsSlotId((err, data) = > {
    console.log(`callback: err- >${JSON.stringify(err)}, data- >${JSON.stringify(data)}`);
});

sms.getDefaultSmsSlotId7+

getDefaultSmsSlotId(): Promise

獲取發送短信的默認SIM卡槽ID,使用Promise方式作為異步方法。

系統能力 :SystemCapability.Telephony.SmsMms

返回值:

類型說明
Promise以Promise形式返回發送短信的默認SIM卡: - 0:卡槽1 - 1:卡槽2

示例:

let promise = sms.getDefaultSmsSlotId();
promise.then(data = > {
    console.log(`getDefaultSmsSlotId success, promise: data- >${JSON.stringify(data)}`);
}).catch(err = > {
    console.error(`getDefaultSmsSlotId fail, promise: err- >${JSON.stringify(err)}`);
});

sms.setSmscAddr7+

setSmscAddr(slotId: number, smscAddr: string, callback: AsyncCallback): void

設置短信服務中心(SMSC)地址,使用callback方式作為異步方法。

需要權限 :ohos.permission.SET_TELEPHONY_STATE,該權限為系統權限

系統能力 :SystemCapability.Telephony.SmsMms

系統API :該接口為系統接口,三方應用不支持調用。

參數:

參數名類型必填說明
slotIdnumberSIM卡槽ID: - 0:卡槽1 - 1:卡槽2
smscAddrstring短信服務中心地址。
callbackAsyncCallback回調函數。

示例:

let slotId = 0;
let smscAddr = '+861xxxxxxxxxx';
sms.setSmscAddr(slotId, smscAddr, (err,data) = > {
      console.log(`callback: err- >${JSON.stringify(err)}, data- >${JSON.stringify(data)}`);
});

sms.setSmscAddr7+

setSmscAddr(slotId: number, smscAddr: string): Promise

設置短信服務中心(SMSC)地址,使用Promise方式作為異步方法。

需要權限 :ohos.permission.SET_TELEPHONY_STATE,該權限為系統權限

系統能力 :SystemCapability.Telephony.SmsMms

系統API :該接口為系統接口,三方應用不支持調用。

參數:

參數名類型必填說明
slotIdnumberSIM卡槽ID: - 0:卡槽1 - 1:卡槽2
smscAddrstring短信服務中心地址。

返回值:

類型說明
Promise以Promise形式異步返回設置結果。

示例:

let slotId = 0;
let smscAddr = '+861xxxxxxxxxx';
let promise = sms.setSmscAddr(slotId, smscAddr);
promise.then(data = > {
    console.log(`setSmscAddr success, promise: data- >${JSON.stringify(data)}`);
}).catch(err = > {
    console.error(`setSmscAddr fail, promise: err- >${JSON.stringify(err)}`);
});

sms.getSmscAddr7+

getSmscAddr(slotId: number, callback: AsyncCallback): void

獲取短信服務中心(SMSC)地址,使用callback方式作為異步方法。

需要權限 :ohos.permission.GET_TELEPHONY_STATE,該權限為系統權限

系統能力 :SystemCapability.Telephony.SmsMms

系統API :該接口為系統接口,三方應用不支持調用。

參數:

參數名類型必填說明
slotIdnumberSIM卡槽ID: - 0:卡槽1 - 1:卡槽2
callbackAsyncCallback回調函數。

示例:

let slotId = 0;
sms.getSmscAddr(slotId, (err, data) = > {
      console.log(`callback: err- >${JSON.stringify(err)}, data- >${JSON.stringify(data)}`);
});

sms.getSmscAddr7+

getSmscAddr(slotId: number): Promise

獲取短信服務中心(SMSC)地址,使用Promise方式作為異步方法。

需要權限 :ohos.permission.GET_TELEPHONY_STATE,該權限為系統權限

系統能力 :SystemCapability.Telephony.SmsMms

系統API :該接口為系統接口,三方應用不支持調用。

參數:

參數名類型必填說明
slotIdnumberSIM卡槽ID: - 0:卡槽1 - 1:卡槽2

返回值:

類型說明
Promise以Promise形式返回獲取短信服務中心地址的結果。

示例:

let slotId = 0;
let promise = sms.getSmscAddr(slotId);
promise.then(data = > {
    console.log(`getSmscAddr success, promise: data- >${JSON.stringify(data)}`);
}).catch(err = > {
    console.error(`getSmscAddr fail, promise: err- >${JSON.stringify(err)}`);
});

sms.hasSmsCapability7+

hasSmsCapability(): boolean

檢查當前設備是否具備短信發送和接收能力,該方法是同步方法。

系統能力 :SystemCapability.Telephony.SmsMms

返回值:

類型說明
boolean- true:設備具備短信發送和接收能力 - false:設備不具備短信發送和接收能力
let result = sms.hasSmsCapability(); 
console.log(`hasSmsCapability: ${JSON.stringify(result)}`);

ShortMessage

短信實例。

系統能力 :以下各項對應的系統能力均為SystemCapability.Telephony.SmsMms。

參數名類型說明
hasReplyPathboolean收到的短信是否包含“TP-Reply-Path”,默認為false。 “TP-Reply-Path”:設備根據發送SMS消息的短消息中心進行回復。
isReplaceMessageboolean收到的短信是否為“替換短信”,默認為false。 “替換短信”有關詳細信息,參見 “3GPP TS 23.040 9.2.3.9”。
isSmsStatusReportMessageboolean當前消息是否為“短信狀態報告”,默認為false。 “短信狀態報告”是一種特定格式的短信,被用來從Service Center到Mobile Station傳送狀態報告。
messageClass[ShortMessageClass]短信類型。
pduArraySMS消息中的協議數據單元 (PDU)。
protocolIdnumber發送短信時使用的協議標識。
scAddressstring短消息服務中心(SMSC)地址。
scTimestampnumberSMSC時間戳。
statusnumberSMS-STATUS-REPORT消息中的短信狀態指示短信服務中心(SMSC)發送的短信狀態。
visibleMessageBodystring短信正文。
visibleRawAddressstring發送者地址。

ShortMessageClass

短信類型。

系統能力 :以下各項對應的系統能力均為SystemCapability.Telephony.SmsMms。

名稱說明
UNKNOWN0未知類型。
INSTANT_MESSAGE1即時消息,收到后立即顯示。
OPTIONAL_MESSAGE2存儲在設備或SIM卡上的短信。
SIM_MESSAGE3包含SIM卡信息的短信,需要存儲在SIM卡中。
FORWARD_MESSAGE4要轉發到另一臺設備的短信。

SendMessageOptions

發送短信的參數和回調。根據SendMessageOptions中的可選參數content的值判斷短信類型。

系統能力 :以下各項對應的系統能力均為SystemCapability.Telephony.SmsMms。

參數名類型必填說明
slotIdnumber用于發送短信的SIM卡槽ID: - 0:卡槽1 - 1:卡槽2
destinationHoststring短信的發送地址。
contentstringArray
serviceCenterstring短信中心地址。默認使用SIM卡中的短信中心地址。
destinationPortnumber如果發送數據消息,destinationPort 是必需的。否則是可選的。
sendCallbackAsyncCallback<[ISendShortMessageCallback]>短信發送結果回調,返回短信發送的結果,參考[ISendShortMessageCallback]。
deliveryCallbackAsyncCallback<[IDeliveryShortMessageCallback]>短信送達結果回調,返回短信遞送報告,參考[IDeliveryShortMessageCallback]。

ISendShortMessageCallback

回調實例。返回短信發送結果、存儲已發送短信的URI和是否為長短信的最后一部分。

系統能力 :以下各項對應的系統能力均為SystemCapability.Telephony.SmsMms。

參數名類型必填說明
isLastPartboolean指定這是否是長短信的最后一部分。true表示這是長短信的最后一部分,false表示不是。默認為false。
result[SendSmsResult]短信發送結果。
urlstring存儲發送短信的URI。

IDeliveryShortMessageCallback

回調實例。返回短信送達報告。

系統能力 :以下各項對應的系統能力均為SystemCapability.Telephony.SmsMms。

參數名類型必填說明
pduArray短信送達報告。HarmonyOSOpenHarmony鴻蒙文檔籽料:mau123789是v直接拿

搜狗高速瀏覽器截圖20240326151344.png

SendSmsResult

短信發送結果。

系統能力 :以下各項對應的系統能力均為SystemCapability.Telephony.SmsMms。

名稱說明
SEND_SMS_SUCCESS0發送短信成功。
SEND_SMS_FAILURE_UNKNOWN1發送短信失敗,原因未知。
SEND_SMS_FAILURE_RADIO_OFF2發送短信失敗,原因為調制解調器關機。
SEND_SMS_FAILURE_SERVICE_UNAVAILABLE3發送短信失敗,原因為網絡不可用、不支持發送或接收短信。

審核編輯 黃宇

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 鴻蒙
    +關注

    關注

    57

    文章

    2392

    瀏覽量

    43055
收藏 人收藏

    評論

    相關推薦

    鴻蒙實戰項目開發:【短信服務

    概述 本示例展示了電話服務中發送短信的功能。 樣例展示 涉及OpenHarmony技術特性 網絡通信 難度級別 中級 基礎信息 使用@ohos.telephony.sms接口展示了
    發表于 03-03 21:29

    [分享]短消息服務SMS)編程流程

    短消息服務SMS)編程流程短消息服務是在移動通訊全球系統(Global System for Mobile Communications networks ,GSM)中的移動電話間發
    發表于 05-31 09:34

    SMS 短信發送開發指南

    SMS 短信發送開發指南,有用就下載吧
    發表于 04-15 02:53

    HarmonyOS API Version 7版本特性說明

    ,歸屬PLMN,SPN,類型,電話號碼,ICCID,語音信箱等等),默認語音/數據/短信SIM卡獲取與設置。@ohos.telephony.sms新增發送短信相關接口。支持
    發表于 11-30 15:19

    HarmonyOS API Version 7版本特性說明

    ,歸屬PLMN,SPN,類型,電話號碼,ICCID,語音信箱等等),默認語音/數據/短信SIM卡獲取與設置。@ohos.telephony.sms新增發送短信相關接口。支持
    發表于 12-01 10:35

    基于Web的GSM短信服務系統的開發

    文章介紹了一個基于WEB的GSM短信服務系統的設計;闡述了系統應用的關鍵技術;討論了系統實現的幾種方式,通過對比這幾種方式的優劣,提出一種適合中小型應用的系統實現方
    發表于 09-01 11:37 ?36次下載

    手機短信(SMS)工作原理

      在本文中,我們將會分析短信的工作原理,探究它的使用并了解有的時候短信需要很長一段時間才能到達接收者的原因。   SMS表示短信服務。簡單來講,它是在手機
    發表于 10-30 16:21 ?101次下載

    基于80C31的短信息終端電話開發

      現在,短信服務日益普及。各個電話機廠家競相設計和開發短信息終端電話。為配合我所開發
    發表于 11-08 10:33 ?1694次閱讀
    基于80C31的<b class='flag-5'>短信</b>息終端<b class='flag-5'>電話</b><b class='flag-5'>開發</b>

    EIC-NS20短信服務器用戶指南

      EIC-NS20智能短信服務器是一個通過以太網收發短消息的服務器。EIC-NS20智能短信服務器依賴GSM網絡來收發短信息,可用于短信
    發表于 09-22 12:41 ?2次下載
    EIC-NS20<b class='flag-5'>短信服務</b>器用戶指南

    三大運營商計劃推出的升級版短信服務5G消息有哪些特點

    4月11日消息,據媒體報道,三大運營商計劃在年內推出升級版短信服務5G消息。
    的頭像 發表于 04-12 09:23 ?3173次閱讀

    微軟Office Outlook Lite服務升級,支持短信功能

    據報道,微軟于今日宣布更新 Outlook Lite 服務,使其支持 SMS 短信功能。微軟稱,通過此項升級,用戶現可整合管理電子郵件及 SMS
    的頭像 發表于 05-28 11:41 ?642次閱讀

    鴻蒙開發電話服務:【@ohos.telephony.call (撥打電話)】

    call模塊提供呼叫管理功能,包括撥打電話、跳轉到撥號界面、獲取通話狀態、格式化電話號碼等。
    的頭像 發表于 06-15 09:13 ?931次閱讀
    <b class='flag-5'>鴻蒙</b><b class='flag-5'>開發電話</b><b class='flag-5'>服務</b>:【@<b class='flag-5'>ohos.telephony</b>.call (撥打<b class='flag-5'>電話</b>)】

    鴻蒙開發電話服務:【@ohos.telephony.observer (observer)】

    訂閱網絡狀態變化事件,使用callback方式作為異步方法。
    的頭像 發表于 06-15 09:18 ?588次閱讀
    <b class='flag-5'>鴻蒙</b><b class='flag-5'>開發電話</b><b class='flag-5'>服務</b>:【@<b class='flag-5'>ohos.telephony</b>.observer (observer)】

    鴻蒙開發電話服務ohos.telephony.simSIM卡管理

    獲取指定卡槽SIM卡是否激活,使用callback方式作為異步方法。
    的頭像 發表于 06-16 22:28 ?450次閱讀
    <b class='flag-5'>鴻蒙</b><b class='flag-5'>開發電話</b><b class='flag-5'>服務</b>:<b class='flag-5'>ohos.telephony</b>.sim<b class='flag-5'>之</b>SIM卡管理

    鴻蒙開發電話服務ohos.telephony.data蜂窩數據

    獲取默認移動數據的SIM卡,使用callback方式作為異步方法。
    的頭像 發表于 06-18 09:31 ?376次閱讀
    <b class='flag-5'>鴻蒙</b><b class='flag-5'>開發電話</b><b class='flag-5'>服務</b>:<b class='flag-5'>ohos.telephony</b>.data<b class='flag-5'>之</b>蜂窩數據
    青浦区| 大发888客户端de 软件| 梦幻城百家乐的玩法技巧和规则| 哪个百家乐网站信誉好| 累积式百家乐的玩法技巧和规则 | 百家乐官网五湖四海娱乐网 | 真龙娱乐城| 太阳城百家乐官网赌场| 真人百家乐官网做假| 百家乐官网无损打法| 博狗百家乐真实| 新百家乐庄闲路单图记录| 布加迪百家乐的玩法技巧和规则| 香港六合彩开奖历史记录| 百家乐官网游戏算牌| 去澳门百家乐官网娱乐城| 小孟百家乐官网的玩法技巧和规则 | 百家乐百乐发破解版| 大发888老虎机手机版| 五台县| 百家乐游戏软件出售| 百家乐官网娱乐城游戏| 百家乐官网英皇娱乐城| 百家乐现金网平台| 星河百家乐的玩法技巧和规则| 太阳神网上娱乐| 丹棱县| 大发888舍出同线牌| 云鼎百家乐官网注册| 百家乐官网庄家怎样赚钱| 百家乐9点直赢| 莒南县| 百家乐娱乐开户| 516棋牌游戏中心 官方版| 网络百家乐官网漏洞| 游戏机百家乐下载| 香港六合彩网| 骰子百家乐官网的玩法技巧和规则 | 威尼斯人娱乐城反水| 百家乐官网览| 百博百家乐的玩法技巧和规则|