Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Nokia Innovation Day 2025: l’Europa ha bisogno di campioni nelle telecomunicazioni
Nokia Innovation Day 2025: l’Europa ha bisogno di campioni nelle telecomunicazioni
Dal richiamo di Enrico Letta alla necessità di completare il mercato unico entro il 2028 alla visione di Nokia sul ruolo dell’IA e delle reti intelligenti, il Nokia Innovation Day 2025 ha intrecciato geopolitica e tecnologia, mostrando a Vimercate come la ricerca italiana contribuisca alle sfide globali delle telecomunicazioni
Sottile, leggero e dall'autonomia WOW: OPPO Reno14 F conquista con stile e sostanza
Sottile, leggero e dall'autonomia WOW: OPPO Reno14 F conquista con stile e sostanza
OPPO Reno14 F 5G si propone come smartphone di fascia media con caratteristiche equilibrate. Il device monta processore Qualcomm Snapdragon 6 Gen 1, display AMOLED da 6,57 pollici a 120Hz, tripla fotocamera posteriore con sensore principale da 50MP e generosa batteria da 6000mAh con ricarica rapida a 45W. Si posiziona come alternativa accessibile nella gamma Reno14, proponendo un design curato e tutto quello che serve per un uso senza troppe preoccupazioni.
Destiny Rising: quando un gioco mobile supera il gioco originale
Destiny Rising: quando un gioco mobile supera il gioco originale
Tra il declino di Destiny 2 e la crisi di Bungie, il nuovo titolo mobile sviluppato da NetEase sorprende per profondità e varietà. Rising offre ciò che il live service di Bungie non riesce più a garantire, riportando i giocatori in un universo coerente. Un confronto che mette in luce i limiti tecnici e strategici dello studio di Bellevue
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 29-06-2003, 18:59   #1
Web Wolf
Senior Member
 
L'Avatar di Web Wolf
 
Iscritto dal: Nov 2001
Città: Macerata (MC)
Messaggi: 812
URGENTE !!! Aiuto per programma JSP

Ciao ragazzi, sto scrivendo questa pagina JSP che inserisce e legge in un database SQL i dati che riceve. In pratica, la funzione di inserisci funziona perfettamente, mentre la funzione di ricerca funziona, ma se c'é più di un elemento come risultato, ne visualizza solo uno (prima li visualizzava tutti e ora no ... mah misteri del java ), comunque la cosa forte é che se inserisco la funzione elimina (che per prova é la copia spiccicata della funzione ricerca) quando la seleziono il server dà un errore, mentre non lo dà se seleziono la funzione di ricerca (che sottolineo essere la sua copia perfetta, tranne che nell'istruzione if).

Quello che mi fa imbestialire del java é che se capita un errore una volta su 1000 si capisce dove é, mentre di solito tocca ad affidarsi a qualche essere superiore per capire dove c#####o é l'errore.
Voi per caso riuscieta a capirlo ?

Grazie

------------------------------------------------------------------------------

Codice:










<html>

<head>
<title>Risultato dell'operazione</title>
</head>

<body background="C://Programmi//jakarta-tomcat-3.3.1a//webapps//root//immagini//sfondo5.jpg" text="white">

<%@ page import="java.io.*" %>
<%@ page import="java.util.*"%>
<%@ page import="java.sql.*"%>


