仓酷云

标题: JAVA网站制作之JSP完成论坛树型布局的详细算法 [打印本页]

作者: 灵魂腐蚀    时间: 2015-1-18 11:39
标题: JAVA网站制作之JSP完成论坛树型布局的详细算法
大型的应用一般不会用这些框架(因为性能考虑);开发人员根据需要选择用一些框架,也可以不选用框架;不用框架并不代表要自己写框架;修改框架的可能性更小。js|树型布局|算法
  完成论坛树型布局的算法良多,我如今的JSP论坛接纳的也是傍边的一种:不必递回完成树型布局的算法,如今我将论坛树型布局的详细算法和人人先容一下,和人人一同交换。
1、演示表的布局:
   表名:mybbslist
   字段    数据范例  申明
   BBSID    主动编号 
   RootID   Int    根帖ID,自己为根帖则RootID=ID
   FID     Int    父帖ID,上一层帖子的ID,如是根帖则FID=0
   DEPTH    Int    根帖Level=0,其他根据复兴的深度递增
   BBSSubject Char    主题

2。创立表:

createtablemybbslist(
 forumIDint(20)notnull,
 bbsIDintauto_incrementprimarykey,
 rootidint(20)notnull,
 fidint(20)notnull,
 depthint(20)notnull,
 userIDint(20)notnull,
 bbsUservarchar(24)notnull,
 bbsSubjectvarchar(100)notnull,
 bbsContenttext,
 bbsTimevarchar(30),
 bbsReadint(20),
 bbsReplyint(20),
INDEXforumID(forumID))
3、毗连MYSQL数据库的BEAN

packagenetzero;
importjava.sql.*;
publicclassmydb
{
StringdriverName="org.gjt.mm.mysql.Driver";
Connectionconn=null;
Statementstmt=null;
ResultSetrs=null;
StringconnURL="jdbc:mysql://localhost/mybbs?user=root&password=how&useUnicode=true&characterEncode=8859_1";
//StringconnURL="jdbc:mysql://localhost/netzerobbs?user=root&password=how";
publicmydb()
{
try
{
Class.forName(driverName);
}
catch(java.lang.ClassNotFoundExceptione)
{
System.err.println("netzero(String):"+e.getMessage());
}
}

publicResultSetexecuteQuery(Stringsql)throwsSQLException
{
conn=DriverManager.getConnection(connURL);
stmt=conn.createStatement();
rs=stmt.executeQuery(sql);
returnrs;
}

publicbooleancloseConn()
{
try
{
if(rs!=null)rs.close();
if(stmt!=null)stmt.close();
if(conn!=null)conn.close();
returntrue;
}
catch(SQLExceptionex)
{
System.err.println("closeConn:"+ex.getMessage());
returnfalse;
}
}

}

4、显现论坛的JSP程序

<jsp:useBeanid="mybbs"scope="session"class="netzero.mydb"/>
<%@pagecontentType="text/html;charset=gb2312"%>
<%@pageimport="java.io.*"%>
<%@pageimport="java.sql.*"%>
<%
intintRowCount;
out.print("显现论坛树形布局");
out.print("<br><br>");
try{
Stringsql="select*frommybbslistorderbyrootiddesc,depth,fid,bbsid";
ResultSetrs=mybbs.executeQuery(sql);
if(rs.next())
{
rs.last();
intRowCount=rs.getRow();
out.print("论坛树中有");
out.print(intRowCount);
out.print("个叶子节点");
rs.first();
intj=0;
intDepth=0;
out.print("<ul>");
while(j<intRowCount)
{
intrsDepth=rs.getInt("Depth");
if(rsDepth<Depth)
{
for(inti=1;i<Depth+1;i=i+1)
{
out.print("</ul>");
}
}
rsDepth=rs.getInt("Depth");
if(rsDepth>Depth)
{
out.print("<ul>");
}
out.print("<li>");

Stringbbssubject=rs.getString("bbssubject");
out.print(bbssubject);
out.print("</li>");
Depth=rs.getInt("Depth");
j=j+1;
rs.next();
}
out.print("</ul>");
}
else
{
out.print("数据库中无纪录");
}
}catch(SQLExceptionE){
out.println("SQLException:"+E.getMessage());
out.println("SQLState:"+E.getSQLState());
out.println("VendorError:"+E.getErrorCode());
}
%>
<%//封闭mysql毗连
try{
if(!mybbs.closeConn());
}catch(Exceptionex){
System.err.println("closeConn:"+ex.getMessage());
}
%>






