精彩的人生

          好好工作,好好生活

          BlogJava 首頁 新隨筆 聯系 聚合 管理
            147 Posts :: 0 Stories :: 250 Comments :: 0 Trackbacks

          #

          今天需要讀取xml文件.
          以前幾乎沒有做過xml文件的解析(在一個面試的測試題中做過一道xml解析的題),覺得xml解析挺容易的.上網找了找,資料還挺多,下面就是一篇很不錯的文章,原文地址為http://www.jdon.com/idea/xml.htm

          Java和XML是黃金組合,網上已經有很多文章介紹,XML作為電子商務中數據交換,已經有其不可替代的作用,但是在平時系統開發中,我們不一定都用到數據交換,是不是無法使用XML了?

          當然不是,現在已經有一個新趨勢,java程序的配置文件都開始使用XML格式,以前是使用類似windows的INI格式.(Java中也有Propertiesy這樣的類專門處理這樣的屬性配置文件).使用XML作為Java的配置文件有很多好處,從Tomcat的安裝配置文件和J2ee的配置文件中,我們已經看到XML的普遍應用,讓我們也跟隨流行趨勢用XML武裝起來.

          現在關鍵是如何讀取XML配置文件?有好幾種XML解析器:主要有DOM和SAX ,這些區別網上文章介紹很多.

          apache的XML項目組中,目前有Xerces Xalan Cocoon幾個開發XML相關技術的project.Tomcat本身使用的是 Sun 的 JAXP,而其XSL Taglib project中使用Xerces解析器.

          好了,上面都是比較煩人的理論問題,還是趕快切入XML的配置文件的讀取吧.

          在我們的程序中,通常要有一些根據主機環境確定的變量.比如數據庫訪問用戶名和密碼,不同的主機可能設置不一樣.只要更改XML配置文件,就可以正常運行.

          <myenv>

          <datasource>
          <dbhost>localhost</dbhost>
          <dbname>sqlname</dbname>
          <dbuser>username</dbuser>
          <dbpassword>password</dbpassword>
          </datasource>

          </myenv>

           

           

          上面這個myenv.xml配置文件一般是放在tomcat的WEB-INF/classes目錄下.

          我們編制一個Java程序直接讀取,將dbhost dbuser dbpassword提取出來供其他程序訪問數據庫用.

          目前使用SAX比較的多,與DOM主要區別是 SAX是一行一行讀取XML文件進行分析,適合比較大文件,DOM是一次性讀入內存,顯然不能對付大文件.這里我們使用SAX解析,由于SAX解析器不斷在發展,網上有不少文章是針對老版本的.如果你使用JDK1.4 ,可以參考 使用SAX處理XML文檔 一文.這里的程序是根據其改進并且經過實踐調試得來的.

          對上面myenv.xml讀取的Java程序:


          import org.xml.sax.Attributes;
          import org.xml.sax.helpers.DefaultHandler;
          import org.xml.sax.SAXException;

          import java.util.Properties;

          //使用DefaultHandler的好處 是 不必陳列出所有方法,
          public class ConfigParser extends DefaultHandler {

          ////定義一個Properties 用來存放 dbhost dbuser dbpassword的值
          private Properties props;

          private String currentSet;
          private String currentName;
          private StringBuffer currentValue = new StringBuffer();

          //構建器初始化props
          public ConfigParser() {

          this.props = new Properties();
          }

          public Properties getProps() {
          return this.props;
          }



          //定義開始解析元素的方法. 這里是將<xxx>中的名稱xxx提取出來.
          public void startElement(String uri, String localName, String qName, Attributes attributes)
          throws SAXException {
          currentValue.delete(0, currentValue.length());
          this.currentName =qName;




          }

          //這里是將<xxx></xxx>之間的值加入到currentValue

          public void characters(char[] ch, int start, int length) throws SAXException {

          currentValue.append(ch, start, length);

          }

          //在遇到</xxx>結束后,將之前的名稱和值一一對應保存在props中

          public void endElement(String uri, String localName, String qName) throws SAXException {

          props.put(qName.toLowerCase(), currentValue.toString().trim());
          }

          }

          上面的這個解析程序比較簡單吧? 其實解析XML就是這么簡單.

          現在我們已經將dbhost dbuser dbpassword的值localhost sqlname username password提取了出來.但是這只是在在解析器內部,我們的程序還不能訪問.需要再編制一個程序.

           

          import java.util.Properties;
          import javax.xml.parsers.SAXParser;
          import javax.xml.parsers.SAXParserFactory;
          import java.net.URL;

          public class ParseXML{

          //定義一個Properties 用來存放 dbhost dbuser dbpassword的值
          private Properties props;

          //這里的props
          public Properties getProps() {
          return this.props;
          }

          public void parse(String filename) throws Exception {

          //將我們的解析器對象化
          ConfigParser handler = new ConfigParser();

          //獲取SAX工廠對象
          SAXParserFactory factory = SAXParserFactory.newInstance();
          factory.setNamespaceAware(false);
          factory.setValidating(false);

          //獲取SAX解析
          SAXParser parser = factory.newSAXParser();

          //得到配置文件myenv.xml所在目錄. tomcat中是在WEB-INF/classes
          //下例中BeansConstants是用來存放xml文件中配置信息的類,可以自己代替或定義
          URL confURL = BeansConstants.class.getClassLoader().getResource(filename);

          try
          {
          //將解析器和解析對象myenv.xml聯系起來,開始解析
          parser.parse(confURL.toString(), handler);
          //獲取解析成功后的屬性 以后 我們其他應用程序只要調用本程序的props就可以提取出屬性名稱和值了
          props = handler.getProps();
          }finally{
          factory=null;
          parser=null;
          handler=null;
          }

          }

          }

          由于我們的XML文件是使用最簡單的形式 ,因此解析器相對簡單,但是這已經足夠對付我們的配置文件了.

          判斷一個程序系統的先進性,我們先看看他的配置文件,如果還在使用老套的xxx=123 這樣類似.ini的文件,
          我們也許會微微一笑,他又落伍了.....

           

          posted @ 2005-12-05 14:44 hopeshared 閱讀(477) | 評論 (0)編輯 收藏

                  由于工作需要,要做一個項目打包的功能. 原則上,項目打包應該寫一個ant腳本,然后在代碼中執行它,反正很復雜.
                  一個朋友推薦我用fatjar試試, 我上網搜到了這篇文章,轉過來保存.




                  今天啟動tomcat發現特別慢,得等1分多鐘才啟動完,這才想起來,我把WEB-INFO/lib/struts.jar , pager-tag.jar都刪除了,取而代之的是他們的源碼,tomcat啟動的時候因為找不到jar文件就要重新編譯,所以特別地慢。因此,我把struts.jar拷貝到WEB-INFO/lib下了,現在缺pager-tag.jar了。(其實pager-tag的源碼編譯不慢,主要是struts源碼編譯比較慢)我找了一下把程序打包的工具,其實eclipse自己帶了一個export工具可以打包,你的項目=〉export=>jar file=>然后挨個選擇你需要的包=〉寫好目標jar文件名=〉寫好目標目錄=〉就生成新jar了。

                  其實這樣已經能夠滿足我的要求了,查看Eclipse如何打包的過程中我發現有個fatjar插件功能更強些,可以把需要的資源打進一個jar里。所以下載了一個,下載地址:http://sourceforge.net/project/showfiles.php?group_id=115990&package_id=125924 解壓縮后是一個.../plugins/(net...)把plugins下面的(net..)文件夾拷貝到eclipse的plugins下,重新啟動Eclipse3.1,Windows=>prefernce=>fat jar preference看到他就說明已經安裝成功了。如果沒有看到,沒有關系,刪除D:\eclipse310\configuration\org.eclipse.update\platform.xml文件(此文件可以自動生成)不用擔心以前的插件會因此而消失,沒事。

                  剛開始找不到如何使用它,后來看到你的項目=〉Export..=>向導里有fat jar =>使用起來真的很方便。

          總結:
          一般把src打包export=>Jar File 即可。
          想把src附屬的資源一起打包,必須使用FatJar => export..=>FatJar.


          原文引用通告地址: http://blog.csdn.net/srx/services/trackbacks/492760.aspx
          posted @ 2005-11-30 09:39 hopeshared 閱讀(19265) | 評論 (6)編輯 收藏

          這里用到了一個開源的包commons-fileupload.jar,事實證明這個包十分好用

           

          uploadPhoto.jsp:
          <%@ page contentType="text/html; charset=GBK" %>
          <html>
          <head>
          <title>
          upload
          </title>


          </head>
          <body bgcolor="#ffffff">
          <h1>
          <%
          if(request.getAttribute("msg")==null)
          {//提示信息
          }
          else{
          %>
          <%=(String)request.getAttribute("msg")%>
          <%
          }

          %>
          </h1>
          <form action="photoImg.jsp" id="frm" encType="multipart/form-data"  method="post">
          <br/><br/>
            
          <input type="FILE" name="FILE1" id="myFilename" size="50"/>
          <input type="submit" name="Submit" value="Submit" />
          <input type="reset" value="Reset"/>
          </form>
          </body>
          </html>

          注意:這個form必須寫上encType="multipart/form-data" 來表明上傳文件。并且,這個form中不能用隱藏變量來傳遞參數。就是說寫一個<input type = hidden name=tmp>在下一個頁面或者action中用request.getParameter是取不到的。

           

           

          photoImg.jsp:

          <%@ page contentType="text/html; charset=GBK" %>
          <%@ page import="java.util.*" %>
          <%@ page import="java.awt.*" %>
          <html>
          <head>
          <title>
          upload
          </title>
          </head>
          <body bgcolor="#ffffff">

          <%
                  GPhoto photo 
          = new GPhoto();
                  request 
          = photo.uploadImage(request);
          %>

          <jsp:forward page="uploadPhoto.jsp">
          </jsp:forward>
          </body>
          </html>

          uploadImage()是這樣實現的:
          public static HttpServletRequest uploadImage(HttpServletRequest request)
                      
          throws Exception {

                  DiskFileUpload fileUpload 
          = new DiskFileUpload();

                  
          //設置允許用戶上傳文件大小,單位:字節
                  fileUpload.setSizeMax(8388608);

                  
          //設置最多允許在內存中存儲的數據,單位:字節
                  fileUpload.setSizeThreshold(1024000);

                  
          //設置一旦文件大小超過getSizeThreshold()的值時數據存放在硬盤的目錄
                  
          //在進行文件上傳的時候文件先存再內存中,然后才會存到server上,但是如果內存放不下那么大的文件
                  
          //就必須用硬盤上的 一個臨時文件夾來保存這個文件的部分,然后轉存
                  
          //現在默認的文件存儲的路徑是
                  String tmp = “c:/temp/”;

                  
          //設置上傳文件的存儲路徑,如果不設置這個路徑,這個文件將保存在
          //server的根目錄下(如tomcat或者resin的根目錄)
                  String uploadPath = “c:/”;

                  fileUpload.setRepositoryPath(tmp);

                  String strType 
          = "";

                  
          try {
                      List fileItems 
          = fileUpload.parseRequest(request);

                      Iterator iterator 
          = fileItems.iterator();

                      
          while(iterator.hasNext()) {

                          FileItem fileItem 
          = (FileItem)iterator.next();

                          
          //文件域的表單信息
                          if (!fileItem.isFormField()) {
                              String strName 
          = fileItem.getName();

                              
          long size = fileItem.getSize();
                              
          if((strName==null||strName.equals("")) && size==0)
                                  
          continue;

                                  File savedFile 
          = new File(uploadPath + strName);

                                  fileItem.write(savedFile);

                                  request.setAttribute(
          "msg","save file successful!");
                          }

                      }

                      
          if(request.getAttribute("msg")== null)
                      
          {
                          request.setAttribute(
          "msg","save file failed!");
                      }

                  }
           catch (Exception ex) {
                      request.setAttribute(
          "msg","save file failed!");
                  }

                  
          return request;
              }


          OK,文件保存了

           

          我在windows下傳文件很正常,但是在linux下,當文件過大,需要使用臨時文件夾的時候出現問題,可能是文件路徑的問題。
          posted @ 2005-11-27 12:56 hopeshared 閱讀(7568) | 評論 (1)編輯 收藏

          java中的圖片處理是很讓人頭疼的一件事情。目前java api中的imageIO可以將gif圖片轉換成png圖片,jpg圖片可以正常轉換。據說gifjpg也是有辦法的,但是將jpg轉成gif,我費了很大的工夫才找到一個很好的解決方案。

           

          首先介紹的是一段很好的縮放圖片的代碼::
          public static BufferedImage resize(BufferedImage source, int targetW, int targetH) {
              
          // targetW,targetH分別表示目標長和寬
                  int type = source.getType();
                  BufferedImage target 
          = null;
                  
          double sx = (double) targetW / source.getWidth();
                  
          double sy = (double) targetH / source.getHeight();

                  
          //這里想實現在targetW,targetH范圍內實現等比縮放。如果不需要等比縮放
                  
          //則將下面的if else語句注釋即可
                  if(sx>sy)
                  
          {
                      sx 
          = sy;
                      targetW 
          = (int)(sx * source.getWidth());
                  }
          else{
                      sy 
          = sx;
                      targetH 
          = (int)(sy * source.getHeight());
                  }


                  
          if (type == BufferedImage.TYPE_CUSTOM) //handmade
                      ColorModel cm = source.getColorModel();
                      WritableRaster raster 
          = cm.createCompatibleWritableRaster(targetW, targetH);
                      
          boolean alphaPremultiplied = cm.isAlphaPremultiplied();
                      target 
          = new BufferedImage(cm, raster, alphaPremultiplied, null);
                  }
           else
                      target 
          = new BufferedImage(targetW, targetH, type);
                  Graphics2D g 
          = target.createGraphics();
                  
          //smoother than exlax:
                  g.setRenderingHint(RenderingHints.KEY_INTERPOLATION, RenderingHints.VALUE_INTERPOLATION_BICUBIC);


                  g.drawRenderedImage(source, AffineTransform.getScaleInstance(sx, sy));
                  g.dispose();
                  
          return target;
              }


          接下來是將InputStream保存為jpg文件
          public static void saveImageAsJpg (InputStream in, File saveFile,int width,int hight)    
                      
          throws Exception {
                  BufferedImage srcImage;

                  srcImage 
          = ImageIO.read(in);

                  
          if(width > 0 || hight > 0)
                  
          {
                       srcImage 
          = resize(srcImage, width, hight);
                  }


                  ImageIO.write(srcImage, 
          "JPEG", saveFile);
                  in.close();
              }


          參數解釋:

          in::是一個jpg圖片的InputStream

          saveFile::目標文件

          width::目標寬度,如果不需要縮放則置0

          hight::目標高度,如果不需要縮放則置0

           

           

          然后是將InputStream保存為gif文件:
          private static void saveImageAsGif(InputStream in, File fileToSave,int width, int hight)
                      
          throws Exception {
                  BufferedImage srcImage;

                  srcImage 
          = ImageIO.read(in);

                  
          if(width>0 && hight >0)
                  
          {
                       srcImage 
          = resize(srcImage, width, hight);
                  }


                  FileOutputStream out 
          = new FileOutputStream(fileToSave);
                  GifEncoder encoder 
          = new GifEncoder(srcImage, out);
                  encoder.encode();

                  in.close();
              }


          參數解釋:

          in::是一個jpg或者gif圖片的InputStream

          saveFile::目標文件

          width::目標寬度,如果不需要縮放則置0

          hight::目標高度,如果不需要縮放則置0

           

          GifEncoder這個類是java api中沒有的,也是我找尋了很久的一個東西。它是Acme.JPM.Encoders.GifEncoder,只要找到這個包,將jpg轉為gif就不是問題了。

           

           

          Jpg圖片使用的是24-bit的編碼,pngpng-24png-8兩種,但是gif8-bit的編碼。如果強行將jpg圖片信息流按字節拆開,轉換成gif圖片,即使使用標準256色,也會出現嚴重的失真。

           

          我曾經使用了gif4j_light_trial_1.0.jar這個包,但是這個包讓我很失望。盡管它可以將多張圖片合成一個動態的gif圖片,但是它是付費的,免費使用期只有一個月。并且,在使用它將jpg圖片轉換成gif圖片之后中間會有一條白色的橫線,不知道這是系統的缺陷還是在費用包中做的手腳。

          posted @ 2005-11-27 12:53 hopeshared 閱讀(5058) | 評論 (17)編輯 收藏

               摘要: 這里,我用pop3連126.com的郵箱取到郵件,解析郵件附件。我的工作是取到jpg或gif圖片并保存。   說明:這是我的在工作中寫的代碼,是可用的。但是有部分代碼被截取出來,比如有些參數我覺得沒有必要,就刪除了,沒有測試??赡軙衎ug,但是肯定是小bug。  連接到郵箱: public static void connectMail(...  閱讀全文
          posted @ 2005-11-27 12:50 hopeshared 閱讀(599) | 評論 (0)編輯 收藏

          僅列出標題
          共30頁: First 上一頁 22 23 24 25 26 27 28 29 30 下一頁 
          主站蜘蛛池模板: 丰城市| 来宾市| 甘德县| 江达县| 横山县| 台江县| 荥经县| 新疆| 鲜城| 澎湖县| 牡丹江市| 民权县| 库车县| 北辰区| 哈尔滨市| 东丰县| 南乐县| 汉源县| 陇西县| 凤翔县| 天峻县| 清新县| 蒙阴县| 诸暨市| 连山| 南岸区| 临沂市| 临城县| 湛江市| 德安县| 和政县| 闽清县| 米林县| 鄂州市| 阿瓦提县| 馆陶县| 河南省| 板桥市| 兴安盟| 栖霞市| 菏泽市|