首頁 >資料庫 >mysql教程 >使用JSP + JAVABEAN + XML 开发的一个例子_MySQL

使用JSP + JAVABEAN + XML 开发的一个例子_MySQL

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB原創
2016-06-01 14:09:14861瀏覽

  本例子是参考了一些网站上有关JSP 对 XML 的操作的相关文档,又结合了一些个人的体会。例子涉及的内容是,开发的一个企业内部定餐系统后台管理端的部分代码,功能主要集中在对于餐馆基本信息的管理。

该例子本身开发的起因是我在原公司和同事们一个玩笑的一部分。特此也表达对那些一起共事的朋友们的想念。

例子本身是在TOMCAT4.01 平台下运行的B/S结构的程式。有关TOMCAT 的配置,这里不做说明。只讲解一下相关文件及文件夹的目录结构。

目录结构说明:
/tomcat/webapps/canyin/                    -----主目录
/tomcat/webapps/canyin/jsp/               -----JSP 文件目录
/tomcat/webapps/canyin/jsp/admin/       -----实现后台管理的JSP 文件的存放目录
/tomcat/webapps/canyin/WEB-INF/classes/canyin/               ------javabean 文件的存放目录
/tomcat/webapps/canyin/data/   -----xml 文件存放目录
/tomcat/webapps/ROOT/           -----tomcat 启动文件存放文件夹,只存放了index.html 文件

文件简单说明:
/tomcat/webapps/canyin/data/users.xml    -----记录用户信息
/tomcat/webapps/canyin/data/restaurants.xml  -----记录餐馆的基础信息


/tomcat/webapps/ROOT/index.html       -----首页,页面出现输入框,要求用户输入用户名,密码


/tomcat/webapps/canyin/jsp/loginjudge.jsp       -----用户身份判断页面,根据用户名称和密码决定页面是转入后台管理端,还是前台客户端。本例子中,用户身份一旦确认为有管理权限,可以进入后台管理端,就直接跳到餐馆基本信息管理页面,简化说明的流程。
/tomcat/webapps/canyin/jsp/admin/admin_rest.jsp    -----餐馆基本信息管理页面,管理餐馆的名称,电话,地址等信息

/tomcat/webapps/canyin/WEB-INF/classes/canyin/checkSessionBean.class  ----- 后台管理端检测标志用户身份的session 的值,如果不是管理员的话,跳回登陆页面。              
/tomcat/webapps/canyin/WEB-INF/classes/canyin/connXmlBean.class  -----连接xml 文件
/tomcat/webapps/canyin/WEB-INF/classes/canyin/writeXmlBean.class  -----写入xml文件

文件详细介绍及附带代码说明。

/tomcat/webapps/canyin/data/users.xml    

代码:
   


   
   
   
  

 
说明:字段含义是用户名,密码以及用户的身份
 
/tomcat/webapps/canyin/data/restaurants.xml  

代码:
   


  上海亭快餐店 
  021-76546726 
  

百老汇广场B座
 
  

  香格里拉大饭店 
  021-2312134 
  
南京路1023号
 
  

  
说明:属性是记录在restaurants.xml 文件中总共有过多少条记录,每新增一条,无论以后删除是否,该值都会增加1,就好象数据库中习惯使用的自动增加1的id 项。用来给新增的 的属性赋一个唯一的值。其它的字段意思比较明显。
/tomcat/webapps/ROOT/index.html       (单纯的HTML代码)

代码:


oddWorld 餐饮系统





  
     
      
      
      
    
  
使用JSP + JAVABEAN + XML 开发的一个例子_MySQL  餐饮系统登录  使用JSP + JAVABEAN + XML 开发的一个例子_MySQL

  

  

  
     
    
  
 
      


        


           
            
        
         
            
        
      
餐饮系统登录
 
              
                
                   
                    
                    
                  
                  
                    
                    
                  
                
              
登录名:  
                                    name="username" class=stedit value="joard">
                    
