當前位置:
首頁 >
使用SAX解析XML封装实体Bean
發布時間:2025/7/14
39
豆豆
生活随笔
收集整理的這篇文章主要介紹了
使用SAX解析XML封装实体Bean
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
新的項目需要對用戶權限進行控制,經過和項目經理商量我們決定使用XML文件存儲權限代碼和層次關系,這樣比較方便也便于維護,使用SAX讀取XML文件,我發現在讀取的時候可以順便將XML文件中的內容封裝為實體Bean,便于頁面使用JSTL進行迭代。<?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office" /> ?一、XML結構 我的XML結構為這樣的 <root> ?<basemenu??id=""?name="基礎信息"?url="#"> ??<menu?id=""?name="倉儲位設置"?url="#"> ???<submenu?id=""?name="倉庫設置"?url=""> ????<button?id=""?name="查詢"?url="#"></button> ???</submenu> ??</menu> ?</basemenu> </root> 二、實體Bean 針對這種結構我定義了幾個實體Bean 看名字就能知道對應的XML標記的名字,由于所有的標記都有三個屬性,我就將他們抽象出來定義了一個超類, public?class?WMSBean?{ ?public?String?id; ?public?String?name; ?public?String?url; //省略set,get方法 下面依次是各個實體類的代碼 public?class?RootBean?{ ?public?List<BaseMenuBean>?baseMenuBean; public?class?BaseMenuBean?extends?WMSBean?{ ?public?List<MenuBean>?menuBean; public?class?MenuBean?extends?WMSBean?{ ?public?List<Submenu>?submenu; public?class?Submenu?extends?WMSBean?{ ?public?List<Button>?button; public?class?Button?extends?WMSBean?{ } 實體類內部成員變量使用了List類型,這樣的話可以存放多個相同的標記(Button在最底層沒有成員變量) 三、解析XML并封裝 開始看我解析XML的代碼了 public?class?ParseXml?extends?DefaultHandler?{ ?public?RootBean?rootBean;//成員變量 ?public?ParseXml()?{ ??super(); ??this.rootBean?=?new?RootBean();//初始化 ?} ?public?void?startElement(String?namespaceURI,?String?localName,//此方法讀取XML元素 ???String?name,?Attributes?atts)?{ ??WMSBean?bean?=?this.doInstanceBean(name);//調用doInstanceBean方法 ??for?(int?i?=?0;?i?<?atts.getLength();?i++)?{//對實體Bean進行初始化 ???if?("id".equals(atts.getLocalName(i)))?{ ????bean.setId(atts.getValue(i)); ???} ???if?("name".equals(atts.getLocalName(i)))?{ ????bean.setName(atts.getValue(i)); ???} ???if?("url".equals(atts.getLocalName(i)))?{ ????bean.setUrl(atts.getValue(i)); ???} ??} ??this.doSetBean(bean);//將實體Bean進行封裝 ?} //根據名稱初始化一個實體對象,并返回,這個方法充分的利用了java的多態特性 ?private?WMSBean?doInstanceBean(String?name)?{?? if?("basemenu".equals(name))?{ ???return?new?BaseMenuBean(); ??}?else?if?("menu".equals(name))?{ ???return?new?MenuBean(); ??}?else?if?("submenu".equals(name))?{ ???return?new?Submenu(); ??}?else?if?("button".equals(name))?{ ???return?new?Button(); ??}?else?{ ??} ??return?null; ?} ?private?void?doSetBean(WMSBean?bean)?{ ??if?(bean?instanceof?BaseMenuBean)?{//判斷其類型 ???this.rootBean.setBaseMenuBean((BaseMenuBean)?bean); ??} ?else?if?(bean?instanceof?MenuBean)?{ ???List<BaseMenuBean>?baseMenuBeanList?=?this.rootBean?.getBaseMenuBean(); ???baseMenuBeanList.get(baseMenuBeanList.size()?-?1).setMenuBea(?(MenuBean)?bean); //獲得List中最后一個對想,并add ??}? else?if?(bean?instanceof?Submenu)?{ ???List<BaseMenuBean>?baseMenuBeanList?=?this.rootBean?.getBaseMenuBean(); ???BaseMenuBean?baseMenuBean?=?baseMenuBeanList.get(baseMenuBeanList ?????.size()?-?1); ???List<MenuBean>?menuBeanList?=?baseMenuBean.getMenuBean(); ???menuBeanList.get(menuBeanList.size()?-?1).setSubmenu((Submenu)?bean); ??}? else?if?(bean?instanceof?Button)?{//依次重復相同操作 ???List<BaseMenuBean>?baseMenuBeanList?=?this.rootBean?.getBaseMenuBean(); ???BaseMenuBean?baseMenuBean?=?baseMenuBeanList.get(baseMenuBeanList ?????.size()?-?1); ???List<MenuBean>?menuBeanList?=?baseMenuBean.getMenuBean(); ???MenuBean?menuBean?=?menuBeanList.get(menuBeanList.size()?-?1); ???List<Submenu>?submenuList?=?menuBean.getSubmenu(); ???submenuList.get(submenuList.size()?-?1).setButton((Button)?bean); ??}?else?{?} ?} ?public?RootBean?getRootBean()?{ ??return?rootBean; ?} ?public?void?setRootBean(RootBean?rootBean)?{ ??this.rootBean?=?rootBean; ?} } 四、調用、運行 public?ModelAndView?menu(HttpServletRequest?request,?HttpServletResponse?response)?throws?Exception?{ ??SAXParserFactory?sf?=?SAXParserFactory.newInstance(); ??SAXParser?sp?=?sf.newSAXParser();//初始化對象 ??ParseXml?parseXml?=?new?ParseXml();//初始化對象 ??sp.parse(new?InputSource(this.getServletContext().getRealPath( ????"/WEB-INF/quanxian.xml")),?parseXml); //通過Servlet容器獲得xml文件,將我們的parseXml作為參數傳遞進去 ??RootBean?bean?=?parseXml.getRootBean();//獲得parseXml內部的成員變量RootBean ??return?new?ModelAndView().addObject("RootBean",?bean); //添加進request對象中并返回到頁面以供迭代 ?} 五、迭代 為了代碼的簡練我省去了一部分html代碼,只保留了迭代RootBean部分的代碼,使用JSTL進行迭代,即簡單又不出錯。 <c:forEach?items="${RootBean.baseMenuBean}"?var="base"> ?<li?id="${base.id}"><a?href="${base.url}">${base.name}</a> ??<ul> ??<c:forEach?items="${base.menuBean}"?var="menu">? ??<li?id="${menu.id}"><a?href="${menu.url}">${menu.name}</a> ????<ul> ????<c:forEach?items="${menu.submenu}"?var="sub"> ????<li?id="${sub.id}"><a?href="${sub.url}">${sub.name}</a> ?????<ul> ?????<c:forEach?items="${sub.button}"?var="button"> ??????<li?id="${button.id}"><a?href="${button.url}">${button.name}</a></li> ?????</c:forEach> ?????</ul>???? ????</li> ????</c:forEach> ????</ul> ??</li>?? ??</c:forEach> ??</ul> ?</li> </c:forEach> 總結,不是所有的應用都要按照某某方式去做,我沒有使用Digester但是我封裝的實體也比較靈活,至少很符合我的使用,這已經足夠了。
總結
以上是生活随笔為你收集整理的使用SAX解析XML封装实体Bean的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: MYSQL用户root密码为弱口令的**
- 下一篇: .Net Micro Framework