用Java实现PDU编码

2024-01-01 04:08
文章标签 java 实现 编码 pdu

本文主要是介绍用Java实现PDU编码,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

PDU编码的方案网上很多,可以参考一下,我们只要按照协议格式去做就行了。要注意的一点是短消息内容需要进行Unicode编码转换。

1.发英文

 发英文时可以进行7bit编码或8bit编码.因为英文和数字等小于128的Ascii码,高位为0,所以,我们可以把最高位也利用起来,去掉最高位的0,然后,每个字节的位以次向前移动,这样一条短信就可以发最多160个字符。因为GSM协议规定短信最多是140个字节,这样的话总共是140×8=1120位,如果我们每个字节只占7位的话,那么就可以容下:1120/7=160个字符。

当然也可以用UCS2(也就是UTF-16,每个字符占两个字节),这样的话,发送只能发送最多有70个英文字符

2.发中文

发送中文时,必须用UCS2进行编码,最多可以发140/2=70个汉字。

接收到短消息之后,按编码方式进行解码就行了。

3.参考源代码:

 

package  com.gftech.common;

public   class  PduPack  {
 
// 短消息中心号长度
 private String smscLen;

 
private String smscFormat;

 
// 短消息中心号
 private String smsc;

 
// 源地址长度
 private int addrLen;

 
private String addrFormat;

 
// 源地址
 private String addr;

 
// 短消息内容编码方式,tp_dcs
 private String msgCoding;

 
// 时间戳,tp_scts
 
// private String timestamp;
 
 
private int msgLen;

 
// 短消息内容,tp_ud
 private String msgContent;

 
public PduPack() {
  smscLen 
= "08";
  smscFormat 
= "91";
  addrLen 
= 13;
  addrFormat 
= "91";

 }


 
public PduPack(String src) {

  
if (src != null && src.length() > 44{
   String temp 
= src.substring(418);
   smsc 
= GFString.interChange(temp);
   
if (smsc != null && smsc.length() > 1){
    smsc 
= smsc.substring(0, smsc.length() - 1);
    
if(smsc.length()==13)
     smsc
=smsc.substring(2);
   }


   temp 
= src.substring(2022);
   addrLen 
= Integer.parseInt(temp, 16);
   
if (addrLen % 2 == 0)
    temp 
= src.substring(2424 + addrLen);
   
else
    temp 
= src.substring(2424 + addrLen + 1);
   addr 
= GFString.interChange(temp);
   
// 去掉为补齐为偶数加上的那一位
   if (addr != null && addr.length() % 2 == 0{
    addr 
= addr.substring(0, addr.length() - 1);
    
if (addr.length() == 13)// 如果前面有86,去掉它
     addr = addr.substring(2);
   }

   
if (addrLen % 2 == 0{
    msgCoding 
= src.substring(24 + addrLen + 224 + addrLen + 4);
    temp 
= src.substring(24 + addrLen + 4 + 16);
   }
 else {
    msgCoding 
= src.substring(24 + addrLen + 324 + addrLen + 5);
    temp 
= src.substring(24 + addrLen + 5 + 16);

这篇关于用Java实现PDU编码的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Spring Boot整合Redis注解实现增删改查功能(Redis注解使用)

《SpringBoot整合Redis注解实现增删改查功能(Redis注解使用)》文章介绍了如何使用SpringBoot整合Redis注解实现增删改查功能,包括配置、实体类、Repository、Se... 目录配置Redis连接定义实体类创建Repository接口增删改查操作示例插入数据查询数据删除数据更

Java Lettuce 客户端入门到生产的实现步骤

《JavaLettuce客户端入门到生产的实现步骤》本文主要介绍了JavaLettuce客户端入门到生产的实现步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要... 目录1 安装依赖MavenGradle2 最小化连接示例3 核心特性速览4 生产环境配置建议5 常见问题

Java使用Swing生成一个最大公约数计算器

《Java使用Swing生成一个最大公约数计算器》这篇文章主要为大家详细介绍了Java使用Swing生成一个最大公约数计算器的相关知识,文中的示例代码讲解详细,感兴趣的小伙伴可以了解一下... 目录第一步:利用欧几里得算法计算最大公约数欧几里得算法的证明情形 1:b=0情形 2:b>0完成相关代码第二步:加

linux ssh如何实现增加访问端口

《linuxssh如何实现增加访问端口》Linux中SSH默认使用22端口,为了增强安全性或满足特定需求,可以通过修改SSH配置来增加或更改SSH访问端口,具体步骤包括修改SSH配置文件、增加或修改... 目录1. 修改 SSH 配置文件2. 增加或修改端口3. 保存并退出编辑器4. 更新防火墙规则使用uf

Java 的ArrayList集合底层实现与最佳实践

《Java的ArrayList集合底层实现与最佳实践》本文主要介绍了Java的ArrayList集合类的核心概念、底层实现、关键成员变量、初始化机制、容量演变、扩容机制、性能分析、核心方法源码解析、... 目录1. 核心概念与底层实现1.1 ArrayList 的本质1.1.1 底层数据结构JDK 1.7

Java Map排序如何按照值按照键排序

《JavaMap排序如何按照值按照键排序》该文章主要介绍Java中三种Map(HashMap、LinkedHashMap、TreeMap)的默认排序行为及实现按键排序和按值排序的方法,每种方法结合实... 目录一、先理清 3 种 Map 的默认排序行为二、按「键」排序的实现方式1. 方式 1:用 TreeM

Java中流式并行操作parallelStream的原理和使用方法

《Java中流式并行操作parallelStream的原理和使用方法》本文详细介绍了Java中的并行流(parallelStream)的原理、正确使用方法以及在实际业务中的应用案例,并指出在使用并行流... 目录Java中流式并行操作parallelStream0. 问题的产生1. 什么是parallelS

C++中unordered_set哈希集合的实现

《C++中unordered_set哈希集合的实现》std::unordered_set是C++标准库中的无序关联容器,基于哈希表实现,具有元素唯一性和无序性特点,本文就来详细的介绍一下unorder... 目录一、概述二、头文件与命名空间三、常用方法与示例1. 构造与析构2. 迭代器与遍历3. 容量相关4

Java中Redisson 的原理深度解析

《Java中Redisson的原理深度解析》Redisson是一个高性能的Redis客户端,它通过将Redis数据结构映射为Java对象和分布式对象,实现了在Java应用中方便地使用Redis,本文... 目录前言一、核心设计理念二、核心架构与通信层1. 基于 Netty 的异步非阻塞通信2. 编解码器三、

C++中悬垂引用(Dangling Reference) 的实现

《C++中悬垂引用(DanglingReference)的实现》C++中的悬垂引用指引用绑定的对象被销毁后引用仍存在的情况,会导致访问无效内存,下面就来详细的介绍一下产生的原因以及如何避免,感兴趣... 目录悬垂引用的产生原因1. 引用绑定到局部变量,变量超出作用域后销毁2. 引用绑定到动态分配的对象,对象