密码:
                                        name="userpass" type=password value="oddworld">
                    

            

              
                 
                 
                  
                  
                  
                  
                
                 
              
 
                    
                  
   
                    
                  
 

              

            

    




     <script><br><!--<br>function checkform()<br>{ <br> var Checkblank = /^(\s*|(\ )|(\.))*$/;<br> if (Checkblank.test(dataform.username.value)) <br>{<br> alert("登录名不能为空!");<br> return false; <br> } <br> <br> if (Checkblank.test(dataform.userpass.value)) <br>{<br> alert("密码不能为空!");<br> return false; <br> } <br><br><br> window.dataform.submit();<br><br> }<br>--><br><br></script>

说明:把用户名称和用户密码提交到/tomcat/webapps/canyin/jsp/loginjudge.jsp       

/tomcat/webapps/canyin/WEB-INF/classes/canyin/checkSessionBean.class  (代码是相应的java 文件)

package canyin;

import javax.servlet.http.HttpSession;
import javax.servlet.http.HttpServletRequest;

public class checkSessionBean {
 
 private boolean bolCheckPass=false;
 private HttpServletRequest request = null;
 
 public boolean checkSessionBean(HttpServletRequest request,String strSessionName,String strCheckValue){
   public boolean checkSessionBean(HttpServletRequest request){
  HttpSession session = request.getSession(false);
  return(bolCheckPass);
  
  if (strSessionName==null || strCheckValue==null){
   return(bolCheckPass);
  }else{
   if (session!=null && session.getValue(strSessionName)!=null){
    bolCheckPass=session.getValue(strSessionName).equals(strCheckValue);
   }
   
     return(bolCheckPass);
  }
 }
}

说明:检验参数传入的session 名称的数值和参数传入的字段的数值是否相等。

/tomcat/webapps/canyin/WEB-INF/classes/canyin/connXmlBean.class  

代码:
package canyin;

import javax.xml.parsers.*;
import javax.xml.transform.*;
import javax.xml.transform.dom.DOMSource;
import javax.xml.transform.stream.StreamResult;
import org.w3c.dom.*;

public class connXmlBean {
 
 private DocumentBuilderFactory factory=null;
 private DocumentBuilder builder=null;
 private Document doc=null;
 
 public connXmlBean(){}
  
 public String connXml(String xmlFileName){
  
  String strExc="";
  
  try{
   factory = DocumentBuilderFactory.newInstance();
       builder=factory.newDocumentBuilder();
       doc=builder.parse(xmlFileName);
       doc.normalize(); 
      }catch(Exception e){
       strExc=e.toString();
    }
    
    return(strExc);
 }
 
 public Document getXmlDoc(){
    return(doc);
 }
}

说明:打开一个指定xml 文件

/tomcat/webapps/canyin/WEB-INF/classes/canyin/writeXmlBean.class  

代码:
package canyin;

import javax.xml.parsers.*;
import javax.xml.transform.*;
import javax.xml.transform.dom.DOMSource;
import javax.xml.transform.stream.StreamResult;
import java.io.File;
import org.w3c.dom.*;

public class writeXmlBean {
 
 public writeXmlBean(){}
  
 public String writeXml(Document doc,String xmlFileName){
  
  String strExc="";
  
  try{
   TransformerFactory tfactory = TransformerFactory.newInstance(); 
   Transformer transformer = tfactory.newTransformer(); 

   DOMSource source = new DOMSource(doc); 

   StreamResult result = new StreamResult(new File(xmlFileName)); 

   transformer.transform(source,result);  
      }catch(Exception e){
       strExc=e.toString();
    }
    
    return(strExc);
 }
 
}

说明:写入dom 的内容到一个指定的xml 文件。

/tomcat/webapps/canyin/jsp/loginjudge.jsp       

代码:
 copy right by joard ast  
 
