Java Standart Tag Library

Status
Nicht offen für weitere Antworten.

chipmount

Aktives Mitglied
Hi,
möchte mal eine jsp mit Funktionen(jstl-> die auf eine datenbank zugreift und was ausführt) realisieren

habe mir paar dokus, foren angeschaut aber nicht schlauer geworden

ich habe Tomcat 5 laufen muss ich trotzdem jakarta-taglibs installieren(welche version) oder reichen die jstl.jar
und standard.jar von Tomcat aus ???

was sind ..tld??? muss ich für meine DB-Anwendung eine eigene ...tld schreiben oder wie funktioniert das ganze


danke
 

bronks

Top Contributor
Welche Dokumentationen hast Du denn gelesen? Könntest Du evtl. ein paar gute Links posten.

Ich erzähl Dir mal warum ich weiß, wie soetwas Funktioniert: Ich habe den Code studiert, den dir der "foobar" hier gepostet hat. Unter anderem ist da auch eine TLD dabei.


uuuuuuuupppps :?

das solltest Du mal ausprobieren :lol:
 

bronks

Top Contributor
chipmount hat gesagt.:
ich sehe da keine TLD-Datei für SQL...

Ahhh... Hab verstanden. Die JSTL haben eigene SQL-Funktionen. Mal sehn was man damit so machen kann. Ein einfach gehaltenes Beispiel mit MySQL

Datenbankname: adressen
Tabellenname: adressen
Datenfelder: name, vorname

Der Code gibt die Felder Name und Vorname aller Datensätze aus:
Code:
<%@ page language="java" import="java.lang.*,java.util.*" %>

<%@ taglib uri="http://java.sun.com/jsp/jstl/sql" prefix="sql" %>
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %>

<html>
    <head>
        <title> Datenbankservlet </title>
    </head>
    <body>

        <sql:setDataSource scope="session" var="dataSource"
        url="jdbc:mysql://127.0.0.1/adressen" driver="com.mysql.jdbc.Driver"
        user="root" password="geheim"/>

        <sql:query var="adressen" dataSource="${dataSource}" scope="session">
            SELECT * FROM adressen
        </sql:query>

        <c:forEach var="row" items="${adressen.rows}">
            Name:    ${row.name}

            Vorname: ${row.vorname}

        </c:forEach>

    </body>
</html>

Wohl gemerkt: Es funktioniert. Ist aber so eine PHPmäßige Lösung.
 

chipmount

Aktives Mitglied
also hab dieses beispiel so abgewandelt
http://bran.hta-bi.bfh.ch/guides/javainsel3/javainsel_170016.htm

<BASE>\jt\WEB-INF\lib\dom.jar
<BASE>\jt\WEB-INF\lib\jstl.jar
<BASE>\jt\WEB-INF\lib\standard.jar
<BASE>\jt\WEB-INF\lib\jaxen-full.jar
<BASE>\jt\WEB-INF\lib\jaxp-api.jar
<BASE>\jt\WEB-INF\lib\jdbc2_0-stdext.jar
<BASE>\jt\WEB-INF\lib\xalan.jar
<BASE>\jt\WEB-INF\lib\sax.jar
<BASE>\jt\WEB-INF\lib\xercesImpl.jar
<BASE>\jt\WEB-INF\lib\saxpath.jar

<BASE>\jt\WEB-INF\tld\c.tld

meine FirstTagDemo.jsp

Code:
<%@ taglib prefix="c" uri="/WEB-INF/tld/c.tld" %>
<% request.setAttribute( "jt", "Java-Tutor" ); %>
<% request.setAttribute( "end", "4" ); %>
<% request.setAttribute( "number", "12.03.1973. Das ist mein Geburtstag" ); %>
<c:expr value="$jt"/> 

<c:expr value="$jt.big()"/> 

<c:expr value="$jt.charAt(end)"/> 

<c:expr value="$jt.fontcolor('gray')"/> 

<c:expr value="$jt.link('http://java-tutor.com/')"/> 

<c:expr value="$jt.slice(0, end)"/> 

<c:expr value="$parseInt(number)"/> 

<c:expr value="$escape(number)"/>

leider krieg ich diese fehlermeldung:

