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