 loginjudge.jsp 功能:用户身份校验,根据 /data/user.xml 文件内标示的用户不同的身份
 决定转入后台管理页面,还是客户点菜页面。
 --%>




 



session.setMaxInactiveInterval(1800);


Document doc;
NodeList users;
String strExc="";
String strUsername,strPassword;

strUsername=(String)request.getParameter("username");
strPassword=(String)request.getParameter("userpass");

//校验数据是否为空
if (strUsername=="" || strPassword=="" ){
 out.println("<script>");<br> out.println("alert(''用户名或密码有空值!'');");<br> out.println("window.location.href=''/index.html'';");<br> out.println("</script>");
 return;
}

xmlBean.connXml("webapps/canyin/data/users.xml");
doc=xmlBean.getXmlDoc();

try{
 users =doc.getElementsByTagName("user");
       
     for (int i=0;i        Element user=(Element) users.item(i);
         
  String strAtrNameValue=user.getAttributeNode("name").getNodeValue();       
 String strAtrPassWordValue=user.getAttributeNode("password").getNodeValue();
        String strAtrRoleValue=user.getAttributeNode("roles").getNodeValue(); 
        
       
         
        if (strAtrNameValue.equals(strUsername) && strAtrPassWordValue.equals(strPassword)){
         
         if (strAtrRoleValue.equals("admin")){
          out.println("<script>");<br> out.println("alert(''欢迎管理员登陆系统!'');");<br> out.println("</script>");
    
    //设置标示用户身份的 session(sesUserRole) ,管理员身份为 admin
    session.setAttribute("sesUserRole","admin");
    
    //跳转到管理页面
    response.sendRedirect("admin/admin_rest.jsp");
    return;
    
         }else{
          //设置标示用户身份的 session(sesUserRole) ,管理员身份为 user
          session.setAttribute("sesUserRole","user");
          
          //跳转到普通用户页面
          response.sendRedirect("index.jsp");       
          return;
         }

        }else{
         out.println("<script>");<br> out.println("alert(''用户名或密码错误!'');");<br> out.println("history.go(-1);");<br> out.println("</script>");
   return;
        }

 }
}catch(Exception e){
     strExc=e.toString();
}
%>
说明:.......

/tomcat/webapps/canyin/jsp/admin/admin_rest.jsp    

代码:
 copy right by joard ast  
 