<%	
	
	Class.forName("com.mysql.jdbc.Driver").newInstance();
	
	java.sql.Connection con;
	
	con = DriverManager.getConnection("jdbc:mysql://localhost/tesina?user=Lonely Wolf&password=sagitta");	
			
	Statement stmt=con.createStatement();
		
	String sql;
	String[] pagine=request.getParameterValues("tipopagina");
	String pagina=pagine[0];
	String valoridisco[] = new String [8];
	
	if (pagina.equals("inserisci"))  {	   
	
		Enumeration eNames=request.getParameterNames();
		stmt.executeUpdate("use tesina");
		stmt.executeUpdate("create table if not exists dischi (datacom char(30), titolo char(30), code char(30), genere char(30), datapro char(30), autore char(30), casa char(30))");
	
		   while (eNames.hasMoreElements()) {
			String name=(String) eNames.nextElement();
			String[] values=request.getParameterValues(name);
			
			if (name.equals("datacom")) { valoridisco[0]=values[0]; }
			if (name.equals("titolo")) { valoridisco[1]=values[0]; }
			if (name.equals("code")) { valoridisco[2]=values[0]; }
			if (name.equals("genere")) { valoridisco[3]=values[0]; }
			if (name.equals("datapro")) { valoridisco[4]=values[0]; }
			if (name.equals("autore")) { valoridisco[5]=values[0]; }
			if (name.equals("casa")) { valoridisco[6]=values[0]; }
				 	            }
 
			
			if(valoridisco[1].equals("") || valoridisco[5].equals("") || valoridisco[2].equals("")) {  
							stmt.close();stmt=null;con.close();
							%> <jsp:forward page="errorins.jsp"/> <% }
			
			sql="insert into dischi (datacom, titolo, code, genere, datapro, autore, casa)"+
			" values ('"+valoridisco[0]+"','"+valoridisco[1]+"','"+valoridisco[2]+"','"+valoridisco[3]+"','"+valoridisco[4]+"','"+
			valoridisco[5]+"','"+valoridisco[6]+"')";
						
			stmt.executeUpdate(sql); %>

		<fieldset>
		<legend><h2><font color="white">Riepilogo dati inseriti</font></h2></legend><br>
		<p>Titolo:&nbsp&nbsp&nbsp<%= valoridisco[1] %></p>
		<p>Autore:&nbsp&nbsp&nbsp<%= valoridisco[5] %></p>
		<p>Genere:&nbsp&nbsp&nbsp<%= valoridisco[3] %></p>
		<p>Codice:&nbsp&nbsp&nbsp<%= valoridisco[2] %></p>
		<p>Casa:&nbsp&nbsp&nbsp<%= valoridisco[6] %></p>
		<p>Data di produzione:&nbsp&nbsp&nbsp<%= valoridisco[4] %></p>
		<p>Data di commercializzazione:&nbsp&nbsp&nbsp<%= valoridisco[0] %></p>
		</fieldset><br>
		<p align="center">Databse aggiornato</p>
		<br><br>
			
			
			<% } 

	if (pagina.equals("ricerca")) {
			
		Enumeration eNames=request.getParameterNames();
		stmt.executeUpdate("use tesina");

			while (eNames.hasMoreElements()) {
				String name=(String) eNames.nextElement();
				String[] values=request.getParameterValues(name);	

				if (name.equals("tiposelezione")) { valoridisco[0]=values[0]; }
				if (name.equals("campotesto")) { valoridisco[1]=values[0]; }			 
											}
		if (valoridisco[1].equals("")) { stmt.close();stmt=null;con.close(); %> <jsp:forward page="errorins.jsp"/> <% }	
		sql="select * from dischi where "+valoridisco[0]+" = '"+valoridisco[1]+"'";
		
		ResultSet rs=stmt.executeQuery(sql);
		int ris=0;
		
		if (rs.next()) { while (rs.next()) { 
					ris++;
					String datacom=rs.getString(1);
					String titolo=rs.getString(2);
					String code=rs.getString(3);
					String genere=rs.getString(4);
					String datapro=rs.getString(5);
					String autore=rs.getString(6);
					String casa=rs.getString(7);
 			
					
		%> 
		   
                   <fieldset>
			<legend><h2><font color="yellow">Risultato n:<%= ris %></font></h2></legend>
			<font color="white">
			<p>Titolo:&nbsp&nbsp&nbsp<%= titolo %></p>
			<p>Autore:&nbsp&nbsp&nbsp<%= autore %></p>		   
			<p>Genere:&nbsp&nbsp&nbsp<%= genere %></p>
			<p>Codice:&nbsp&nbsp&nbsp<%= code %></p>
			<p>Casa discografica:&nbsp&nbsp&nbsp<%= casa %></p>
			<p>Data di produzione:&nbsp&nbsp&nbsp<%= datapro %></p>
			<p>Data di commercializzazione:&nbsp&nbsp&nbsp<%= datacom %></p>
			</font>	   
		   </fieldset><br>
		

		<%	
	  
				                   } } 
		
		else { stmt.close();stmt=null;con.close(); %> <jsp:forward page="errorins.jsp"/> <% } 
		
		rs.close();
		rs=null;
				}
		
	
	if (pagina.equals("elimina")) {
			
		Enumeration eNames=request.getParameterNames();
		stmt.executeUpdate("use tesina");

			while (eNames.hasMoreElements()) {
				String name=(String) eNames.nextElement();
				String[] values=request.getParameterValues(name);	

				if (name.equals("tiposelezione")) { valoridisco[0]=values[0]; }
				if (name.equals("campotesto")) { valoridisco[1]=values[0]; }			 
											}
		if (valoridisco[1].equals("")) { stmt.close();stmt=null;con.close(); %> <jsp:forward page="errorins.jsp"/> <% }	
		sql="select * from dischi where "+valoridisco[0]+" = '"+valoridisco[1]+"'";
		
		ResultSet rs=stmt.executeQuery(sql);
		int ris=0;
		
		if (rs.next()) { while (rs.next()) { 
					ris++;
					String datacom=rs.getString(1);
					String titolo=rs.getString(2);
					String code=rs.getString(3);
					String genere=rs.getString(4);
					String datapro=rs.getString(5);
					String autore=rs.getString(6);
					String casa=rs.getString(7);
 			
					
		%> 
		   
                   <fieldset>
			<legend><h2><font color="yellow">Risultato n:<%= ris %></font></h2></legend>
			<font color="white">
			<p>Titolo:&nbsp&nbsp&nbsp<%= titolo %></p>
			<p>Autore:&nbsp&nbsp&nbsp<%= autore %></p>		   
			<p>Genere:&nbsp&nbsp&nbsp<%= genere %></p>
			<p>Codice:&nbsp&nbsp&nbsp<%= code %></p>
			<p>Casa discografica:&nbsp&nbsp&nbsp<%= casa %></p>
			<p>Data di produzione:&nbsp&nbsp&nbsp<%= datapro %></p>
			<p>Data di commercializzazione:&nbsp&nbsp&nbsp<%= datacom %></p>
			</font>	   
		   </fieldset><br>
		

		<%	
	  
				                   } } 
		
		else { stmt.close();stmt=null;con.close(); %> <jsp:forward page="errorins.jsp"/> <% } 
		
		rs.close();
		rs=null;
				}			     
	


 			


	stmt.close();
	stmt=null;

	con.close();
	

