Terry.Li-彬

          虛其心,可解天下之問;專其心,可治天下之學(xué);靜其心,可悟天下之理;恒其心,可成天下之業(yè)。

            BlogJava :: 首頁(yè) :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理 ::
            143 隨筆 :: 344 文章 :: 130 評(píng)論 :: 0 Trackbacks

          XML中二進(jìn)制數(shù)據(jù)的處理方法

            在xml中,所有的數(shù)據(jù)都是以文本的形式來(lái)顯示,但是二進(jìn)制數(shù)據(jù)不能直接以文本格式來(lái)表示,那xml又是怎么處理二進(jìn)制數(shù)據(jù)的呢?下面就來(lái)探討一下。

             為了簡(jiǎn)單和通用性,xml被設(shè)計(jì)成了以文本的格式來(lái)表示數(shù)據(jù)。在xml中,所有的數(shù)據(jù)都是以文本的格式來(lái)存儲(chǔ),二進(jìn)制數(shù)據(jù)也不例外。在xml中,二進(jìn)制數(shù)據(jù)也要被編碼成文本的格式,發(fā)送到目的方。目的方接收到這個(gè)文本二進(jìn)制數(shù)據(jù)以后,再以相同的解碼程序解成相應(yīng)的二進(jìn)制數(shù)據(jù),當(dāng)然數(shù)據(jù)原來(lái)的格式,名稱等輔助信息一定要當(dāng)作相關(guān)信息一起發(fā)送。一般二進(jìn)制數(shù)據(jù)編碼成BASE64格式,它的優(yōu)點(diǎn)是容易易于編碼和解碼,缺點(diǎn)是比純的二進(jìn)制多占用33%的存儲(chǔ)空間。

          下面是具體的程序?qū)崿F(xiàn):

          <%@ page contentType="text/html; charset=gb2312" %>

          <%@ page import="java.io.*" %>

          <%

          String ret=new String();

                try

                {

                 

                  InputStream in=new FileInputStream("c:\\aaa.doc");

                  byte[] bytes=new byte[in.available()];

                        in.read(bytes);

                  ret=new sun.misc.BASE64Encoder().encode(bytes); //具體的編碼方法

                  in.close();

                }

                catch(FileNotFoundException e)

                {

                   e.printStackTrace();

                }

                catch(java.io.IOException ex)

                {

                   ex.printStackTrace();

                }

          %>

          ret就是最后的結(jié)果,編碼以后就可以用標(biāo)準(zhǔn)的xml方式發(fā)送了。發(fā)送到目的方以后,還要對(duì)數(shù)據(jù)進(jìn)行相應(yīng)的解碼,才能得到原來(lái)的二進(jìn)制文件,解碼的代碼如下:

          <%@ page contentType="text/html; charset=gb2312" %>

          <%@ page import="java.io.*" %>

          <%

          byte[] bytes = new sun.misc.BASE64Decoder().decodeBuffer(ret);  

          java.io.ByteArrayInputStream inStream=new java.io.ByteArrayInputStream(bytes);

          byte[]  buffer =new  byte[1444];

          FileOutputStream fs=new FileOutputStream( "d:\\aaa.doc");

          int bytesum=0;

          int byteread=0;    

          while ((byteread=inStream.read(buffer))!=-1)

            {    

               bytesum+=byteread;

               fs.write(buffer,0,byteread);

               } 

          %>

          BASE64可以處理不太大的數(shù)據(jù),如果要移動(dòng)大量的數(shù)據(jù),且要考慮空間/時(shí)間效率時(shí),要采用其他的替代方法。
           
          黑白琴鍵http://www.cnblogs.com/jebit/articles/8252.aspxSat, 01 May 2004 21:28:00 GMThttp://www.cnblogs.com/jebit/articles/8252.aspxhttp://www.cnblogs.com/jebit/comments/8252.aspxhttp://www.cnblogs.com/jebit/articles/8252.aspx#Feedback0http://www.cnblogs.com/jebit/comments/commentRss/8252.aspxhttp://www.cnblogs.com/jebit/services/trackbacks/8252.aspx CSDN - 文檔中心 - Java     

          posted on 2007-09-06 18:15 禮物 閱讀(836) 評(píng)論(0)  編輯  收藏 所屬分類: java
          主站蜘蛛池模板: 灵宝市| 黄大仙区| 巩留县| 栖霞市| 德州市| 左云县| 甘肃省| 万年县| 成都市| 腾冲县| 峨山| 喀什市| 兴和县| 永州市| 疏勒县| 澜沧| 改则县| 枣强县| 康马县| 高州市| 闵行区| 永清县| 贵港市| 奉节县| 卓资县| 海丰县| 北流市| 高平市| 黔江区| 凉城县| 连州市| 通渭县| 邹平县| 灵石县| 南昌县| 通江县| 安丘市| 鹤山市| 蒙自县| 尼木县| 九寨沟县|