上篇文章介绍了组定长的核心方法,准备说说组定长报文的规则和对中文的处理
定长报文规则
- 定长报文的长度按字节计算
- 值的长度不够时,需要填充指定字符,以满足定长要求
- 常用填充方式
左补“0”:表示数值或参与数值计算的信息,长度不够左补“0”
金额:一般以“分”为单位,长度不够左补“0”;
右补“空格”:除以上两种情况以外,长度不够右补“空格”;
以上规则是我在项目中遇到的,其他项目的具体规定可能不一样,但是其中的思路应该相通的。我对补“0”和 补“空格”一直没搞明白原因,在我看来全都补“空格”也没什么问题啊!有知道原因的大佬请不吝赐教!!!
定长报文中文字节长度计算,以及填充一个要素值的方法
英文字母,数字容易计算字节长度,取字符数就可以了。但是中文的字节长度是和字符集相关的,GBK是两个字节,UTF-8是3个字节。因此要计算一个含中文要素值的字节长度,一般需要知道要素值中中文的个数。
- 英文,数字计算字节数
public static int getEnStringLength(String s){
if(s == null){
return 0;
}
//字符数即字节数
return s.length();
}
- 中文计算字节数: 下面的方法不用对字符串中的中文进行计数,可直接计算含任意个数中文的字符串的字节数
/**
* 按报文约定字符集获取字符串字节数(用于中文字符串)
*/
public static int getCNStringLength(String s, String charset) throws UnsupportedEncodingException{
if(s == null){
return 0;
}
//charset 报文约定字符集
return s.getBytes(charset).length;
}
- 获取要素值的正确字节数,(包括英文,数字,中文)
public static int getValueLength(String s, String charset) throws UnsupportedEncodingException{
if(s == null){
return 0;
}
return Math.max(s.length(), getCNStringLength(s, charset));
}
- 填充一个要素值
/**
* 填充一个要素
* @param value 要素值
* @param stdLength 要素标准长度(最大长度)
* @param charset 约定字符集
* @return
* @throws UnsupportedEncodingException
*/
public static String fillValue(String value, int stdLength, String charset) throws UnsupportedEncodingException{
//要素值的字节数
int sLength = getValueLength(value, charset);
if (sLength >= stdLength){
return value;
}
//不足的长度
int restLength = stdLength - sLength;
//paddingSpacesByCache参看上一篇文章《java高效组定长报文》
return FixedMsgUtil.paddingSpacesByCache(restLength, value);
}