找回密码
 加入我们

QQ登录

只需一步,快速开始

搜索
查看: 2525|回复: 7

[写号相关] 一篇有关sms的文章,请大家看一下

[复制链接]
发表于 2007-4-11 20:46 | 显示全部楼层 |阅读模式
原文在http://www.dreamfabric.com/sms/ 详细的解释了sms的编码等问题。
2 I  e! q: ]+ ~6 r: n% O, B8 I8 HSMS and the PDU format1 k+ _3 U* v# a% i  D

, O1 f/ c3 c/ s+ l3 rIntroduction
- r: A+ L( [* e8 a3 G& C) M' |The SMS message, as specified by the Etsi organization (documents GSM 03.40 and GSM 03.38), can be up to 160 characters long, where each character is 7 bits according to the 7-bit default alphabet. Eight-bit messages (max 140 characters) are usually not viewable by the phones as text messages; instead they are used for data in e.g. smart messaging (images and ringing tones) and OTA provisioning of WAP settings. 16-bit messages (max 70 characters) are used for Unicode (UCS2) text messages, viewable by most phones. A 16-bit text message of class 0 will on some phones appear as a Flash SMS (aka blinking SMS or alert SMS). : Y4 O  J0 e$ ^- J

0 h. Q4 t8 s8 x
& x( P  T& f9 Q7 K2 A7 \0 V  E  _The PDU format+ R' j/ j* H8 h- e  R8 O
There are two ways of sending and receiving SMS messages: by text mode and by PDU (protocol description unit) mode. The text mode (unavailable on some phones) is just an encoding of the bit stream represented by the PDU mode. Alphabets may differ and there are several encoding alternatives when displaying an SMS message. The most common options are "PCCP437", "PCDN", "8859-1", "IRA" and "GSM". These are all set by the at-command AT+CSCS, when you read the message in a computer application. If you read the message on your phone, the phone will choose a proper encoding. An application capable of reading incoming SMS messages, can thus use text mode or PDU mode. If text mode is used, the application is bound to (or limited by) the set of preset encoding options. In some cases, that's just not good enough. If PDU mode is used, any encoding can be implemented.
$ _" Y% c8 d  l* ?  jReceiving a message in the PDU mode) _) M, t1 w# O" t
The PDU string contains not only the message, but also a lot of meta-information about the sender, his SMS service center, the time stamp etc. It is all in the form of hexa-decimal octets or decimal semi-octets. The following string is what I received on a Nokia 6110 when sending the message containing "hellohello" from www.mtn.co.za. 9 d0 |  e# L1 V) Q  h
07        917283010010F5        040BC87238880900F10000993092516195800AE8329BFD4697D9EC37/ K" p( y+ b& f) A$ V
2 U6 E0 H& s$ W3 I2 o7 \
* _$ U. y* c- i* D4 A2 I: j; C. ~
This octet sequence consists of three parts: An initial octet indicating the length of the SMSC information ("07"), the SMSC information itself ("917283010010F5"), and the SMS_DELIVER part (specified by ETSI in GSM 03.40).
2 @- a& k8 b0 C
' x) S4 u/ ?( sNote: on some phones (e.g. Ericssson 888?) the first three (colored) parts are omitted when showing the message in PDU mode! / e& i7 _/ e+ r( n) Q
Octet(s)        Description% Z9 Y9 k# @8 r$ m7 I& B" O
07        Length of the SMSC information (in this case 7 octets)- T$ r  ]8 {' f6 R
91        Type-of-address of the SMSC. (91 means international format of the phone number)4 V. A" l7 W* D- V* i$ `
72 83 01 00 10 F5        Service center number(in decimal semi-octets). The length of the phone number is odd (11), so a trailing F has been added to form proper octets. The phone number of this service center is "+27381000015". See below.
) L1 y7 @- K, l1 k7 T8 ?04        First octet of this SMS-DELIVER message.
  Z5 H" B' e' r0B        Address-Length. Length of the sender number (0B hex = 11 dec)& l) }4 |- U; _: Y/ N5 p& }
C8        Type-of-address of the sender number( Z6 A2 a" {8 _% N9 [
72 38 88 09 00 F1        Sender number (decimal semi-octets), with a trailing F! @; n; l0 C7 N9 ]
00        TP-PID. Protocol identifier.6 f* m6 o) a% e
00        TP-DCS Data coding scheme
( v! N1 N: G, C99 30 92 51 61 95 80        TP-SCTS. Time stamp (semi-octets)
2 v) Z; o6 {# }3 _0A        TP-UDL. User data length, length of message. The TP-DCS field indicated 7-bit data, so the length here is the number of septets (10). If the TP-DCS field were set to indicate 8-bit data or Unicode, the length would be the number of octets (9).
( \" b/ t* ?$ y" s  bE8329BFD4697D9EC37        TP-UD. Message "hellohello" , 8-bit octets representing 7-bit data.
$ \, c! G( u& g4 C* U$ U( t, ~6 N9 a) |9 h6 ^1 I7 S) V

# m/ n* F* [* K  M& o. F# k9 ^0 K! t& P/ z' \8 K4 n% N% {* x- b8 k
All the octets above are hexa-decimal 8-bit octets, except the Service center number, the sender number and the timestamp; they are decimal semi-octets. The message part in the end of the PDU string consists of hexa-decimal 8-bit octets, but these octets represent 7-bit data (see below). 1 j* w+ L; e4 v0 \8 F5 ~, y

& S' J. i( v. W$ @& D" VThe semi-octets are decimal, and e.g. the sender number is obtained by performing internal swapping within the semi-octets from "72 38 88 09 00 F1" to "27 83 88 90 00 1F". The length of the phone number is odd, so a proper octet sequence cannot be formed by this number. This is the reason why the trailing F has been added. The time stamp, when parsed, equals "99 03 29 15 16 59 08", where the 6 first characters represent date, the following 6 represents time, and the last two represents time-zone related to GMT.
; ^( \% S: y$ q3 c. `# H  M: l( i7 {$ e* P/ [0 b- z+ ?
Interpreting 8-bit octets as 7-bit messages+ i& _8 g, u) G0 T& F
This transformation is described in detail in GSM 03.38, and an example of the "hellohello" transformation is shown here. The transformation is based on the 7 bit default alphabet , but an application built on the PDU mode can use any character encoding.
! U, H8 y, H$ A$ Y4 O& M  kSending a message in the PDU mode
8 k: d( x$ ^" ?2 C% \# W+ x4 r3 sThe following example shows how to send the message "hellohello" in the PDU mode from a Nokia 6110.
! D. Q8 Y4 \% K9 q+ K
% d2 h+ [. z8 C8 \& A1 i, G! _
' o% D7 X: V) N" O6 NAT+CMGF=0    //Set PDU mode
* E) i1 d3 `9 ^) @! A         AT+CSMS=0    //Check if modem supports SMS commands ' L$ h; V4 P0 ~+ B, C
         AT+CMGS=23  //Send message, 23 octets (excluding the two initial zeros)
& S& ?8 v4 y6 }9 X. a>0011000B916407281553F80000AA0AE8329BFD4697D9EC37<ctrl-z> . z5 r7 [0 C' A' h( U) U% i- d
There are 23 octets in this message (46 'characters'). The first octet ("00") doesn't count, it is only an indicator of the length of the SMSC information supplied (0). The PDU string consists of the following:
1 v0 {+ c, ]. v! b  A6 i- q' Z  bOctet(s)&#160; &#160; &#160; &#160; Description 1 [: x0 C$ w0 l4 Q
00 &#160; &#160; &#160; &#160; Length of SMSC information. Here the length is 0, which means that the SMSC stored in the phone should be used. Note: This octet is optional. On some phones this octet should be omitted! (Using the SMSC stored in phone is thus implicit) 3 ^) a8 ^/ H( }4 r4 y4 F
11 &#160; &#160; &#160; &#160; First octet of the SMS-SUBMIT message.
" }) `$ _0 a2 D5 T' d( p8 z00 &#160; &#160; &#160; &#160; TP-Message-Reference. The "00" value here lets the phone set the message reference number itself. * l; _7 \; W  ]! f/ n
0B &#160; &#160; &#160; &#160; Address-Length. Length of phone number (11)
( p: o- ]( }  J. ]* m91 &#160; &#160; &#160; &#160; Type-of-Address. (91 indicates international format of the phone number). 7 N6 E% R& X" V( C0 k, B; ^+ o
6407281553F8 &#160; &#160; &#160; &#160; The phone number in semi octets (46708251358). The length of the phone number is odd (11), therefore a trailing F has been added, as if the phone number were "46708251358F". Using the unknown format (i.e. the Type-of-Address 81 instead of 91) would yield the phone number octet sequence 7080523185 (0708251358). Note that this has the length 10 (A), which is even.
# i% \8 ~# l8 I00 &#160; &#160; &#160; &#160; TP-PID. Protocol identifier
$ u' S1 q9 N0 q# d00 &#160; &#160; &#160; &#160; TP-DCS. Data coding scheme.This message is coded according to the 7bit default alphabet. Having "04" instead of "00" here, would indicate that the TP-User-Data field of this message should be interpreted as 8bit rather than 7bit (used in e.g. smart messaging, OTA provisioning etc).
! a  _! s4 ~9 o. @3 `AA &#160; &#160; &#160; &#160; TP-Validity-Period. "AA" means 4 days. Note: This octet is optional, see bits 4 and 3 of the first octet
8 }5 ~, U1 E0 V/ P  k0A &#160; &#160; &#160; &#160; TP-User-Data-Length. Length of message. The TP-DCS field indicated 7-bit data, so the length here is the number of septets (10). If the TP-DCS field were set to 8-bit data or Unicode, the length would be the number of octets. - ^# L" d, M+ z9 O. K1 w
E8329BFD4697D9EC37 &#160; &#160; &#160; &#160; TP-User-Data. These octets represent the message "hellohello". How to do the transformation from 7bit septets into octets is shown here7 Y: n* ?2 X$ `

6 I( ]* k1 s: C# y另外我还找到了nokia cdma at 命令的有关文档,就不知我们的treo是不是也支持。按道理nokia和高通有技术专利共享的话可能有用。$ {+ M6 P" I; d. ?

( [) W9 B5 }% _8 c, v[ 本帖最后由 Merlin99cn 于 2007-4-11 20:53 编辑 ]

AT_Command_Set_For_Nokia_CDMA_Products_v1_1_en.pdf

1.82 MB, 下载次数: 948

头像被屏蔽
发表于 2007-4-11 22:08 | 显示全部楼层
提示: 作者被禁止或删除 内容自动屏蔽
发表于 2007-4-11 22:12 | 显示全部楼层
谢谢楼主分享资料....
7 n0 ]% {1 P' V# U
8 i/ s7 d1 d5 n有兴趣的朋友们可以琢磨一下哈
发表于 2007-4-11 22:42 | 显示全部楼层
上面是GSM实现sms编码的,对CDMA作用不大
: |4 [1 i2 ^2 x6 _( R' m  g7 \+ B7 @: Z4 s9 Q9 N( j
下面NOKIA的PDF记得看过,SMS部分就三条AT,看起来跟GSM的一样,但在650上不能执行
发表于 2007-4-12 08:34 | 显示全部楼层
顶类似此类的信息
发表于 2007-4-12 09:17 | 显示全部楼层
呵呵,病急乱投医
发表于 2007-4-13 02:14 | 显示全部楼层
完全看不懂!
发表于 2007-4-13 19:27 | 显示全部楼层
看不懂       看懂  意思也难懂           郁闷
您需要登录后才可以回帖 登录 | 加入我们

本版积分规则

QQ|Archiver|手机版|小黑屋|吹友吧 ( 京ICP备05078561号 )

GMT+8, 2025-1-21 22:00 , Processed in 0.287759 second(s), 18 queries .

Powered by Discuz! X3.5 Licensed

© 2001-2024 Discuz! Team.

快速回复 返回顶部 返回列表