日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 >

使用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的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。