`
web_in
  • 浏览: 13982 次
  • 性别: Icon_minigender_1
  • 来自: 广州
社区版块
存档分类
最新评论

[实用工具类与产品化] -- 金融类XML常用文本值转换【难度 ★★】

阅读更多
在金融系统中,经常会使用XML作为数据传输的载体,大家都有银联卡,在刷卡的瞬间,就有一张XML生产并传送都远方的服务器(有兴趣可以查询ISO20022标准)。

XML技术看似简单,但又容易被人忽视。例如许多人由数据库中提取的值,就直接嵌入XML中。表面上看好似没有问题,但万一数据库中存储的值有非法XML字符(如 >, ", ' 等)。则会破坏XML的完整性导致传送错误。

所以我们在提取数据库的值的时候,需要使用安全的字符转义。例如“>”可以转义为“">”。
下面是一个名为TextUtil的工具类,除了XML的转换方法外,还有一个金融数字的显示方法:

import java.text.DecimalFormat;

public class TextUtil {
    public static String changeFromTxtToSafeXML(String str){
        str = str.replace("&", "&");
        str = str.replace("<", "&lt;");
        str = str.replace(">", "&gt;");
        str = str.replace("\"", "&quot;");
        str = str.replace("'", "&apos");
        return str;
    }

    public static String changeFromSafeXMLToTxt(String str){
        str = str.replace("&amp;",  "&");
        str = str.replace("&lt;",   "<");
        str = str.replace("&gt;",   ">");
        str = str.replace("&quot;", "\"");
        str = str.replace("&apos;", "'");
        return str;
    }

    public static String financialDataFormat(double dblData){
        DecimalFormat fnclFormat = new DecimalFormat("#,###,###,##0.00");
        return fnclFormat.format(dblData);
    }

}


我们可以写个测试类来测试这个工具类:
public static void main(String[] args){
    String str1 = "I will try >_< and ^_^ and & ";
    System.out.println("Changed value:" + TextUtil.changeFromTxtToSafeXML(str1));
    double db1 = 6900.3;
    System.out.println("Changed value:" + TextUtil.financialDataFormat(db1));

}

输出的结果:
Changed value:I will try &gt;_&lt; and ^_^ and &amp;
Changed value:6,900.30

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics