Dict.CN 在線詞典, 英語學(xué)習(xí), 在線翻譯

          都市淘沙者

          荔枝FM Everyone can be host

          統(tǒng)計

          留言簿(23)

          積分與排名

          優(yōu)秀學(xué)習(xí)網(wǎng)站

          友情連接

          閱讀排行榜

          評論排行榜

          Java解析網(wǎng)絡(luò)數(shù)據(jù)流的三種特殊方法

          Java作為最開放的語言,已越來越受到網(wǎng)絡(luò)程序員的青睞。但這一青睞族有著同樣的經(jīng)歷——曾經(jīng)都為網(wǎng)絡(luò)上通信的Java數(shù)據(jù)格式而煩腦。

          筆者也不例外,曾經(jīng)為此而查閱了很多文檔,經(jīng)過反復(fù)測試才得以解決,如今筆者已經(jīng)在所從事的很多電子政務(wù)項(xiàng)目中順利的應(yīng)用。今天筆者寫此文,介紹用Java解析網(wǎng)絡(luò)數(shù)據(jù)的三種特殊方法,希望對正在尋求這方面問題答案的讀者有所幫助。

          UTF8轉(zhuǎn)換成GB2312 當(dāng)我們在基于HTTP協(xié)議的JSP或Servlet的應(yīng)用中獲取數(shù)據(jù)或發(fā)送請求時,JVM會把輸送的數(shù)據(jù)編碼成UTF8格式。如果我們直接從HTTP流中提取中文數(shù)據(jù),提取的結(jié)果為“????”(可能更多問號),為轉(zhuǎn)換成我們能夠理解的中文字符,我們需要把UTF8轉(zhuǎn)換成GB2312,借助ISO-8859-1標(biāo)準(zhǔn)編碼能夠輕易的實(shí)現(xiàn),下面的代碼實(shí)現(xiàn)了這一功能:

          byte [] b;

          String utf8_value;

          utf8_value = request.getParameter("NAME");//從HTTP流中取"NAME"的UTF8數(shù)據(jù)

          b = utf8_value.getBytes("8859_1"); //中間用ISO-8859-1過渡

          String name = new String(b, "GB2312"); //轉(zhuǎn)換成GB2312字符

          在知道流長度的情況下將輸入流轉(zhuǎn)換成字節(jié)數(shù)組 Java中的輸入流抽象類InputStream有int read(byte[] b, int off, int len)方法,參數(shù)中byte[] b是用來存放從InputStream中讀取的數(shù)據(jù),int off指定數(shù)組b的偏移地址,也就是數(shù)組b的起始下標(biāo),int len指定需要讀取的長度,方法返回實(shí)際讀取的字節(jié)數(shù)。剛學(xué)Java的朋友可能要說:先定義一個與流長度等長的字節(jié)數(shù)組,調(diào)用read方法,指定起始下標(biāo)為0,指定讀取長度與數(shù)組長度等長,不是一下子可以讀出來了嗎?說的沒錯,筆者曾經(jīng)也試著這樣讀取數(shù)據(jù),但后來發(fā)現(xiàn)在讀取網(wǎng)絡(luò)數(shù)據(jù)時很不安全,我們想想在網(wǎng)絡(luò)上獲取數(shù)據(jù)可能并沒那么流暢,數(shù)據(jù)流的傳送可能會斷斷續(xù)續(xù),所以并不能保證一次就能讀取全部數(shù)據(jù),特別是在讀取大容量數(shù)據(jù)時更是如此,所以我們必須在讀取數(shù)據(jù)時檢測實(shí)際讀到的長度,如果沒有讀完已知長度的數(shù)據(jù)就應(yīng)該再次讀取,以此循環(huán)檢測,直到實(shí)際讀取的長度累加與已知的長度相等,下面的代碼實(shí)現(xiàn)了這一功能:

          ServletInputStream inStream = request.getInputStream(); //取HTTP請求流

          int size = request.getContentLength(); //取HTTP請求流長度

          byte[] buffer = new byte[size]; //用于緩存每次讀取的數(shù)據(jù)

          byte[] in_b = new byte[size]; //用于存放結(jié)果的數(shù)組

          int count = 0;

          int rbyte = 0;

          while (count < size) { //循環(huán)讀取

          rbyte = inStream.read(buffer); //每次實(shí)際讀取長度存于rbyte中

          for(int i=0;i<rbyte;i++) {

          in_b[count + i] = buffer[i];

          }

          count += rbyte;

          }

          在不知道流長度的情況下將輸入流轉(zhuǎn)換成字節(jié)數(shù)組 前面介紹了已知流長度的情況下的轉(zhuǎn)換方法,那么當(dāng)我們不知道流有多長時,也就是說不能確定轉(zhuǎn)換后的字節(jié)數(shù)組有多大時,該怎么處理呢?筆者查看了JDK文檔之后發(fā)現(xiàn)ByteArrayOutputStream有一個byte[] toByteArray()方法,該方法會自動創(chuàng)建一個字節(jié)數(shù)組,然后返回。于是就巧妙的用ByteArrayOutputStream來作中間過渡實(shí)現(xiàn)轉(zhuǎn)換,其它處理跟上面所介紹已知長度的情況差不多。假設(shè)需要被轉(zhuǎn)換的流已經(jīng)放在inStream里了,我們可以用如下的代碼實(shí)現(xiàn)這一功能:

          ByteArrayOutputStream swapStream = new ByteArrayOutputStream();

          byte[] buff = new byte[100]; //buff用于存放循環(huán)讀取的臨時數(shù)據(jù)

          int rc = 0;

          while ((rc = inStream.read(buff, 0, 100)) > 0) {

          swapStream.write(buff, 0, rc);

          }

          byte[] in_b = swapStream.toByteArray(); //in_b為轉(zhuǎn)換之后的結(jié)果

          上面介紹了三種比較實(shí)用的Java數(shù)據(jù)轉(zhuǎn)換,有興趣的朋友可通過nbDeveloper@hotmail.com與筆者取得聯(lián)系,進(jìn)一步交流其它有關(guān)XML應(yīng)用、程序設(shè)計模式、J2EE開發(fā)以及UML等知識。

          posted on 2007-11-07 13:27 都市淘沙者 閱讀(1377) 評論(0)  編輯  收藏 所屬分類: Java Basic/Lucene/開源資料

          主站蜘蛛池模板: 芜湖县| 尚志市| 寿光市| 云霄县| 蛟河市| 元阳县| 临汾市| 新田县| 高台县| 娱乐| 阜康市| 隆林| 泊头市| 唐海县| 临洮县| 泸定县| 景洪市| 遂溪县| 湖南省| 友谊县| 尉犁县| 揭阳市| 汪清县| 博野县| 剑阁县| 鄂托克前旗| 五河县| 江口县| 灯塔市| 郸城县| 轮台县| 武乡县| 忻城县| 八宿县| 永吉县| 辉南县| 兰溪市| 鹰潭市| 淮南市| 句容市| 淅川县|