用Java实现可保存状态的数据库生成XML树,源码来了(10)
发表于:2007-07-01来源:作者:点击数:
标签:
2.XMLServlet. java package com.sitechasia; import javax.servlet.*; import javax.servlet.http.*; import java.io.PrintWriter; import java.io.IOException; import javax. sql .RowSet; import com.sitechasia.ejb.*; import javax.ejb.Handle; public
2.XMLServlet.
java
package com.sitechasia;
import javax.servlet.*;
import javax.servlet.http.*;
import java.io.PrintWriter;
import java.io.IOException;
import javax.
sql.RowSet;
import com.sitechasia.ejb.*;
import javax.ejb.Handle;
public class XMLServlet extends HttpServlet {
PrintWriter out;
private static ResultEdit re;
private Object ref;
boolean flag=true;
private Handle handle=null;
private static String HostIP = null;
private static String HostPort = null;
private static final String CONTENT_TYPEX = "text/xml";
private static final String CONTENT_TYPEH = "text/html";
private static final String CONTENT_XSLT = "<?xml-stylesheet type=\"text/xsl\" href=\"/xsl/treefunc.xsl\"?>";
private static final String CONTENT_XSLC = "<?xml-stylesheet type=\"text/xsl\" href=\"xmltreexsl.xsl\"?>";
/**Initialize global variables*/
public void init() throws ServletException {
}
/**Process the HTTP Get request*/
public void service(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
try{
HttpSession session=request.getSession();
if ( session.getAttribute("ResultEditHandle")==null) {
flag=false;
}
else {
flag=true;
handle=(Handle)session.getAttribute("ResultEditHandle");
re =(ResultEdit)handle.getEJBObject();
}
if (flag){
RowSet rs = re.getRowSet();
response.setContentType(CONTENT_TYPEX);
out = response.getWriter();
out.println("<?xml version=\"1.0\" encoding=\"gb2312\" ?>");
if (request.getParameterValues("clickId")==null){
out.println(CONTENT_XSLT);
}
else {
out.println(CONTENT_XSLC);
}
out.println("<project>");
while(rs.next()){
if (rs.getString(2).equals("0")){
if(rs.getString("herf")==null){
out.println("<node>");
out.println("<id>"+rs.getString(1)+"</id>");
out.println("<layer>"+rs.getString(2)+"</layer>");
out.println("<name>"+rs.getString(3)+"</name>");
out.println("<value>"+(rs.getString(4))+"</value>");
out.println("<father>"+rs.getString(5)+"</father>");
out.println("<href></href>");
out.println("<target></target>");
childnode(rs.getString(1));
out.println("</node>");
}
else {
out.println("<node>");
out.println("<id>"+rs.getString(1)+"</id>");
out.println("<layer>"+rs.getString(2)+"</layer>");
out.println("<name>"+rs.getString(3)+"</name>");
out.println("<value>"+(rs.getString(4))+"</value>");
out.println("<father>"+rs.getString(5)+"</father>");
out.println("<href>"+rs.getString(6)+"</href>");
out.println("<target>"+rs.getString(7)+"</target>");
out.println("</node>");
}
}
}
out.println("</project>");
rs.close();
}
else {
response.setContentType(CONTENT_TYPEH);
out = response.getWriter();
out.println("<html><head><title>no EJB message</title><META HTTP-EQUIV=@#Refresh@# CONTENT=@#2;url=/RefreshPost.html@#/></head>");
out.println("<body>");
out.println("<p><p><p><center>Refresh...... return RefreshPost.html</center></p></p></p></body></html>");
}
}
catch(Exception e){
System.out.println("errror:"+e.getMessage());
e.printStackTrace();
}
}
/**Clean up resources
id 1
layer 2
name 3
value 4
father 5
herf 6
target 7
*/
public void destroy() {
}
public void childnode(String father){
try{
RowSet rs = re.getRowSet();
while(rs.next()){
if (rs.getString(5).equals(father)){
if(rs.getString("herf")==null){
out.println("<node>");
out.println("<id>"+rs.getString(1)+"</id>");
out.println("<layer>"+rs.getString(2)+"</layer>");
out.println("<name>"+rs.getString(3)+"</name>");
out.println("<value>"+(rs.getString(4))+"</value>");
out.println("<father>"+rs.getString(5)+"</father>");
out.println("<href></href>");
out.println("<target></target>");
childnode(rs.getString(1));
out.println("</node>");
}
else{
out.println("<node>");
out.println("<id>"+rs.getString(1)+"</id>");
out.println("<layer>"+rs.getString(2)+"</layer>");
out.println("<name>"+rs.getString(3)+"</name>");
out.println("<value>"+(rs.getString(4))+"</value>");
out.println("<father>"+rs.getString(5)+"</father>");
out.println("<href>"+rs.getString(6)+"</href>");
out.println("<target>"+rs.getString(7)+"</target>");
out.println("</node>");
}
}
}
rs.close();
}
catch(Exception e){
System.out.println(e.getMessage());
e.printStackTrace();
}
}
}
原文转自:http://www.ltesting.net