org.apache.jasper.JasperException: /FirstTagDemo1.jsp(5,0) No tag "expr" defined in
tag library imported with prefix "c"
org.apache.jasper.compiler.DefaultErrorHandler.jspError(DefaultErrorHandler.java:39)
org.apache.jasper.compiler.ErrorDispatcher.dispatch(ErrorDispatcher.java:409)
org.apache.jasper.compiler.ErrorDispatcher.jspError(ErrorDispatcher.java:200)
org.apache.jasper.compiler.Parser.parseCustomTag(Parser.java:1308)
org.apache.jasper.compiler.Parser.parseElements(Parser.java:1560)
org.apache.jasper.compiler.Parser.parse(Parser.java:126)
org.apache.jasper.compiler.ParserController.doParse(ParserController.java:220)
org.apache.jasper.compiler.ParserController.parse(ParserController.java:101)
org.apache.jasper.compiler.Compiler.generateJava(Compiler.java:203)
org.apache.jasper.compiler.Compiler.compile(Compiler.java:470)
org.apache.jasper.compiler.Compiler.compile(Compiler.java:451)
org.apache.jasper.compiler.Compiler.compile(Compiler.java:439)
org.apache.jasper.JspCompilationContext.compile(JspCompilationContext.java:511)
org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:295)
org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:292)
org.apache.jasper.servlet.JspServlet.service(JspServlet.java:236)
javax.servlet.http.HttpServlet.service(HttpServlet.java:802)

woran liegt es???
was ist falsch???

danke
 

chipmount

Aktives Mitglied
ok hat sich erledigt

habe jezt dieses problem

meine ..html
Code:
<html>
<head>
<title>formulaire d´essaie </title>
</head>
<body>
<h3>Geben Sie den Bestellersname ein :</h3>
<FORM Method="GET" Action="sql.jsp">

Name:       <INPUT TYPE="text" name=param >


      <INPUT type=submit value=Abfrage senden>
</FORM>
</body>
</html>

meine ...jsp
Code:
<%@ taglib uri="/WEB-INF/tld/taglibs-dbtags.tld" prefix="sql" %>

<%-- open a database connection --%>

<sql:connection id="conn1">
  <sql:userId>scott</sql:userId>
  <sql:password>tiger</sql:password>
  <sql:url>jdbc:oracle:thin:@..:1521:..</sql:url>
  <sql:driver>oracle.jdbc.driver.OracleDriver</sql:driver>
</sql:connection>

<%-- open a database query --%>
<table>
<sql:statement id="stmt1" conn="conn1"> 
  <sql:query>
    select bestnr, bestelldatum, bestsum from Bestellung WHERE name=?    
  </sql:query>

  <%-- loop through the rows of your query --%>

  <sql:resultSet id="rset2">
    <tr>
      <td><sql:getColumn position="1"/></td>
      <td><sql:getColumn position="2"/></td>
      <td><sql:getColumn position="3"/></td> 
      <sql:getColumn position="4"/><%=request.getParameter("param")%>    
<sql:wasNull>[no description]</sql:wasNull></td>

    </tr>
  </sql:resultSet>
</sql:statement>
</table>

<%-- close a database connection --%>
<sql:closeConnection conn="conn1"/>

meine FEHLERMELDUNG:

javax.servlet.ServletException: java.sql.SQLException: ORA-01008: Nicht
allen Variablen ist ein Wert zugeordnet

org.apache.jasper.runtime.PageContextImpl.doHandlePageException(PageContextImpl.java:825)
org.apache.jasper.runtime.PageContextImpl.handlePageException(PageContextImpl.java:758)
org.apache.jsp.sql_jsp._jspService(sql_jsp.java:247)
org.apache.jasper.runtime.HttpJspBase.service(HttpJspBase.java:94)
javax.servlet.http.HttpServlet.service(HttpServlet.java:802)
org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:324)
org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:292)
org.apache.jasper.servlet.JspServlet.service(JspServlet.java:236)
javax.servlet.http.HttpServlet.service(HttpServlet.java:802)

ist die parameter übergabe falsch??
wie mach ich das richtig??
 
G

Gast

Gast
Bist Du Dir sicher, das der Wert aus der "Form" auch an das statement übergeben wird, bzw. überhaupt auf der nächsten jsp ankommt.
Teste das mal erst mal.

Frage: Warum arbeitest Du mit einer Oracle-Datenbank? Die ist doch sehr "heavy" und meiner Meinung nach nicht ganz einfach zu administrieren?
 