%>


</body>

</html>
[/code]
Web Wolf è offline   Rispondi citando il messaggio o parte di esso
Old 29-06-2003, 19:01   #2
Web Wolf
Senior Member
 
L'Avatar di Web Wolf
 
Iscritto dal: Nov 2001
Città: Macerata (MC)
Messaggi: 812
forse il problema é in qualche parentesi o ; che non ho chiuso, ma io non sono riuscito a trovarli.

Questo é quello che dice il server:

----------------------------------------------------------------------------------


Error: 500
Location: /elabora.jsp
Internal Servlet Error:

javax.servlet.ServletException
at org.apache.jasper.runtime.PageContextImpl.handlePageException(PageContextImpl.java:460)
at elabora_29._jspService(elabora_29.java:488)
at org.apache.jasper.runtime.HttpJspBase.service(HttpJspBase.java:119)
at javax.servlet.http.HttpServlet.service(HttpServlet.java)
at org.apache.tomcat.facade.ServletHandler.doService(ServletHandler.java:574)
at org.apache.tomcat.core.Handler.invoke(Handler.java:322)
at org.apache.tomcat.core.Handler.service(Handler.java:235)
at org.apache.tomcat.facade.ServletHandler.service(ServletHandler.java:485)
at org.apache.tomcat.core.ContextManager.internalService(ContextManager.java:917)
at org.apache.tomcat.core.ContextManager.service(ContextManager.java:833)
at org.apache.tomcat.modules.server.Http10Interceptor.processConnection(Http10Interceptor.java:176)
at org.apache.tomcat.util.net.TcpWorkerThread.runIt(PoolTcpEndpoint.java:494)
at org.apache.tomcat.util.threads.ThreadPool$ControlRunnable.run(ThreadPool.java:516)
at java.lang.Thread.run(Thread.java:536)
Root cause:
java.lang.NullPointerException
at elabora_29._jspService(elabora_29.java:340)
at org.apache.jasper.runtime.HttpJspBase.service(HttpJspBase.java:119)
at javax.servlet.http.HttpServlet.service(HttpServlet.java)
at org.apache.tomcat.facade.ServletHandler.doService(ServletHandler.java:574)
at org.apache.tomcat.core.Handler.invoke(Handler.java:322)
at org.apache.tomcat.core.Handler.service(Handler.java:235)
at org.apache.tomcat.facade.ServletHandler.service(ServletHandler.java:485)
at org.apache.tomcat.core.ContextManager.internalService(ContextManager.java:917)
at org.apache.tomcat.core.ContextManager.service(ContextManager.java:833)
at org.apache.tomcat.modules.server.Http10Interceptor.processConnection(Http10Interceptor.java:176)
at org.apache.tomcat.util.net.TcpWorkerThread.runIt(PoolTcpEndpoint.java:494)
at org.apache.tomcat.util.threads.ThreadPool$ControlRunnable.run(ThreadPool.java:516)
at java.lang.Thread.run(Thread.java:536)
Web Wolf è offline   Rispondi citando il messaggio o parte di esso
Old 30-06-2003, 11:37   #3
kingv
Senior Member
 
