BukuController.java 3.01 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98
package org.perpus.controller;

import java.io.IOException;

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 org.perpus.model.Buku;
import org.perpus.dao.BukuDAO;
import org.perpus.dao.BukuDAOImplementation;

/**
 * Servlet implementation class BukuController
 */
@WebServlet("/BukuController")
public class BukuController extends HttpServlet {
	
	private BukuDAO dao;
    private static final long serialVersionUID = 1L;
    public static final String lIST_Buku = "/listBuku.jsp";
    public static final String INSERT_OR_EDIT = "/buku.jsp";
 
	
       
    /**
     * @see HttpServlet#HttpServlet()
     */
    public BukuController() {
        dao = new BukuDAOImplementation();
    }

	/**
	 * @see HttpServlet#doGet(HttpServletRequest request, HttpServletResponse response)
	 */
	protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException 
	{
		String forward = "";
        String action = request.getParameter( "action" );
 
        if( action.equalsIgnoreCase( "delete" ) ) {
            forward = lIST_Buku;
            int isbn = Integer.parseInt( request.getParameter("isbn") );
            dao.deleteBuku(isbn);
            request.setAttribute("bukus", dao.getAllBukus() );
        }
        else if( action.equalsIgnoreCase( "edit" ) ) {
            forward = INSERT_OR_EDIT;
            int isbn = Integer.parseInt( request.getParameter("isbn") );
            Buku buku = dao.getBukuById(isbn);
            request.setAttribute("buku", buku);
        }
        else if( action.equalsIgnoreCase( "insert" ) ) {
            forward = INSERT_OR_EDIT;
        }
        else {
            forward = lIST_Buku;
            request.setAttribute("bukus", dao.getAllBukus() );
        }
        RequestDispatcher view = request.getRequestDispatcher( forward );
        view.forward(request, response);
	
		
		
	}

	/**
	 * @see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse response)
	 */
	protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
		Buku buku = new Buku();
 
		//buku.setIsbn(0);
		buku.setJudul(request.getParameter("judul"));
		buku.setPengarang(request.getParameter("pengarang"));
		buku.setPenerbit(request.getParameter("penerbit"));
		buku.setTahun(Integer.parseInt(request.getParameter("tahun")));
		buku.setHarga(Integer.parseInt(request.getParameter("harga")));
		String isbn = request.getParameter("isbn");
				
		
        if( isbn == null || isbn.isEmpty() )
            
        	dao.addBuku(buku);
        else {
            buku.setIsbn(Integer.parseInt(isbn));
            dao.updateBuku(buku);
        }
        RequestDispatcher view = request.getRequestDispatcher( lIST_Buku );
        request.setAttribute("bukus", dao.getAllBukus());
        view.forward(request, response);
	}

}