J

Janascho

Gast
Es liegt an folgendem:

Von dir:
Code:
<sql:query>
    select bestnr, bestelldatum, bestsum from Bestellung WHERE name=?   
  </sql:query>

Richtig wäre jetzt:
Code:
<sql:query>
    select bestnr, bestelldatum, bestsum from Bestellung WHERE name=?   
   <sql:param value="blabla" />
  </sql:query>

Durch das WHERE name = ?, also das ?, wird dadraus ein PreparedStatement. Soll heißen, die Query wurde vorbereitet und hat unbelegte Variablenstellen. Diese werden dann der Reihe nach (!!) mit <sql:param value="" /> in deinem sql:query belegt. Sollte sogar SQL-Injektion sicher sein...

Ansonsten ist eine Oracle-Datenbank wirklich sehr "heavy"...

Und klappt's?
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
T Java ServerFaces Anwendung mit XHTML & CSS Allgemeines EE 1
E modulare Java-Anwendung verteilen (Camel) Allgemeines EE 0
B Java Mail und idle() mit zig Emailadressen? Allgemeines EE 59
H JWebUnit Fehler: java.lang.NoClassDefFoundError: org/apache/regexp/RESyntaxException Allgemeines EE 24
B Java mail API - möchte nur eine gewisse Anzahl von Emails in die Liste holen Allgemeines EE 3
M Rest mit Java 11 Allgemeines EE 6
M java.lang.SecurityException: class "javax.persistence.TupleElement"'s signer information does not match ... Allgemeines EE 1
F Java Programmierer Allgemeines EE 13
R Wie viel DevOps sollte ein Java-Entwickler kennen, der sich in Microservices spezialisiert? Allgemeines EE 5
Dimax JSP Probleme mit Java in JSP Allgemeines EE 21
Dimax JSP Auf button click java methode ausführen.Ist das möglich? Allgemeines EE 6
B Logging (log4j) in JAVA EE application - WildFly Allgemeines EE 15
A Java EE (am Cleint) und websocket Allgemeines EE 8
J Ich kann Java JDK nicht downloaden Allgemeines EE 6
R Aufbau zum Java EE Entwickler - Schulungen Allgemeines EE 0
G Java EE Hosting ? Allgemeines EE 6
P Java EE Videotutorials Allgemeines EE 1
R Java Enterpise entwickeln mit Virtualbox Allgemeines EE 6
A OutOfMemoryError: Java heap space Allgemeines EE 7
I Start Word from Java Allgemeines EE 1
T Java Jersey Interceptor Allgemeines EE 7
R Post Variable in Java Allgemeines EE 8
L JSP Fehlermeldung bei Verwendung von Java-Expression-Language Allgemeines EE 8
K Wie habt ihr Java EE gelernt? Allgemeines EE 11
hjpsoft JSF Lösung einer Aufgabe im "Workshop Java EE7" Allgemeines EE 5
S Welcher Java EE Applikationserver für RESTful Webservice? Allgemeines EE 2
T Java Login Allgemeines EE 1
L Certified Master Java Enterprise Architect Java EE Allgemeines EE 3
R Java EE 6, eclipse, maven, jsf, hibernate, mysql Allgemeines EE 8
D Einfaches Java Projekt funktioniert nicht Allgemeines EE 3
W Authentifizierung und Sessions in Java EE7 Allgemeines EE 0
OnDemand Task in Java ee Allgemeines EE 7
OnDemand JSF - java File Verständnisfrage Allgemeines EE 5
OnDemand Deployen ohne .java Files Allgemeines EE 0
E Wie kann ich über einen Suchfeld in Java Server Pages nach Datenbankinhalten suchen? Allgemeines EE 11
V Java EE 7 CDI, annotations und beans Allgemeines EE 1
G Bachelorthesis: Java oder PHP (CMS) Allgemeines EE 7
X Konsolenausgabe einer java klasse in eine jsp umleiten Allgemeines EE 7
S Aufruf eines EJBs aus einer nativen Java-Applikation Allgemeines EE 1
T Fertiges html javascrip css template in java EE application Allgemeines EE 0
F Eclipse/Java EE Debug-Problem Allgemeines EE 1
D Java Projekt goes Webservice Allgemeines EE 6
L Button Handling in JSP mit Java-Backend Allgemeines EE 2
Shams Frage zu Dowload von JAVA SDK Allgemeines EE 5
T Größeres Java EE Beispiel Projekt Allgemeines EE 4
N JavaScript schickt und Java empfängt? Allgemeines EE 4
O Java EE in Netbeans + allgemeine Fragen Allgemeines EE 5
H java selenium spezis? Allgemeines EE 4
H java selenium test connection refused Allgemeines EE 6
M Java EE-Technologie-Lern-Wahl Allgemeines EE 5
B [EJB] javax.inject.DefinitionException: bean not a Java type Allgemeines EE 5
J Java Dependencies auslesen Allgemeines EE 19
2 installation java EE Allgemeines EE 12
J PHP oder Java? Allgemeines EE 12
L Webseiten Formulare über Java Oberfläche ausfüllen? Allgemeines EE 2
T Java CMS Entwicklung : Welcher Weg ist besser? Allgemeines EE 9
F Gesucht: Gratis Server für Java Entwickler Allgemeines EE 4
J Einstieg in Java EE Allgemeines EE 5
aze Eclipse Java EE Web Project:Wo liegen die Servlets ? Allgemeines EE 4
S java Entities Problem Allgemeines EE 19
D Grundüberlegung Java Webprojekt Allgemeines EE 10
F Einstieg in Java EE - Beispielanwendungen Allgemeines EE 52
R JAVA EE - eigene Klassen aus EJB übernehmen Allgemeines EE 2
T "normales" Java Programm auf einen Server laufen lassen Allgemeines EE 3
M EE6+EJB+JavaLib: Error in annotation processing: java.lang.NoClassDefFoundError Allgemeines EE 4
G java ResourceLocator Allgemeines EE 12
M Was ist mit Java möglich? Allgemeines EE 13
T Komponenten zusammenhänge Java EE Allgemeines EE 7
A Java CMS Allgemeines EE 2
P Architektur Java EE <-> HTML5 Allgemeines EE 3
A Java Tomcat findet Website nicht Allgemeines EE 8
F Java EE Server nutzung kostenlos an Schule? (zB. mit Glassfish) Allgemeines EE 6
B Java EE, kickstart my heart Allgemeines EE 10
P Frage zu Java EE Design Patterns Allgemeines EE 3
G EJB und Java EE - No Persistence provider Allgemeines EE 5
zilti Java EE Hosting, worauf muss ich achten? Allgemeines EE 5
M Java EE6: Wie Login-Vorgang durchführen? Allgemeines EE 2
MQue Java Web- Application -> MVC Allgemeines EE 4
G Java <-> Flex Allgemeines EE 2
Spin Ant - Java Beans umsetzen Allgemeines EE 4
V "null" durch NICHTS ersetzen jsp und java beans Allgemeines EE 3
M Serialisierung und Klonen in Java Allgemeines EE 5
W JAVA Optionen auslesen Allgemeines EE 3
D Spring 3 vs. Java EE 6 Allgemeines EE 33
MQue CMS in Verbindung mit Java Allgemeines EE 16
X3TitanCore Java Servertechnologie Allgemeines EE 7
C WebStart Fehler nach update auf Java 1.6 Allgemeines EE 2
R Variablen statt Java-Methoden in EL's Allgemeines EE 4
T Suche Buch für: Large Scale Web-Apps | Clustering | Scaling in Java ? Allgemeines EE 4
G Vergleich zwischen Java Spirng und Ruby on Rails Allgemeines EE 9
K EJB Enterprise Java Beans Allgemeines EE 32
F Ich will mit Java Internetseiten bauen, aber wo hosten? Allgemeines EE 14
J OOP Java Array Problem Allgemeines EE 2
T Problem mit Java Transaction API Allgemeines EE 2
D Java EE vs. Spring/Hibernate Allgemeines EE 26
R Java EE Anfänger will mehr. Allgemeines EE 7
A Fragen zum Einstieg in Java EE Allgemeines EE 11
M Evolution der Web-Entwicklung im Java-Bereich Allgemeines EE 15
N erstes Java EE Projekt - Server/ EJB-Verbindung-Anfängerfage Allgemeines EE 17
G Von Java SE nach JavaEE umsteigen Allgemeines EE 31

Ähnliche Java Themen

Neue Themen


Oben