- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我们正在使用 SMPP cloud-hopper 库将长消息发送到 SMS gateway Innovativetxt.com,但当我们将长消息拆分为每个部分 140 字节时,似乎是这样。每条消息的字符数达到134个字符。
然而,行业标准是 GSM 编码长消息的每一部分都应包含 153 个字符。当我们通过 140 字节拆分时,我们只有 134 个字符是不是做错了什么?如果我们尝试提交大于 140 字节的消息,网关提供商会拒绝它,消息正文过大。
应将消息拆分为每条 153 个字符以发送到 SMSC,而不是通过每条 140 字节发送消息。
拆分长消息的最佳方法是什么?按消息大小,即 140 字节或消息字符计数?
任何人都通过 cloudhopper 或其他基于 Java 的库遇到过同样的问题,我们应该怎么做。
最佳答案
这是一个常见的混淆。你做的一切都是对的。消息长度可以是 160 个字符(7 位 GSM 03.38)、140 个字符(8 位拉丁文)、70 个字符(16 位 UCS-2)。注意:160 * 7 == 140 * 8 == 70 * 16。
当您拆分一条长消息时,总部件号和部件索引等附加信息存储在消息正文中,即所谓的用户数据 header (UDH)。这个标题也发生了。因此,对于 UDH,您留下了 153 个 GSM 字符(7 位)、134 个字符/字节(8 位)有效负载或 67 个 2 字节-unicode 字符(16 位)
另见 http://www.nowsms.com/long-sms-text-messages-and-the-160-character-limit
在您的情况下,对于 8 位的 Contatenated 消息,UDH 的长度为 6 个字节。
UDH结构
0x05: Length of UDH (5 bytes to follow)0x00: Concatenated message Information Element (8-bit reference number)0x03: Length of Information Element data (3 bytes to follow)0xXX: Reference number for this concatenated message0xYY: Number of fragments in the concatenated message0xZZ: Fragment number/index within the concatenated message
Total message length, bits: 160*7 = 140*8 = 1120UDH length, bits: 6*8 = 48Left payload, bits: 1120-48 = 1072
For GSM 03.38 you get 1072/7 = 153 GSM (7-bit) chars + 1 filling unused bit.For Latin you get 1072/8 = 134 (8-bit) chars.For UCS-2 you get 1072/16 = 67 (16-bit) chars.
如您所见,153 个 GSM 字符等于 134 个字节减去 1 位。可能这 134 个字符就是 Java 报告给您的。但是一旦你拆分了你的长文本消息,你最终会得到一个包含文本和 UDH 的二进制消息。并且您应该将消息视为二进制。我建议您从结果部分制作二进制转储并进行调查。
关于java - SMPP 提交长消息和消息拆分,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21098643/
我有一个如下所示的数据框: import pandas as pd d = {'decil': ['1. decil','1. decil','2. decil','2. decil','3. dec
我有一些数据想要添加到我的应用中...大约 650 个类别(包括名称 + ID 号),每个类别平均有 85 个项目(每个都有一个名称/ID 号)。 iPhone会支持这么大的plist吗?我想首先在
我目前正在使用 Python 从头开始实现决策树算法。我在实现树的分支时遇到了麻烦。在当前的实现中,我没有使用深度参数。 发生的情况是,要么分支结束得太快(如果我使用标志来防止无限递归),要么如果
我在 Stack 上发现了这个问题 - Measuring the distance between two coordinates in PHP 这个答案在很多方面似乎对我来说都是完美的,但我遇到了
我目前正在清理一个具有 2 个索引和 2.5 亿个事件行以及大约同样多(或更多)的死行的表。我从我的客户端计算机(笔记本电脑)向我的服务器发出命令 VACCUM FULL ANALYZE。在过去的 3
这一切都有点模糊,因为该计划是相当深入的,但坚持我,因为我会尽量解释它。我编写了一个程序,它接受一个.csv文件,并将其转换为MySQL数据库的INSERT INTO语句。例如: ID Numbe
我有一个地址示例:0x003533,它是一个字符串,但要使用它,我需要它是一个 LONG,但我不知道该怎么做:有人有解决方案吗? s 字符串:“0x003533”到长 0x003533 ?? 最佳答案
请保持友善 - 这是我的第一个问题。 =P 基本上作为一个暑期项目,我一直在研究 wikipedia page 上的数据结构列表。并尝试实现它们。上学期我参加了 C++ 类(class),发现它非常有
简单的问题。想知道长 IN 子句是否是一种代码味道?我真的不知道如何证明它。除了我认为的那样,我不知道为什么它会闻起来。 select name, code, capital, pop
我正在尝试基于 C# 中的种子生成一个数字。唯一的问题是种子太大而不能成为 int32。有什么方法可以像种子一样使用 long 吗? 是的,种子必须很长。 最佳答案 这是我移植的 Java.Util.
我一直想知道这个问题有一段时间了。在 CouchDB 中,我们有一些相当的日志 ID……例如: “000ab56cb24aef9b817ac98d55695c6a” 现在,如果我们正在搜索此项目并浏览
列的虚拟列 c和一个给定的值 x等于 1如果 c==x和 0 其他。通常,通过为列创建虚拟对象 c , 一排除一个值 x选择,因为最后一个虚拟列不添加任何信息 w.r.t.已经存在的虚拟列。 这是我如
使用 tarantool,为什么我要记录这些奇怪的消息: 2016-03-24 16:19:58.987 [5803] main/493623/http/XXX.XXX.XXX.XXX:57295 t
我显然是 GitHub 的新手,想确保在开始之前我做的事情是正确的。 我想创建一个新的存储库,它使用来自 2 个现有项目的复刻/克隆。现有项目不是我的。 假设我想使用的 repo 被称为来自开发人员“
我的应用程序名称长度为 17 个字符。当安装在设备上时,它看起来像应用程序...名称。有没有办法在多行上显示应用程序名称?请帮忙。 最佳答案 不,你不能。我认为 iPad 支持 15 个字符来完整显示
我必须编写一个程序来读取文件中的所有单词,并确定每个单词使用了多少次。我的任务是使用多线程来加快运行时间,但是单线程程序的运行速度比多线程程序快。我曾尝试研究此问题的解决方案,但很多解释只会让我更加困
假设我在给定的范围内有一个位置pos,这样: 0 = newRange*newRange : "Case not supported yet"; // Never happens in my code
我试图在 Java 中将 unix 时间四舍五入到该月的第一天,但没有成功。示例: 1314057600 (Tue, 23 Aug 2011 00:00:00 GMT) 至 1312156800
我们的项目有在 CVS 中从现有分支创建新分支的历史。几年后,这导致了每次发布时更改的文件上的这种情况: 新版本:1.145.4.11.2.20.2.6.2.20.2.1.2.11.2.3.2.4.4
我有以下数据框: DAYS7 <- c('Monday','Tuesday','Wednesday','Thursday','Friday', 'Saturday', 'Sunday') DAYS
我是一名优秀的程序员,十分优秀!