 admin_rest.jsp 功能:后台管理页面,餐馆管理页面。
 --%>





 







if(!checkSessionBean.checkSessionBean(request,"sesUserRole","admin")){
 out.print(showDialog("您没有管理的权限!","/index.html"));
 return;
}

//从餐馆资料文件 rest.xml 中得到相关数据
Document doc;
NodeList restaurants;

String strAct;
int intId=0;
String strOperation="show";

//接受外部传入的参数
strAct=(String)request.getParameter("act");

xmlBean.connXml("webapps/canyin/data/restaurants.xml");
doc=xmlBean.getXmlDoc();
restaurants =doc.getElementsByTagName("restaurant");

//根据外部传入的参数来决定对 restaurant.xml 文件的操作
if (strAct!=null){
 if(strAct.equals("addnewDo")){
  
  String strName;
  String strPhone;
  String strAddress;
  Text textseg;
  
  strName=(String)request.getParameter("name").trim();
  strPhone=(String)request.getParameter("phone").trim();
  strAddress=(String)request.getParameter("address").trim();
  
  //数据校验
  if(strName==null){
   out.print(showDialog("餐馆名称不能为空!"));
   return;
  }
  if(strPhone==null){
   out.print(showDialog("餐馆电话不能为空!"));
   return;
  }
  /*if(strAddress==null){
   out.print(showDialog("餐馆地址不能为空!"));
   return;
  }*/
  
  //校验数据的唯一性
  for(int i=0;i   Element restaurant=(Element) restaurants.item(i);
   if(((String)restaurant.getElementsByTagName("name").item(0).getFirstChild().getNodeValue()).equals(strName)){
    out.print(showDialog("餐馆名称重复!"));
    return; 
   }else{
    if(((String)restaurant.getElementsByTagName("name").item(0).getFirstChild().getNodeValue()).equals(strPhone)){
     out.print(showDialog("餐馆电话重复!"));
     return;
    }
   }
   
  }
  
  
    
  //得到已有的记录数,给新增的餐馆记录设定唯一的递增的id 属性
  int intNum=0;
  Element restNum=(Element)doc.getElementsByTagName("restaurants").item(0);
  intNum=Integer.parseInt(restNum.getAttributeNode("num").getNodeValue()); 

  intNum+=1;
  
  //为restaurants的属性num 的数值加1
  restNum.getAttributeNode("num").setNodeValue(String.valueOf(intNum));

  //新增节点    
  Element newRestaurant=doc.createElement("restaurant");
  
  Attr newArrId=doc.createAttribute("id");
  //Attribute newArrId = new Attribute("id",String.valueOf(intNum));  
  textseg=doc.createTextNode(String.valueOf(intNum));
  newArrId.setValue(String.valueOf(intNum));
  newRestaurant.setAttributeNode(newArrId);
  
  Element newName=doc.createElement("name");
  textseg=doc.createTextNode(strName);
  newName.appendChild(textseg);
  newRestaurant.appendChild(newName);
  
  Element newPhone=doc.createElement("phone");
  textseg=doc.createTextNode(strPhone);
  newPhone.appendChild(textseg);
  newRestaurant.appendChild(newPhone);
  
  Element newAddress=doc.createElement("address");
  textseg=doc.createTextNode(strAddress);
  newAddress.appendChild(textseg);
  newRestaurant.appendChild(newAddress);
  
  doc.getDocumentElement().appendChild(newRestaurant);

  //调用bean 写入相应的xml文件
  writeXmlBean.writeXml(doc,"webapps/canyin/data/restaurants.xml");

  response.sendRedirect(request.getRequestURI());  
  return;
 }
 if(strAct.equals("modiDo")){
  String strName;
  String strPhone;
  String strAddress;
  Text textseg;
  int modiId;
  //记录要修改的记录是item(i)的哪一项
  int intI=0;
  
  strName=(String)request.getParameter("name").trim();
  strPhone=(String)request.getParameter("phone").trim();
  strAddress=(String)request.getParameter("address").trim();
  modiId=Integer.parseInt(request.getParameter("recordId").trim());
  
  //数据校验
  if(strName==null){
   out.print(showDialog("餐馆名称不能为空!"));
   return;
  }
  if(strPhone==null){
   out.print(showDialog("餐馆电话不能为空!"));
   return;
  }
  if(modiId==0){
   out.print(showDialog("你要修改餐馆的记录不存在!"));
   return;
  }
  /*if(strAddress==null){
   out.print(showDialog("餐馆地址不能为空!"));
   return;
  }*/
  
  //标志显示记录存在
  boolean recordExist=false;
  
  //校验数据的唯一性
  for(int i=0;i   Element restaurant=(Element) restaurants.item(i);
   
   if(Integer.parseInt(restaurant.getAttributeNode("id").getNodeValue())==modiId){
    recordExist=true;
    intI=i;

   }
   
   if(((String)restaurant.getElementsByTagName("name").item(0).getFirstChild().getNodeValue()).equals(strName) && Integer.parseInt(restaurant.getAttributeNode("id").getNodeValue())!=modiId ){
    out.print(showDialog("餐馆名称重复!"));
    return; 
   }else{
    if(((String)restaurant.getElementsByTagName("name").item(0).getFirstChild().getNodeValue()).equals(strPhone) && Integer.parseInt(restaurant.getAttributeNode("id").getNodeValue())!=modiId ){
     out.print(showDialog("餐馆电话重复!"));
     return;
    }
   }
   
  }
  

  
  if(!recordExist){
   out.print(showDialog("你要修改餐馆的记录不存在!"));
   return;
  }else{
   //进行记录更改的操作
   try{
    Element modiRestaurant=(Element) restaurants.item(intI);
    modiRestaurant.getElementsByTagName("name").item(0).getFirstChild().setNodeValue(strName);
    modiRestaurant.getElementsByTagName("phone").item(0).getFirstChild().setNodeValue(strPhone);
    modiRestaurant.getElementsByTagName("address").item(0).getFirstChild().setNodeValue(strAddress);
    
    //调用bean 写入相应的xml文件
    writeXmlBean.writeXml(doc,"webapps/canyin/data/restaurants.xml");
  
    response.sendRedirect(request.getRequestURI());  
    return; 
    
   }catch(Exception e){}
  }
 }
 //进行删除操作
 if(strAct.equals("del")){
  int delId;
  //记录要修改的记录是item(i)的哪一项
  int intI=0;

  delId=Integer.parseInt(request.getParameter("recordId").trim());

  if(delId==0){
   out.print(showDialog("你要修改餐馆的记录不存在!"));
   return;
  }
  
  file://标志显示记录存在
  boolean recordExist=false;

  //校验数据的唯一性
  for(int i=0;i   Element restaurant=(Element) restaurants.item(i);
   
   if(Integer.parseInt(restaurant.getAttributeNode("id").getNodeValue())==delId){
    recordExist=true;
    intI=i;

   }
  }
  
  if(!recordExist){
   out.print(showDialog("你要删除餐馆的记录不存在!"));
   return;
  }else{
   //进行记录删除的操作
   try{
    Node delNode=(Node)restaurants.item(intI);
    
    doc.getElementsByTagName("restaurants").item(0).removeChild(delNode);

    //调用bean 写入相应的xml文件
    writeXmlBean.writeXml(doc,"webapps/canyin/data/restaurants.xml");

    response.sendRedirect(request.getRequestURI());  
    return; 
    
   }catch(Exception e){}
  }

 }
}

//由外部传入参数决定页面相应的处理状态
if (strAct==null){
 strOperation="show";
}else{
 if (strAct.equals("modi")){
  strOperation="modi";
  intId=Integer.parseInt(request.getParameter("recordId"));
 }else{
  if(strAct.equals("addnew")){
   strOperation="addnew";
  }else{
   strOperation="show";
  }
 }
}


//如果为空记录,则变更页面状态为“新增”
if (restaurants.getLength()==0){
 strOperation="addnew";
}
%>



oddWorld 餐饮系统







  
     
      
      
      
   
    
  
使用JSP + JAVABEAN + XML 开发的一个例子_MySQL  餐饮系统管理--餐馆管理 使用JSP + JAVABEAN + XML 开发的一个例子_MySQL [ 退出系统 ]

  

  