唉!都是钱闹的1.Swing和.net开发比较------从市场份额看.net开发主要占据大部分的中小型和中型的的桌面开发,原因是它封装了很多工具
作者: 小妖女    时间: 2015-1-21 12:28
学Java必读的两个开源程序就是Jive和Pet Store.。 Jive是国外一个非常著名的BBS程序,完全开放源码。论坛的设计采用了很多先进的技术,如Cache、用户认证、Filter、XML等,而且论坛完全屏蔽了对数据库的访问,可以很轻易的在不同数据库中移植。论坛还有方便的安装和管理程序,这是我们平时编程时容易忽略的一部份(中国程序员一般只注重编程的技术含量,却完全不考虑用户的感受,这就是我们与国外软件的差距所在)。
作者: 变相怪杰    时间: 2015-1-29 17:26
你现在最缺的是实际的工作经验,而不是书本上那些凭空想出来的程序。
作者: 海妖    时间: 2015-2-5 03:02
是一种由美国SUN计算机公司(Sun Microsystems, Inc.)所研究而成的语言
作者: 小魔女    时间: 2015-2-10 07:10
还好,SUN提供了Javabean可以把你的JSP中的 Java代码封装起来,便于调用也便于重用。
作者: admin    时间: 2015-2-11 13:05
Pet Store.(宠物店)是SUN公司为了演示其J2EE编程规范而推出的开放源码的程序,应该很具有权威性,想学J2EE和EJB的朋友不要 错过了。
作者: 冷月葬花魂    时间: 2015-2-11 19:30
还好,SUN提供了Javabean可以把你的JSP中的 Java代码封装起来,便于调用也便于重用。
作者: 因胸联盟    时间: 2015-2-25 19:52
是一种简化的C++语言 是一种安全的语言,具有阻绝计算机病毒传输的功能
作者: 山那边是海    时间: 2015-3-8 02:02
你可以去承接一些项目做了,一开始可能有些困难,可是你有技术积累,又考虑周全,接下项目来可以迅速作完,相信大家以后都会来找你的,所以Money就哗啦啦的。。。。。。
作者: 莫相离    时间: 2015-3-8 18:46
Java是一个纯的面向对象的程序设计语言,它继承了 C++语言面向对象技术的核心。Java舍弃了C ++语言中容易引起错误的指针(以引用取代)、运算符重载(operator overloading)
作者: 灵魂腐蚀    时间: 2015-3-13 09:10
Java是一种计算机编程语言,拥有跨平台、面向对java
作者: 蒙在股里    时间: 2015-3-16 08:54
是一种使网页(Web Page)由静态(Static)转变为动态(Dynamic)的语言
作者: 金色的骷髅    时间: 2015-3-17 17:09
[url]http://www.jdon.com/[/url]去下载,或到同济技术论坛的服务器[url]ftp://nro.shtdu.edu.cn[/url]去下,安装上有什么问题,可以到论坛上去提问。
作者: 兰色精灵    时间: 2015-3-24 06:07
Java是一个纯的面向对象的程序设计语言,它继承了 C++语言面向对象技术的核心。Java舍弃了C ++语言中容易引起错误的指针(以引用取代)、运算符重载(operator overloading)
作者: 深爱那片海    时间: 2015-3-27 00:09
Pet Store.(宠物店)是SUN公司为了演示其J2EE编程规范而推出的开放源码的程序,应该很具有权威性,想学J2EE和EJB的朋友不要 错过了。
作者: 简单生活    时间: 2015-4-1 00:09
你就该学一学Servlet了。Servlet就是服务器端小程序,他负责生成发送给客户端的HTML文件。JSP在执行时,也是先转换成Servlet再运行的。虽说JSP理论上可以完全取代Servlet,这也是SUN推出JSP的本意,可是Servlet用来控制流程跳转还是挺方便的,也令程序更清晰。接下来你应该学习一下Javabean了,可能你早就看不管JSP在HTML中嵌Java代码的混乱方式了,这种方式跟ASP又有什么区别呢?
作者: 愤怒的大鸟    时间: 2015-4-1 00:10
是一种简化的C++语言 是一种安全的语言,具有阻绝计算机病毒传输的功能
作者: 只想知道    时间: 2015-4-1 12:08
是一种将安全性(Security)列为第一优先考虑的语言
作者: 精灵巫婆    时间: 2015-4-1 16:08
Sun公司看见Oak在互联网上应用的前景,于是改造了Oak,于1995年5月以Java的名称正式发布。Java伴随着互联网的迅猛发展而发展,逐渐成为重要的网络编程语言。
作者: 飘灵儿    时间: 2015-4-3 13:55
《JAVA语言程序设计》或《JAVA从入门到精通》这两本书开始学,等你编程有感觉的时候也可以回看一下。《JAVA读书笔记》这本书,因为讲的代码很多,也很容易看懂,涉及到面也到位。是你学习技术巩固的好书,学完后就看看《JAVA编程思想》这本书,找找一个自己写的代码跟书上的代码有什么不一样。
作者: 爱飞    时间: 2015-4-4 03:38
我大二,Java也只学了一年,觉得还是看thinking in java好,有能力的话看英文原版(中文版翻的不怎么好),还能提高英文文档阅读能力。




欢迎光临 仓酷云 (http://ckuyun.com/) Powered by Discuz! X3.2