L'Avatar di kingv
 
Iscritto dal: Jan 2001
Città: Milano
Messaggi: 5707
vai alla riga 340 di elabora_29.java per capire la causa della NullPointerException.

Se vuoi un consiglio non mettere tutto quel codice dentro una jsp, creati un package di classi di utilità.
In particolare così apri una connection a db ogni volta che viene eseguita la jsp ed e' lentissimo :o
kingv è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Nokia Innovation Day 2025: l’Europa ha bisogno di campioni nelle telecomunicazioni Nokia Innovation Day 2025: l’Europa ha bisogno d...
Sottile, leggero e dall'autonomia WOW: OPPO Reno14 F conquista con stile e sostanza Sottile, leggero e dall'autonomia WOW: OPPO Reno...
Destiny Rising: quando un gioco mobile supera il gioco originale Destiny Rising: quando un gioco mobile supera il...
Plaud Note Pro convince per qualità e integrazione, ma l’abbonamento resta un ostacolo Plaud Note Pro convince per qualità e int...
Google Pixel 10 è compatto e ha uno zoom 5x a 899€: basta per essere un best-buy? Google Pixel 10 è compatto e ha uno zoom ...
Ancora controlli sulle e-bike, a Civitan...
Annunciato accidentalmente il nuovo gioc...
Spese militari da record: il conto nasco...
Intel e NVIDIA uniscono le forze: cos&ig...
Silent Hill f raccoglie ottimi voti su F...
L'industria farmaceutica americana si af...
Xiaomi YU7 GT avvistato al Nurburgring: ...
Intelligenza artificiale, agenti e strum...
Blocco note porta l'AI gratis sui PC, e ...
Arkheron, il nuovo gioco dell'ex lead de...
HONOR conferma Magic8: avrà AI na...
Auto volanti, il sogno si infrange: il p...
Cantieri in autostrada? Dal 2026 lo Stat...
Tesla non è molto trasparente su ...
Microsoft e NVIDIA guidano maxi-investim...
Chromium
GPU-Z
OCCT
LibreOffice Portable
Opera One Portable
Opera One 106
CCleaner Portable
CCleaner Standard
Cpu-Z
Driver NVIDIA GeForce 546.65 WHQL
SmartFTP
Trillian
Google Chrome Portable
Google Chrome 120
VirtualBox
Tutti gli articoli Tutte le news Tutti i download

Strumenti

Regole
Non Puoi aprire nuove discussioni
Non Puoi rispondere ai messaggi
Non Puoi allegare file
Non Puoi modificare i tuoi messaggi

Il codice vB è On
Le Faccine sono On
Il codice [IMG] è On
Il codice HTML è Off
Vai al Forum


Tutti gli orari sono GMT +1. Ora sono le: 14:02.


Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
Served by www3v