SMS编码及解码规范(2)

2024-02-24 18:18
文章标签 编码 解码 规范 sms

本文主要是介绍SMS编码及解码规范(2),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

例2 发送:SMSC号码是+8613800250500,对方号码是13851872468,消息消息内容是“你好!”,从手发出的PDU串可以是:
 08 91 68 31 08 20 05 05 F0 11 00 0D 91 68 31 58 81 27 64 F8 00 08 30 30 21 80 63 54 80 06 4F 60 59 7D 00 21
对照规范,以上数据信息的含义见表2
           表2 PDU串数据信息说明

分段

含义

说明

08

SMSC地址信息的长度

共8个8位字节(包括91)

91

SMSC地址格式(TON/NPI)

用国际格式号码(在前面加“+”

68 31 08 20 05 05 FD

SMSC地址

8613800250500,补”F”凑成偶数个

11

基本参数(TP-MTI/VFP)

发送,TP-VP用相对格式

00

消息基准值(TP-MR)

0

0D

目标地址数字个数

共13个十进制数

91

SMSC地址格式(TON/NPI)

用国际格式号码(在前面加“+”

68 31 58 81 27 64 F8

目标地址(TP-DA)

8613851872468,补”F”凑成偶数个

00

协议标识(TP-TID)

是普通GSM类型,点到点方式

08

用户信息编码方式(TP-DCS)

UCS编码

30 30 21 80 63 54 80

时间戳(TP-SCTS)

2003-3-12 08:36:45 +8时区

06

用户信息长度(TP-UDL)

实际长度6个字节

4F 60 59 7D 00 21

用户信息(TP-UD)

“你好”

下面详细介绍7-bit和UCS2编码

在PDU Mode中,可以采用三种编码方式来对发送的内容进行编码,它们是7-bit、8-bit和UCS2编码。7-bit编码用于发送普通的ASCII字符, 它将一串7-bit的字符(最高位为0)编成8-bit的数据,每8个字符可“压缩”成7个,8-bit编码通常用于发送数据消息,比如略图片和*** 等;而UCS2编码用于发送Unicode字符。在这三种编码方式下,PDU串的用户信息(TP-UD)璺最大容量(可以发送的短消息的最大字符数)分别 是160、140和70.这里,将一个杋英文字母、一个汉字和一个数据字节视为一个字符。

需要注意的是,PDU 串的用户信息长度(TP-UDL),在各种编码方式下意义有所不同。7-bit编码时,指原始消息的字符个数,而不是编码后的字节数。8-bit编码时, 就是字节数。UCS2编码时,也昌字节数,等于原始短消息的字节数的两倍,如果用户信息(TP-UD)中存在一具头(基本参数的TP-UDHI为1),在 所有编码方式下,用户信息长度(TP-USL)都等于头长度与编码后字节数之和。如果采用GSM03.42所建议的压缩法(TP-DCS的高3位为 001),则该长度也是压缩编码后字节数或头长度与压缩编码后字节数之和。

这篇关于SMS编码及解码规范(2)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/742938

相关文章

MySQL高性能优化规范

前言:      笔者最近上班途中突然想丰富下自己的数据库优化技能。于是在查阅了多篇文章后,总结出了这篇! 数据库命令规范 所有数据库对象名称必须使用小写字母并用下划线分割 所有数据库对象名称禁止使用mysql保留关键字(如果表名中包含关键字查询时,需要将其用单引号括起来) 数据库对象的命名要能做到见名识意,并且最后不要超过32个字符 临时库表必须以tmp_为前缀并以日期为后缀,备份

C++ | Leetcode C++题解之第393题UTF-8编码验证

题目: 题解: class Solution {public:static const int MASK1 = 1 << 7;static const int MASK2 = (1 << 7) + (1 << 6);bool isValid(int num) {return (num & MASK2) == MASK1;}int getBytes(int num) {if ((num &

C语言 | Leetcode C语言题解之第393题UTF-8编码验证

题目: 题解: static const int MASK1 = 1 << 7;static const int MASK2 = (1 << 7) + (1 << 6);bool isValid(int num) {return (num & MASK2) == MASK1;}int getBytes(int num) {if ((num & MASK1) == 0) {return

form表单提交编码的问题

浏览器在form提交后,会生成一个HTTP的头部信息"content-type",标准规定其形式为Content-type: application/x-www-form-urlencoded; charset=UTF-8        那么我们如果需要修改编码,不使用默认的,那么可以如下这样操作修改编码,来满足需求: hmtl代码:   <meta http-equiv="Conte

JavaEE7 Servlet 3.1(JSR 340)规范中文版

http://www.iteye.com/news/27727-jinnianshilongnian     Jave EE 7中的部分规范已正式获得批准通过,其中包括JSR340 Java Servlet 3.1规范,去年翻译了该规范,在此分享出来,希望对某些朋友有所帮助,不足之处请指正。   点击直接下载    在线版目录   Servlet3.1规范翻译

FFmpeg系列-视频解码后保存帧图片为ppm

在正常开发中遇到花屏时怎么处理呢?可以把解码后的数据直接保存成帧图片保存起来,然后直接看图片有没有花屏来排除是否是显示的问题,如果花屏,则代表显示无问题,如果图片中没有花屏,则可以往显示的方向去排查了。 void saveFrame(AVFrame* pFrame, int width, int height, int iFrame){FILE *pFile;char szFilename[

4-4.Andorid Camera 之简化编码模板(获取摄像头 ID、选择最优预览尺寸)

一、Camera 简化思路 在 Camera 的开发中,其实我们通常只关注打开相机、图像预览和关闭相机,其他的步骤我们不应该花费太多的精力 为此,应该提供一个工具类,它有处理相机的一些基本工具方法,包括获取摄像头 ID、选择最优预览尺寸以及打印相机参数信息 二、Camera 工具类 CameraIdResult.java public class CameraIdResult {

Python字符编码及应用

字符集概念 字符集就是一套文字符号及其编码的描述。从第一个计算机字符集ASCII开始,为了处理不同的文字,发明过几百种字符集,例如ASCII、USC、GBK、BIG5等,这些不同的字符集从收录到编码都各不相同。在编程中出现比较严重的问题是字符乱码。 几个概念 位:计算机的最小单位二进制中的一位,用二进制的0,1表示。 字节:八位组成一个字节。(位与字节有对应关系) 字符:我们肉眼可见的文字与符号。

在Eclipse环境下修改Tomcat编码的问题

问题: 由于BMS需要设置UTF-8编码,要不就会出现中文乱码问题; 一、项目保持UTF-8格式; 二、由于可能会多次移除项目、加载项目,不想每次都要修改tmp0\conf 原因: 如果在eclipse中配置了tomcat后,其实,tomcat所用的所有tomcat配置文件,都不是catalina_home/config下面的xml文件,而是在eclipse所创建的Serve