ホームページ > php教程 > PHP开发 > jsp+サーブレット+javabean データページングメソッドの完全な例

jsp+サーブレット+javabean データページングメソッドの完全な例

高洛峰
リリース: 2016-12-29 15:25:48
オリジナル
1793 人が閲覧しました

この記事の例では、データ ページング メソッドの jsp+servlet+javabean 実装について説明します。詳細は以下のとおりです:

ここでは、将来の使用のために、すぐに学び、すぐに忘れるという精神で学習プロセスを記録します。
使用されているコードの一部はオンラインで見つけたもので、私自身の理解を加えて自分で修正しました。オリジナルかどうかはわかりませんが、私自身の学習を記録しているだけです。

使用法関連: PostgreSQL データベース、dom4j、JSP、サーブレット

まず、プロジェクト レイアウト、読者や読者自身が簡単に表示および使用できるようにするためのグローバル ビューです

jsp+サーブレット+javabean データページングメソッドの完全な例

アイデアは次のとおりです:

設定を構成に記録する.xml ファイル データベースの変更、移植、再利用を容易にするための情報。
DOM4JUtil.java は、必要なデータを取得するために XML 属性ファイルを解析するために使用されます
PostgreSQL_Util.java は、データ接続とデータベース操作をパッケージ化します
PageProperties.java は、テーブルページング属性 javaBean です
PageProperties.java は、ページング操作をカプセル化します
Page.java は、メインのページングです操作
tablePage.jsp は効果表示インターフェイスです

サードパーティの jar パッケージが使用されます:

dom4j-1.6.1.jar は XML ファイルの解析に使用されます
postgresql-9.3-1101.jdbc4.jar は JDBC 接続に使用されますto postgreSQL データベース

ページング 効果は次のとおりです。前ページ、次ページをクリックしてページをめくり、指定したページを入力するとジャンプできます(範囲外の最初または最後のページにジャンプします)。特定の実装の詳細なコードを投稿しましたので、参照してください。私は初心者であり、まだ学習段階にあるので、マスターが私にアドバイスを与えることができれば幸いです。

jsp+サーブレット+javabean データページングメソッドの完全な例

2. 特定のコードの実装

1. config.xml データベース接続情報プロパティファイル

