C CMPP3 0 超長簡訊

2021-09-22 09:01:50 字數 3927 閱讀 7172

1、長短資訊:是指超過70個漢字,140個位元組的資訊內容。

最近在做乙個某地市公司運營商的gprs導引專案的時候,運營商要求將對使用者的提示簡訊息(超過140個位元組)傳送到使用者手機,在使用者的手機上一次全顯示。

上網搜尋了一些相關的資料,現在將實現總結如下:

1.1.1.1cmpp_submit訊息定義(sp--->smg)

欄位名位元組數

屬性描述

msg_id

8unsigned integer

資訊標識。

pk_total

1unsigned integer

相同msg_id的資訊總條數,從1開始。

pk_number

1unsigned integer

相同msg_id的資訊序號,從1開始。

registered_delivery

1unsigned integer

是否要求返回狀態確認報告:

0:不需要;

1:需要。

msg_level

1unsigned integer

資訊級別。

service_id

10octet string

業務標識,是數字、字母和符號的組合。

fee_usertype

1unsigned integer

計費使用者型別字段:

0:對目的終端msisdn計費;

1:對源終端msisdn計費;

2:對sp計費;

3:表示本欄位無效,對誰計費參見

fee_terminal_id欄位。

fee_terminal_id

32octet string

被計費使用者的號碼,當fee_usertype為3時該值有效,當fee_usertype為0、1、2時該值無意義。

fee_terminal_type

1unsigned integer

被計費使用者的號碼型別,0:真實號碼;1:偽碼。

tp_pid

1unsigned integer

gsm協議型別。詳細是解釋請參考gsm03.40中的9.2.3.9。

tp_udhi

1unsigned integer

gsm協議型別。詳細是解釋請參考gsm03.40中的9.2.3.23,僅使用1位,右對齊。

msg_fmt

1unsigned integer

資訊格式:

0:ascii串;

3:簡訊寫卡操作;

4:二進位制資訊;

8:ucs2編碼;

15:含gb漢字。。。。。。

msg_src

6octet string

資訊內容**(sp_id)。

feetype

2octet string

資費類別:

01:對「計費使用者號碼」免費;

02:對「計費使用者號碼」按條計資訊費;

03:對「計費使用者號碼」按包月收取資訊費。

feecode

6octet string

資費**(以分為單位)。

valid_time

17octet string

存活有效期,格式遵循smpp3.3協議。

at_time

17octet string

定時傳送時間,格式遵循smpp3.3協議。

src_id

21octet string

源號碼。sp的服務**或字首為服務**的長號碼, 閘道器將該號碼完整的填到smpp協議submit_sm訊息相應的source_addr欄位,該號碼最終在使用者手機上顯示為短訊息的主叫號碼。

destusr_tl

1unsigned integer

接收資訊的使用者數量(小於100個使用者)。

dest_terminal_id

32*destusr_tl

octet string

接收簡訊的msisdn號碼。

dest_terminal_type

1unsigned integer

接收簡訊的使用者的號碼型別,0:真實號碼;1:偽碼。

msg_length

1unsigned integer

首席資訊官度(msg_fmt值為0時:<160個位元組;其它<=140個位元組),取值大於或等於0。

msg_content

msg_length

octet string

資訊內容。

linkid

20octet string

點播業務使用的linkid,非點播類業務的mt流程不使用該欄位。

紅色部分表示發長簡訊要更改的字段

洋紅色部分表示發長簡訊可以更改或者不更改的字段

(以下資料參考:

在cmpp協議裡,

cmpp­_submit

訊息定義中有相應的引數配置:

tp_udhi :0代表內容體裡不含有協議頭資訊 1代表內容含有協議頭資訊(長簡訊,push簡訊等都是在內容體上含有頭內容的)當設定內容體包含協議頭,需要根據協議寫入相應的資訊,長簡訊協議頭有兩種:

6位協議頭格式:05 00 03 xx mm nn

byte 1 : 05, 表示剩餘協議頭的長度

byte 2 : 00, 這個值在gsm 03.40規範9.2.3.24.1中規定,表示隨後的這批超長簡訊的標識位長度為1(格式中的xx值)。

byte 3 : 03, 這個值表示剩下簡訊標識的長度

byte 4 : xx,這批簡訊的唯一標誌,事實上,sme(手機或者sp)把訊息合併完之後,就重新記錄,所以這個標誌是否唯

一併不是很 重要。

byte 5 : mm, 這批簡訊的數量。如果乙個超長簡訊總共5條,這裡的值就是5。

byte 6 : nn, 這批簡訊的數量。如果當前簡訊是這批簡訊中的第一條的值是1,第二條的值是2。

例如:05 00 03 39 02 01

7位的協議頭格式:06 08 04 xx xx mm nn

byte 1 : 06, 表示剩餘協議頭的長度

byte 2 : 08, 這個值在gsm 03.40規範9.2.3.24.1中規定,表示隨後的這批超長簡訊的標識位長度為2(格式中的xx值)。

byte 3 : 04, 這個值表示剩下簡訊標識的長度

byte 4-5 : xx xx,這批簡訊的唯一標誌,事實上,sme(手機或者sp)把訊息合併完之後,就重新記錄,所以這個標誌是否唯一並不是很重要。

byte 6 : mm, 這批簡訊的數量。如果乙個超長簡訊總共5條,這裡的值就是5。

byte 7 : nn, 這批簡訊的數量。如果當前簡訊是這批簡訊中的第一條的值是1,第二條的值是2。

例如:06 08 04 00 39 02 01

二. 實現**(c#)

byte messageucs2 = encoding.bigendianunicode.getbytes(mtmsg);

int messageucs2len = messageucs2.length;

int maxmessagelen = 140;

if (messageucs2len > maxmessagelen)

else}}

三、總結。

cmpp髮長簡訊

1、tp_udhi設定為 0x01

2、msg_content 按tp_udhi協議填寫6位元組或者7位元組的tp_udhi協議頭然後加上經過usc2編碼的訊息內容。由tp_udhi協議頭和訊息內容體組成的msg_content總長度不能超過140個位元組

3、msg_fmt 設定為 0x08 ucs2編碼;

4、pk_total和pk_number 可以不設定,如果要設定,就要分別跟tp_udhi的mm和nn欄位一致

設定傳送超長簡訊

cmpp協議中,cmpp submit message中有兩個欄位pk total和pk numer,恰看起來,這就是傳送超長簡訊的設定引數,其實不然,這兩個引數的設定,應該是沒有用處。傳送超長簡訊,需要做兩件事情 設定tp udhi的值設定為1,在訊息正文中增加協議頭。協議後可以兩種格式,分別是長...

設定傳送超長簡訊

cmpp協議中,cmpp submit message中有兩個欄位pk total和pk numer,恰看起來,這就是傳送超長簡訊的設定引數,其實不然,這兩個引數的設定,應該是沒有用處。傳送超長簡訊,需要做兩件事情 設定tp udhi的值設定為1,在訊息正文中增加協議頭。協議後可以兩種格式,分別是長...

超長簡訊的處理辦法

gsm 03.40規範 tp 06 1999 12 15 7.4.0 中規定了sme對於超長簡訊的合併處理。規範制定至今,已經超過6年,絕大多數正在使用的手機,都支援這一功能。cmpp協議中,cmpp submit message中有兩個欄位pk total和pk numer,恰看起來,這就是傳送超...