intPageCount = (intRowCount+intPageSize-1) / intPageSize; //调整待显示的页码
if(intPage>intPageCount) intPage = intPageCount; %>
JSP数据库操作例程 - 数据分页显示 - JDBC 2.0 - mysql
<% if(intPageCount>0) {
//将记录指针定位到待显示页的第一条记录上 sqlRst.absolute((intPage-1) * intPageSize + 1); //显示数据 i = 0;
while(i
<%=sqlRst.getString(1)%>
<% sqlRst.next(); i++; } } %>
第<%=intPage%>页 共<%=intPageCount%>页
<%if(intPage
<%if(intPage>1){%><%}%> <%
//关闭结果集 sqlRst.close();
//关闭SQL语句对象 sqlStmt.close(); //关闭数据库
sqlCon.close(); %>
三、怎么去运行?
见前文《JAVA/JSP学习系列之八(JDBC-ODBC翻页例子)》。
Orion下自定义Tag
作者:东方一蛇/我的家
一、前言 (本文译自Orion官方站点)
本文将一步一步介绍在Orion Application Server下定义自己的标签,然后,实现该标签的功能,最后用一个jsp例子测试。 二、建立标签,实现该标签的功能。
1.命名package为:com.acme.mytags(为了和原文相同,我不做改动) package com.acme.mytags; 2.import相关class
import javax.servlet.jsp.*;
import javax.servlet.jsp.tagext.*;
3.实现javax.servlet.jsp.tagext.Tag接口: public class HelloWorld implements Tag {
4.定义局部变量
private PageContext pageContext; private Tag parent;
5.调用标签开始的实现方法
public int doStartTag() throws javax.servlet.jsp.JspException {
return SKIP_BODY; }
注意:这个方法返回 SKIP_BODY,就是标签的body为空的时候,将返回这个值,否则将返回:EVAL_BODY_INCLUDE 6.调用标签结束的实现方法
public int doEndTag() throws javax.servlet.jsp.JspException { try {
pageContext.getOut().write(\ }
catch(java.io.IOException e) {
throw new JspException(\ }
return EVAL_PAGE;
}
这样将在jsp文件的自定义标签结束地方输出“Hello World!” 7.还不够,我们还要写下面的方法: public void release() {}
对于本简单的例子,上面的方法不需要任何实现。 8.JSP的容器要调用下面的方法:
public void setPageContext(final javax.servlet.jsp.PageContext pageContext) { this.pageContext=pageContext; }
JSP容器通过上面的方法调用标签,而且上面的方法用来设置标签的PageContext. 9.JSP的容器还要调用下面的方法:
public void setParent(final javax.servlet.jsp.tagext.Tag parent) {
this.parent=parent; }
JSP容器通过上面的方法设置标签的parent-Tag,因为每个标签的PageContext都要保留它的parent标签。
10.最后,实现方法:
public javax.servlet.jsp.tagext.Tag getParent() {
return parent; } }
11. 编译标签。 三、描叙标签
现在将要写一个描叙文件,描叙该标签。 1.建立一个taglib.tld文件,
2.taglib.tld是一个XML格式的文本文件,XML的头如下:
5.结束 四、打包
名称为:mytags.jar 其目录结构为:
com/acme/mytags/HelloWorld.class META-INF/taglib.tld
五、在jsp文件中使用自定义标签 建立hello.jsp如下:
<%@ taglib uri=\
六、测试运行
在orion目录下,建立如下结构,其中,tag是自己建立的,前面的目录是本来就有的。 E:\\orion\\default-web-app\\tag
将jar文件和jsp文件全部放到这个目录下。 然后,访问:
http://localhost:[port]/tag/hello.jsp 将出现:
--------------------------------------------------------------------------------
Hello World!
-------------------------------------------------------------------------------- 七、恭喜,你已经成功了!
附:mytags.jar和hello.jsp 文件本站下载地址:
http://www.wodejia.net/softdownload/java/orion_tag01.zip
改写MySQL翻页例子
作者:东方一蛇/我的家 一、前言
其实,改写后的JDBC Data-Source是运行在Servlet中的,通过JNDI去查找数据源。我用Orion试的,将本站《JAVA/JSP学习系列之九(MySQL翻页例子) 》 简单改写了一下。 二、配置 (1)JDBC
需要将用到的JDBC驱动Copy到[ORION]/lib目录下 (2)data-source
在[ORION]/config/data-sources.xml文件中加入如下: 〈data-source
class=\ name=\
location=\ xa-location=\ ejb-location=\
connection-driver=\ username=\password=\
url=\ inactivity-timeout=\/〉
需要注意的是:
(1)ejb-location这个后面的“jdbc/mysqlDbPage”是JNDI要来查找的。 (2)connection-driver为JDBC数据库驱动 (3)url是JDBC中的URL (4)username为数据库用户名 (5)password为用户密码
(6)inactivity-timeout为数据库连接超时,默认为30秒 对于其他的地方不要改。 三、改写后的代码如下:
<%@ page contentType=\
<%@ page import=\<%
//建立一个JNDI查找对象
InitialContext JNDI_Context = new InitialContext(); //JNDI查找数据源
DataSource ds = (DataSource) JNDI_Context.lookup(\ //得到一个数据源连接
Connection conn = ds.getConnection(); int intPageSize; //一页显示的记录数 int intRowCount; //记录总数 int intPageCount; //总页数 int intPage; //待显示页码 java.lang.String strPage; int i;
//设置一页显示的记录数