  width="90%">
     
     
      
      
      
      
      
      
    
 for(int i=0;i {
  Element restaurant=(Element) restaurants.item(i);
  
  if (strOperation=="modi" && Integer.parseInt(restaurant.getAttributeNode("id").getNodeValue())==intId){
%>
    
    
 
      ?act=modiDo" method="post"  onSubmit=''return checkform(this);'' >
        
        
        
        
        
        
      
    
        //显示正常的格式 %>
     
      
      
      
      
      
      
    
    }%>
        //显示新增的格式%>
     
      ?act=addnewDo" method="post"  onSubmit=''return checkform2(this);'' >
        
        
        
        
        
        
      
    
    
     
  
  餐馆名称 餐馆电话  
        
餐馆地址

      
 
        
修改

      
 
        
删除

      
 
          ">
          
 
                            style="HEIGHT: 22px; WIDTH: 150px" value="         out.print(restaurant.getElementsByTagName("name").item(0).getFirstChild().getNodeValue());
         
        }%>
" maxlength="40" >
        
 
                            style="HEIGHT: 22px; WIDTH: 100px" value="         out.print(restaurant.getElementsByTagName("phone").item(0).getFirstChild().getNodeValue());
         
        }%>" maxlength="20" >
        
 
                            style="HEIGHT: 22px; WIDTH: 200px" value="                  
                  if(restaurant.getElementsByTagName("address").item(0).hasChildNodes()){
         out.print(restaurant.getElementsByTagName("address").item(0).getFirstChild().getNodeValue());
         
        }%>" maxlength="100" >
        
使用JSP + JAVABEAN + XML 开发的一个例子_MySQL      height=15 src="../../images/editok.gif" width=15>  
         out.print(restaurant.getElementsByTagName("name").item(0).getFirstChild().getNodeValue());
         
        }%>
         out.print(restaurant.getElementsByTagName("phone").item(0).getFirstChild().getNodeValue());
         
        }%>
 
                if(restaurant.getElementsByTagName("address").item(0).hasChildNodes()){
        out.print(restaurant.getElementsByTagName("address").item(0).getFirstChild().getNodeValue());
         
        }%>
      
