JSP入门教程 下载本文

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翻页例子)》。

10. 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的头如下:

1.0 1.1 mt

http://www.orionserver.com/tutorials/tagtut/lesson1/mytags.jar My first Tag library 4.描叙标签

helloWorld

com.acme.mytags.HelloWorld empty A Hello world Tag 5.结束 四、打包

名称为:mytags.jar 其目录结构为:

com/acme/mytags/HelloWorld.class META-INF/taglib.tld

五、在jsp文件中使用自定义标签 建立hello.jsp如下:

<%@ taglib uri=\

Hello World!


六、测试运行

在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

11. 改写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;

//设置一页显示的记录数 intPageSize = 2; //取得待显示页码

strPage = request.getParameter(\ if(strPage==null){

//表明在QueryString中没有page这一个参数,此时显示第一页数据 intPage = 1; } else{

//将字符串转换成整型

intPage = java.lang.Integer.parseInt(strPage); if(intPage<1) intPage = 1; }

// 得到结果

stmt = conn.createStatement();

ResultSet sqlRst = stmt.executeQuery(\ //获取记录总数 sqlRst.last();

intRowCount = sqlRst.getRow(); //记算总页数

intPageCount = (intRowCount+intPageSize-1) / intPageSize;