package Srv; import java.io.IOException; import java.sql.SQLException; import java.util.List; import javax.servlet.RequestDispatcher; import javax.servlet.ServletException; import javax.servlet.annotation.WebServlet; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import Dao.ArticoloDao; import Model.Articolo; /** * Servlet implementation class ArticoloSrv */ @WebServlet("/ArticoloSrv") public class ArticoloSrv extends HttpServlet { private static final long serialVersionUID = 1L; /** * @see HttpServlet#HttpServlet() */ public ArticoloSrv() { super(); // TODO Auto-generated constructor stub } /** * @see HttpServlet#doGet(HttpServletRequest request, HttpServletResponse * response) */ protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { String operazione = request.getParameter("operazione"); ArticoloDao aDao = new ArticoloDao(); if (operazione == null) { response.getWriter().append("Operazione non specificata"); return; } try { if (operazione.equals("inserimento")) { String descrizione = request.getParameter("descrizione"); String quant = request.getParameter("quantita"); int quantita = Integer.parseInt(quant); Articolo a = new Articolo(); a.setDescrizione(descrizione); a.setQuantita(quantita); aDao.insert(a); response.getWriter().append("Inserimento eseguito"); } else if (operazione.equals("update")) { String descrizione = request.getParameter("descrizione"); String quant = request.getParameter("quantita"); int quantita = Integer.parseInt(quant); String cod = request.getParameter("codice"); int codice = Integer.parseInt(cod); Articolo a = new Articolo(); a.setDescrizione(descrizione); a.setQuantita(quantita); a.setCodice(codice); aDao.update(a); response.getWriter().append("Update eseguito"); } else if (operazione.equals("delete")) { String cod = request.getParameter("codice"); int codice = Integer.parseInt(cod); aDao.delete(codice); response.getWriter().append("Delete eseguito"); } else if (operazione.equals("find")) { String cod = request.getParameter("codice"); int codice = Integer.parseInt(cod); Articolo articolo = aDao.getByCode(codice); if (articolo != null) { request.getSession().setAttribute("articoloTrovato", articolo); // Puoi fare forward a una pagina di dettaglio, ad esempio: RequestDispatcher dispatcher = getServletContext().getRequestDispatcher("/dettaglioArticolo.jsp"); dispatcher.forward(request, response); return; } else { response.getWriter().append("Articolo non trovato"); } } else if (operazione.equals("findAll")) { List listaArticoli = aDao.getAll(); request.getSession().setAttribute("elencoArticoli", listaArticoli); RequestDispatcher dispatcher = getServletContext().getRequestDispatcher("/elencoArticoli.jsp"); dispatcher.forward(request, response); return; } else { response.getWriter().append("Operazione sconosciuta: ").append(operazione); } } catch (SQLException e) { e.printStackTrace(); response.getWriter().append("Errore SQL: ").append(e.getMessage()); } catch (NumberFormatException e) { e.printStackTrace(); response.getWriter().append("Errore nel formato numero: ").append(e.getMessage()); } } /** * @see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse * response) */ protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { // TODO Auto-generated method stub doGet(request, response); } }