<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE postgres[
 <!ELEMENT postgres (driver,url,username,pwd)>
 <!ELEMENT driver (#PCDATA)>
 <!ELEMENT url (#PCDATA)>
 <!ELEMENT username (#PCDATA)>
 <!ELEMENT pwd (#PCDATA)>
]>
<postgres>
 <driver>org.postgresql.Driver</driver>
 <url>jdbc:postgresql://localhost:5432/java</url>
 <username>admin</username>
 <pwd>k42jc</pwd>
</postgres>
ログイン後にコピー

3. PostgreSQL_Util.java

package util;
import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.Element;
import org.dom4j.io.SAXReader;
/** 
 * 用于解析xml属性文件 
 * @author JohsonMuler 
 * 
 */
public class DOM4JUtil {
 private static Element root=null;
 static{//静态代码块
  //创建解析对象
  SAXReader sr=new SAXReader();
  //获取当前工程路径
//  String url=System.getProperty("user.dir");
  String url=DOM4JUtil.class.getResource("").getPath();
//  System.out.println(url);
  try {
   //通过文件路径获取配置文件信息
   Document doc=sr.read(url+"config.xml");
   //获取根节点
   root=doc.getRootElement();
  } catch (DocumentException e) {
   e.printStackTrace();
  }
 }
 public static String getPostgresData(String str){
  //以根节点为基础,获取配置文件数据
  Element e=root.element(str);
  String data=e.getText();
  return data;
 }
 public static void main(String[] args) {
//  String url=DOM4JUtil.class.getResource("..").getPath();
//  System.out.println(System.getProperty("user.dir"));
//  System.out.println(url);
  String driver=getPostgresData("driver");
  String url=getPostgresData("url");
  System.out.println(driver);
  System.out.println(url);
 }
}
ログイン後にコピー

5 , TablePage.java

package util;
import java.sql.PreparedStatement;
import java.sql.Statement;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.List;
public class PostgreSQL_Util {
 private static DOM4JUtil dom=new DOM4JUtil();
 private static Connection c=null;
 private static ResultSet rs=null;
 private static String driver=dom.getPostgresData("driver");
 private static String url=dom.getPostgresData("url");
 private static String username=dom.getPostgresData("username");
 private static String pwd=dom.getPostgresData("pwd");
 public PostgreSQL_Util(){
  try {
   Class.forName(driver);
   c=DriverManager.getConnection(url);
  } catch (ClassNotFoundException e) {
   System.out.println("未找到指定类:"+e.getMessage());
  } catch (SQLException e) {
   System.out.println("获取连接异常:"+e.getMessage());
  }
 }
 /**
  * 数据查询方法(Statement)
  * @param sql
  * @return
  * @throws SQLException
  */
 public ResultSet executeQuery(String sql) throws SQLException{
  Statement s=c.createStatement();
  rs=s.executeQuery(sql);
  return rs;
 }
 /**
  * 重载方法(PreparedStatement)
  * @param sql
  * @param list
  * @return
  * @throws SQLException
  */
 public ResultSet executeQuery(String sql,List<Object> list) throws SQLException{
  PreparedStatement ps=c.prepareStatement(sql);
  for(int i=0;i<list.size();i++){
   System.out.println(list.get(i));
   System.out.println(i+1);
   ps.setObject(i+1, list.get(i));
  }
  rs=ps.executeQuery();
  c.close();
  return rs;
 }
 /**
  * 数据更新方法(添加,删除,更改)(Statement)
  * @param sql
  * @throws SQLException
  */
 public int executeUpdate(String sql) throws SQLException{
  Statement s=c.createStatement();
  int i=s.executeUpdate(sql);
  c.close();
  return i;
 }
 /**
  * 重载方法(PreparedStatement)
  * @param sql
  * @param list
  * @throws SQLException
  */
 public int executeUpdate(String sql,List<Object> list) throws SQLException{
  PreparedStatement ps=c.prepareStatement(sql);
  for(int i=0;i<list.size();i++){
   ps.setObject(i+1, list.get(i));
  }
  int i=ps.executeUpdate();
  c.close();
  return i;
 }
 /**
  * 单独的获取连接
  * @return
  * @throws ClassNotFoundException
  * @throws SQLException
  */
 public static Connection getConnection() throws ClassNotFoundException, SQLException{
  Class.forName(driver);
  c=DriverManager.getConnection(url);
  return c;
 }
}
ログイン後にコピー

6, Page.java これがメインの処理クラスです, Servlet

package bean;
import java.sql.ResultSet;
public class PageProperties {
 private int currentPage;//当前页号
 private int totalPages;//总页数
 private int totalRecords;//总数据条数
 private ResultSet rs;//动态结果集
 public PageProperties() {
  super();
 }
 public PageProperties(int currentPage, int totalPages, int totalRecords, 
   ResultSet rs) {
  super();
  this.currentPage = currentPage;
  this.totalPages = totalPages;
  this.totalRecords = totalRecords;
  this.rs = rs;
 }
 public int getCurrentPage() {
  return currentPage;
 }
 public void setCurrentPage(int currentPage) {
  this.currentPage = currentPage;
 }
 public int getTotalPages() {
  return totalPages;
 }
 public void setTotalPages(int totalPages) {
  this.totalPages = totalPages;
 }
 public int getTotalRecords() {
  return totalRecords;
 }
 public void setTotalRecords(int totalRecords) {
  this.totalRecords = totalRecords;
 }
 public ResultSet getRs() {
  return rs;
 }
 public void setRs(ResultSet rs) {
  this.rs = rs;
 }
}
ログイン後にコピー

7, tablePage.jsp フロントエンド表示効果

package bean;
import java.sql.ResultSet;
public class PageProperties {
 private int currentPage;//当前页号
 private int totalPages;//总页数
 private int totalRecords;//总数据条数
 private ResultSet rs;//动态结果集
 public PageProperties() {
  super();
 }
 public PageProperties(int currentPage, int totalPages, int totalRecords, 
   ResultSet rs) {
  super();
  this.currentPage = currentPage;
  this.totalPages = totalPages;
  this.totalRecords = totalRecords;
  this.rs = rs;
 } 
 public int getCurrentPage() {
  return currentPage;
 }
 public void setCurrentPage(int currentPage) {
  this.currentPage = currentPage;
 }
 public int getTotalPages() {
  return totalPages;
 }
 public void setTotalPages(int totalPages) {
  this.totalPages = totalPages;
 }
 public int getTotalRecords() {
  return totalRecords;
 }
 public void setTotalRecords(int totalRecords) {
  this.totalRecords = totalRecords;
 }
 public ResultSet getRs() {
  return rs;
 }
 public void setRs(ResultSet rs) {
  this.rs = rs;
 }
}
ログイン後にコピー

一見するとバックグラウンドのコードがすごく面倒に感じますが、ただし、これはプログラムの柔軟性と移植性の堅牢性を考慮して、コードの再利用を容易にします。将来の使用のために、必要に応じてプロパティ ファイル (config.xml) で関連する JDBC ドライバーを構成し、JSP ページでのリクエストを通じてバックグラウンド サーブレット (Page.jsp) の転送結果 (「結果」) を取得します。これをページのプロパティ (PageProperties.java クラス) と組み合わせることで効果を実現できます。

もちろん、これは個人的な勉強と、より多くのものを使用する傾向によるものでもあります。

この記事が JSP プログラミング設計に携わる皆様のお役に立てれば幸いです。

データ ページング メソッドの jsp+サーブレット+javabean 実装のより完全な例については、PHP 中国語 Web サイトに注目してください。

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のおすすめ
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート