So erstellen Sie mit JSP+MySQL ein Gästebuch (2)
Autor:Eve Cole
Aktualisierungszeit:2009-07-02 17:13:19
Sobald Sie die Datenbank haben, müssen Sie die Meldung für den Datenbankvorgang lesen!
Nachfolgend sind die wichtigsten Programme zur Anzeige von Meldungen aufgeführt:
<%@page import="java.sql.*"
import="java.util.*"
import="java.io.*"
contentType="text/html; charset=gb2312"
%>
<html>
<Kopf>
<title>Pinghui Free Space Gästebuch</title>
<meta name="GENERATOR" content="Microsoft FrontPage 4.0">
<meta name="ProgId" content="FrontPage.Editor.Document">
<style type="text/css"><!--
Körper {Schriftgröße: 9pt}
td { Schriftgröße: 9pt}-->
</style>
</head>
<Körper>
<p align="center"><u><font size="5" face="华文新伟">Pinghui Free Space Gästebuch</font></u></p>
<table width="75%" border="1" bgcolor="#FFCCFF" bordercolorlight="#0000FF"
bordercolordark="#6666FF" cellpadding="0" cellpacing="0" align="center">
<tr>
<td colspan="5" height="202">
<%//Das Folgende behandelt die Paging-Anfrage des Benutzers
String string_page;
int Page,RecoderPage,RecoderRow;
try{string_page=request.getParameter("page");
}catch (NullPointerException e){string_page="";}
try{Page=Integer.parseInt(string_page);
}catch(NumberFormatException e)
{Seite=0;
}
java.sql.Connection sqlConn; //Datenbankverbindungsobjekt
java.sql.Statement sqlStmt; //Statement-Objekt
java.sql.ResultSet sqlRst; //Ergebnissatzobjekt
// JDBC-Treiberobjekt registrieren
Class.forName ("org.gjt.mm.mysql.Driver").newInstance ();
//Mit Datenbank verbinden
sqlConn= java.sql.DriverManager.getConnection ("jdbc:mysql://localhost/p","test","");
//Anweisungsobjekt erstellen
sqlStmt=sqlConn.createStatement
(java.sql.ResultSet.TYPE_SCROLL_INSENSITIVE,java.sql.ResultSet.CONCUR_READ_ONLY);
//SQL-Anweisung ausführen
String sqlQuery="select count(*) from comment";
sqlRst=sqlStmt.executeQuery (sqlQuery);
sqlRst.next();
int count=sqlRst.getInt(1); //Gesamtzahl der Nachrichtendatensätze abrufen
if (Page>=0)RecoderPage=Page;//Seite verarbeiten
sonst RecorderPage=0-Page*10;
if (RecoderPage>count/15){ RecoderPage=count/15; Page=RecoderPage }//Die Seite ist außerhalb der Grenzen
RecoderRow=RecoderPage*15; //Die anzuzeigende Nachrichtendatensatznummer abrufen
sqlQuery="select * from comment order by userid desc limit "+RecoderRow+",15;" //15 Datensätze gleichzeitig lesen
sqlRst=sqlStmt.executeQuery (sqlQuery);
%> Es gibt insgesamt <%=count%> Nachrichten
<% while (sqlRst.next()) //Nachrichten anzeigen
{ //Den nächsten Datensatz abrufen %> <%=sqlRst.getString("userid")%>
<table width="95%" border="1" cellspacing="1" cellpadding="1"
bordercolorlight="#6666FF" bordercolordark="#6666FF" bgcolor="#CCCCFF" align="center">
<tr>
<td width="25%">Spitzname: <%=sqlRst.getString("username")%></td>
<td width="25%">Geschlecht: <%=sqlRst.getString("sex")%></td>
<td colspan="2" width="50%">Adresse: <%=sqlRst.getString("address") %></td>
</tr>
<tr>
<td width="25%">Telefon: <%=sqlRst.getString("telnumber")%></td>
<td width="25%">Postleitzahl:<%=sqlRst.getString("post")%></td>
<td width="25%">OICQ:<%=sqlRst.getString("oicq")%></td>
<td width="25%">ICQ:<%=sqlRst.getString("icq")%></td>
</tr>
<tr>
<td colspan="2" width="50%">E-Mail:
<a href="mailto:<%=sqlRst.getString("email")%>" title="An die Person schreiben, die die Nachricht hinterlassen hat"><%=sqlRst.getString("email")%></a ></ td>
<td colspan="2" width="50%">URL:
<a href target="_blank"></a><a href="mailto:<%=sqlRst.getString("url")%>" title="An die Person schreiben, die die Nachricht hinterlassen hat">
<%=sqlRst.getString("urltitle")%></a></td>
</tr>
<tr>
<td colspan="4"><font style="line-height: 150%;color: green">
Nachricht:<%=sqlRst.getString("comment")%><br>
-<%=sqlRst.getString("time") %>
(von <%=sqlRst.getString("ip") %>)</font></td>
</tr>
</table>
<hr align="center" noshade size="2" width="95%">
<% } %> <%
//Page die Nachrichten unten
int i=count/15; //Gesamtseite, jede Seite zeigt 15 Datensätze an
int j=i/10; //Insgesamt große Seite, keine 10 Seiten werden in eine große Seite aufgeteilt
//Seite zeigt Seite an
int Startseite;
//int HrefPage;
if (Page<0) Page=0-Page*10; //10 Seiten einmal teilen
StartPage=Page/10; // 10 Seiten gleichzeitig teilen
out.print ("[Total "+(i+1)+"pages]");
//out.print ("total"+j+"screen");
//out.print ("Seite "+Seite+" anzeigen");
//out.print ("StartPage="+StartPage);
if (StartPage>0)
out.print ("|<a href="connectmysql.jsp?page=-"+Integer.toString(StartPage-1)+"">Erste 10 Seiten</a>");
für (int k=0;k<10;k++)
{ int p=StartPage*10+k;
if (p>i) break;
if (p==Seite)
out.print ("|th"+Integer.toString(p+1)+"page");
anders
out.print ("|<a href="connectmysql.jsp?page="+p+"">Page "+Integer.toString(p+1)+"</a>");
}
if (StartPage<j)
out.print ("|<a href="connectmysql.jsp?page=-"+Integer.toString(StartPage+1)+"">Nächste 10 Seiten</a>");
out.print ("|");
%> </td>
</tr>
</table>
</body>
<%
//Schließen Sie das Ergebnismengenobjekt
sqlRst.close();
//Anweisungsobjekt schließen
sqlStmt.close();
//Datenbankverbindung schließen
sqlConn.close();
%> Mängel im Programmende:
Fehler werden nicht erfasst, dies dient jedoch lediglich dazu, das Lesen der MySQL-Datenbank durch JSP zu erläutern. Wenn Sie es als Gästebuch verwenden, müssen Sie mit den Fehlern umgehen! Möchten wir trotzdem eine Nachricht hinterlassen?