?act=modi&recordId=">使用JSP + JAVABEAN + XML 开发的一个例子_MySQL        height=15 src="../../images/edit.gif" width=15> 使用JSP + JAVABEAN + XML 开发的一个例子_MySQL        height=15 
        onClick="javascript:if(confirm(''您是否确定删除本记录,删除后将导至记录无法使用?'')){window.location.href=''?act=del&recordId='';}" 
        src="../../images/delete.gif"  style="max-width:90%" width=15> 
 
                            style="HEIGHT: 22px; WIDTH: 150px" value="" maxlength="40" >
        
 
                            style="HEIGHT: 22px; WIDTH: 100px" value="" maxlength="20" >
        
 
                            style="HEIGHT: 22px; WIDTH: 200px" value="" maxlength="100" >
        
使用JSP + JAVABEAN + XML 开发的一个例子_MySQL      height=15 src="../../images/editok.gif" width=15>  

  

  
     
     
      
    
  
 

        
          
            
            
          
        
 
                            %>
              
                              if(strOperation=="modi"){
              %>
              
                              }else{
                 %>
              ?act=addnew'';">                } 
               } %>
               

              
            

      

  

 





<script><br><!--<br>function checkform2()<br>{<br> var Checkblank = /^(\s*|(\ )|(\.))*$/;<br> <br> if (Checkblank.test(dataform2.name.value))<br> {<br> alert("餐馆名称不能为空!");<br> dataform2.name.focus();<br> return false; <br> } <br> <br> if (Checkblank.test(dataform2.phone.value)) <br> {<br> alert("餐馆电话不能为空!");<br> dataform2.phone.focus();<br> return false; <br> }<br> window.dataform2.submit();<br> }<br> <br> function checkform()<br>{ <br> var Checkblank = /^(\s*|(\ )|(\.))*$/;<br> if (Checkblank.test(dataform.name.value))<br> {<br> alert("餐馆名称不能为空!");<br> dataform.name.focus();<br> return false; <br> }<br> <br> if (Checkblank.test(dataform.phone.value))<br> {<br> alert("餐馆电话不能为空!");<br> dataform.phone.focus();<br> return false; <br> }<br> <br><br> window.dataform.submit();<br> }<br>--><br></script>
说明:本文件的书写有很多地方并不简练,因为在程式的开发过程中,过分简练的程序往往会带来后期维护的困难。

开发心得:

doc.getElementsByTagName("restaurants").item(int i)的返回值是node 型,如果不是要调用它的属性值,没有必要强制转型为 Element型。可以直接操作。本系统因为开发的参考资料的错误,所以全都采用了强制转型。可以在以后的开发中考虑使用node 直接进行操作。

trim() 和 Interger.parseInt() 函数都不可以接受null 型的数值

在tomcat 下左右的文件都是目录从TOMCAT 算起,具体情况请参见\webapps\canyin\jsp\userjudge.jsp 里关于xml 路径的写法。


对原代码感兴趣的朋友请通过如下信箱和我联系,joard@163.com

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn