How to fix a javax.naming.NamingException: Lookup failed

fayabobo picture fayabobo · Dec 27, 2013 · Viewed 42.5k times · Source

I'm trying to persist an entity via a simple jsp form but it doesn't work. the exception that appear is : javax.naming.NamingException: Lookup failed for 'java:global/jee-projet-web'. I'm using glasfish as server.

This is the code of my form:

<%@ page language="java" contentType="text/html; charset=ISO-8859-1" pageEncoding="ISO-8859-1"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1">
<title>Add admin</title>
</head>
<body>
    <p id="info">
        ${info}
    </p>
    <form action="/jee-projet-web/AddAdmin" method="post">
    <fieldset>
        <label>Nom:</label>
        <input type="text" name="lastName" value="Entrez votre nom">
        <label>Prenom</label>
        <input type="text" name="name" value="Entrez votre prnom">
    </fieldset>
        <button type="submit">Ajouter</button>
    </form>
</body>
</html>

my servlet AddAdmin:

package servlet.add;

import java.io.IOException;
import java.util.logging.Logger;

import javax.ejb.EJB;
import javax.ejb.LocalBean;
import javax.naming.Context;
import javax.naming.InitialContext;
import javax.naming.NamingException;
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 model.Admin;
import model.databaseManager.AdminManager;
import model.databaseManager.Database;

@WebServlet(urlPatterns = {"/AdminAdd"})
@SuppressWarnings("serial")
public class AddAdmin extends HttpServlet{

    private AdminManager adminManager;

    @Override
    public void init() {
        Context context;
        try {
            context = new InitialContext();
            AdminManager adminManager = (AdminManager)context.lookup("java:global/jee-projet-web");
        } catch (NamingException e) {
            Logger.getLogger(this.getClass().getName()).warning("Erreur de contexte : Dans le nom");
            e.printStackTrace();
        }
    }

    @Override
    protected void doPost(HttpServletRequest request, HttpServletResponse response) 
            throws ServletException, IOException {
        response.setContentType("text/html; charset=iso-8859-15");

        String lName = request.getParameter("lastName");
        String name = request.getParameter("name");
        if(lName.equals("") || name.equals("")) {
            request.setAttribute("info", "Erreur: Un champ n'a pas été rempli");
            RequestDispatcher dispatcher =
                    getServletContext().getRequestDispatcher("/jsp/add/add.jsp");
            dispatcher.include(request, response);return;
        }

        Admin a = new Admin(lName, name);
        adminManager.addAdmin(a);
        request.setAttribute("info", "Admin ajouté");
        RequestDispatcher dispatcher =
                getServletContext().getRequestDispatcher("/jsp/add/add.jsp");
        dispatcher.include(request, response);return;
    }
}

My entity bean Admin.java:

package model;

import java.io.Serializable;
import javax.persistence.*;


/**
 * The persistent class for the admin database table.
 * 
 */
@SuppressWarnings("serial")
@Entity
@Table(name="admin")
public class Admin implements Serializable {

    @Id
    @GeneratedValue(strategy=GenerationType.AUTO)
    private int id;

    private String lastName;

    private String firstName;

    public Admin() {
    }

    public Admin(String lName, String fName) {
        this.firstName = fName;
        this.lastName = lName;
    }

    public int getId() {
        return this.id;
    }

    public void setId(int id) {
        this.id = id;
    }

    public String getLastName() {
        return this.lastName;
    }

    public void setLastName(String lastName) {
        this.lastName = lastName;
    }

    public String getFirstName() {
        return this.firstName;
    }

    public void setFirstName(String name) {
        this.firstName = name;
    }

}

My managedBean: AdminManager

package model.databaseManager;

import java.util.List;

import javax.persistence.EntityManager;
import javax.persistence.EntityTransaction;
import javax.persistence.Query;

import model.Admin;

public class AdminManager {
    private EntityManager entityManager = null;
    private EntityTransaction entityTransaction = null;

    @SuppressWarnings("static-access")
    public AdminManager(Database database) {
        entityManager = database.ENTITY_MANAGER;
        entityTransaction = database.ENTITY_TRANSACTION;
    }

    public void addAdmin(Admin admin) {
        entityTransaction.begin();
        entityManager.persist(admin);
        entityTransaction.commit();
    }

    public List<Admin> findAll() {
        Query query =
        entityManager.createQuery("select a from Admin a ");
        @SuppressWarnings("unchecked")
        List<Admin> liste = (List<Admin>)query.getResultList();     

        return liste;
    }

    public Admin findAdmin(int id) {
        Query query =
        entityManager.createQuery("select a from Admin a where a.id = :id");
        query.setParameter("id", id);       

        return (Admin) query.getSingleResult();
    }

    public boolean updateAdmin(Admin admin) {
        entityTransaction.begin();
        Query query =
        entityManager.createQuery("select a from Admin a where a.id = :id");
        query.setParameter("id", admin.getId());    
        if(query.getSingleResult()!=null) {
            entityManager.merge(admin);
            entityTransaction.commit();
            return true;
        }
        else return false;
    }

    public boolean deleteAdmin(int id) {
        entityTransaction.begin();
        Admin a = entityManager.find(Admin.class, id);
        if (a != null) {
            entityManager.remove(a);
            entityTransaction.commit();
            return true;
        }
        else return false;
    }

}

my file web.xml:

<?xml version="1.0" encoding="UTF-8"?>
<web-app version="3.0" xmlns="http://java.sun.com/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd">  

    <!-- Configuration jstl -->
    <context-param>
        <param-name>javax.servlet.jsp.jstl.sql.dataSource</param-name>
        <param-value>jdbc/data</param-value>
    </context-param>

    <!-- AddAdmin mapping -->
    <servlet>
        <servlet-name>AddAdmin</servlet-name>
        <servlet-class>servlet.add.AddAdmin</servlet-class>
    </servlet>
    <servlet-mapping>
        <servlet-name>AddAdmin</servlet-name>
        <url-pattern>/AddAdmin</url-pattern>
    </servlet-mapping>  
 </web-app>

my file glassfish-web.xml

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE glassfish-web-app PUBLIC "-//GlassFish.org//DTD GlassFish Application Server 3.1 Servlet 3.0//EN" "http://glassfish.org/dtds/glassfish-web-app_3_0-1.dtd">
<glassfish-web-app>
  <context-root>/jee-projet-web</context-root>
  <class-loader delegate="true"/>
  <jsp-config>
    <property name="keepgenerated" value="true">
      <description>Conserve une copie du code des servlets auto-générées.</description>
    </property>
  </jsp-config>
</glassfish-web-app>

my file persistence.xml

<?xml version="1.0" encoding="UTF-8"?>
<persistence version="2.0" xmlns="http://java.sun.com/xml/ns/persistence" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/persistence http://java.sun.com/xml/ns/persistence/persistence_2_0.xsd">
    <persistence-unit name="jee-projet" transaction-type="RESOURCE_LOCAL">
        <provider>org.eclipse.persistence.jpa.PersistenceProvider</provider>
        <class>model.Account</class>
        <class>model.Action</class>
        <class>model.Admin</class>
        <class>model.Client</class>
        <class>model.Transaction</class>
        <class>model.Wallet</class>
        <class>model.Company</class>
        <class>model.Bourse</class>
        <class>model.Participation</class>

    <properties>
    <property name="javax.persistence.jdbc.url" 
        value="jdbc:mysql://localhost:3306/jee"/>
    <property name="javax.persistence.jdbc.user" value="root"/>
    <property name="javax.persistence.jdbc.driver" 
        value="com.mysql.jdbc.Driver"/>
    <property name="javax.persistence.jdbc.password" value="root"/>
    <property name="eclipselink.ddl-generation" 
        value="drop-and-create-tables"/>
    <property name="eclipselink.logging.level" 
      value="FINEST"/>
  </properties>
    </persistence-unit>
</persistence>

I'm sure all the 3 last files are well placed. and now when running my program here is the error in the console:

2013-12-27T14:01:02.847+0100|Grave: javax.naming.NamingException: Lookup failed for 'java:global/jee-projet-web' in SerialContext[myEnv={java.naming.factory.initial=com.sun.enterprise.naming.impl.SerialInitContextFactory, java.naming.factory.state=com.sun.corba.ee.impl.presentation.rmi.JNDIStateFactoryImpl, java.naming.factory.url.pkgs=com.sun.enterprise.naming} [Root exception is javax.naming.NameNotFoundException: jee-projet-web not found]
    at com.sun.enterprise.naming.impl.SerialContext.lookup(SerialContext.java:491)
    at com.sun.enterprise.naming.impl.SerialContext.lookup(SerialContext.java:438)
    at javax.naming.InitialContext.lookup(InitialContext.java:411)
    at javax.naming.InitialContext.lookup(InitialContext.java:411)
    at servlet.add.AddAdmin.init(AddAdmin.java:33)
    at javax.servlet.GenericServlet.init(GenericServlet.java:244)
    at org.apache.catalina.core.StandardWrapper.initServlet(StandardWrapper.java:1583)
    at org.apache.catalina.core.StandardWrapper.allocate(StandardWrapper.java:1212)
    at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:237)
    at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:160)
    at org.apache.catalina.core.StandardPipeline.doInvoke(StandardPipeline.java:734)
    at org.apache.catalina.core.StandardPipeline.invoke(StandardPipeline.java:673)
    at com.sun.enterprise.web.WebPipeline.invoke(WebPipeline.java:99)
    at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:174)
    at org.apache.catalina.connector.CoyoteAdapter.doService(CoyoteAdapter.java:357)
    at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:260)
    at com.sun.enterprise.v3.services.impl.ContainerMapper.service(ContainerMapper.java:188)
    at org.glassfish.grizzly.http.server.HttpHandler.runService(HttpHandler.java:191)
    at org.glassfish.grizzly.http.server.HttpHandler.doHandle(HttpHandler.java:168)
    at org.glassfish.grizzly.http.server.HttpServerFilter.handleRead(HttpServerFilter.java:189)
    at org.glassfish.grizzly.filterchain.ExecutorResolver$9.execute(ExecutorResolver.java:119)
    at org.glassfish.grizzly.filterchain.DefaultFilterChain.executeFilter(DefaultFilterChain.java:288)
    at org.glassfish.grizzly.filterchain.DefaultFilterChain.executeChainPart(DefaultFilterChain.java:206)
    at org.glassfish.grizzly.filterchain.DefaultFilterChain.execute(DefaultFilterChain.java:136)
    at org.glassfish.grizzly.filterchain.DefaultFilterChain.process(DefaultFilterChain.java:114)
    at org.glassfish.grizzly.ProcessorExecutor.execute(ProcessorExecutor.java:77)
    at org.glassfish.grizzly.nio.transport.TCPNIOTransport.fireIOEvent(TCPNIOTransport.java:838)
    at org.glassfish.grizzly.strategies.AbstractIOStrategy.fireIOEvent(AbstractIOStrategy.java:113)
    at org.glassfish.grizzly.strategies.WorkerThreadIOStrategy.run0(WorkerThreadIOStrategy.java:115)
    at org.glassfish.grizzly.strategies.WorkerThreadIOStrategy.access$100(WorkerThreadIOStrategy.java:55)
    at org.glassfish.grizzly.strategies.WorkerThreadIOStrategy$WorkerThreadRunnable.run(WorkerThreadIOStrategy.java:135)
    at org.glassfish.grizzly.threadpool.AbstractThreadPool$Worker.doWork(AbstractThreadPool.java:564)
    at org.glassfish.grizzly.threadpool.AbstractThreadPool$Worker.run(AbstractThreadPool.java:544)
    at java.lang.Thread.run(Thread.java:744)
Caused by: javax.naming.NameNotFoundException: jee-projet-web not found
    at com.sun.enterprise.naming.impl.TransientContext.doLookup(TransientContext.java:237)
    at com.sun.enterprise.naming.impl.TransientContext.lookup(TransientContext.java:204)
    at com.sun.enterprise.naming.impl.TransientContext.lookup(TransientContext.java:208)
    at com.sun.enterprise.naming.impl.SerialContextProviderImpl.lookup(SerialContextProviderImpl.java:66)
    at com.sun.enterprise.naming.impl.LocalSerialContextProviderImpl.lookup(LocalSerialContextProviderImpl.java:114)
    at com.sun.enterprise.naming.impl.SerialContext.lookup(SerialContext.java:478)
    ... 33 more
2013-12-27T14:01:02.872+0100|Avertissement: StandardWrapperValve[AddAdmin]: Servlet.service() for servlet AddAdmin threw exception
java.lang.NullPointerException
    at servlet.add.AddAdmin.doPost(AddAdmin.java:55)
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:707)
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:790)
    at org.apache.catalina.core.StandardWrapper.service(StandardWrapper.java:1682)
    at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:318)
    at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:160)
    at org.apache.catalina.core.StandardPipeline.doInvoke(StandardPipeline.java:734)
    at org.apache.catalina.core.StandardPipeline.invoke(StandardPipeline.java:673)
    at com.sun.enterprise.web.WebPipeline.invoke(WebPipeline.java:99)
    at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:174)
    at org.apache.catalina.connector.CoyoteAdapter.doService(CoyoteAdapter.java:357)
    at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:260)
    at com.sun.enterprise.v3.services.impl.ContainerMapper.service(ContainerMapper.java:188)
    at org.glassfish.grizzly.http.server.HttpHandler.runService(HttpHandler.java:191)
    at org.glassfish.grizzly.http.server.HttpHandler.doHandle(HttpHandler.java:168)
    at org.glassfish.grizzly.http.server.HttpServerFilter.handleRead(HttpServerFilter.java:189)
    at org.glassfish.grizzly.filterchain.ExecutorResolver$9.execute(ExecutorResolver.java:119)
    at org.glassfish.grizzly.filterchain.DefaultFilterChain.executeFilter(DefaultFilterChain.java:288)
    at org.glassfish.grizzly.filterchain.DefaultFilterChain.executeChainPart(DefaultFilterChain.java:206)
    at org.glassfish.grizzly.filterchain.DefaultFilterChain.execute(DefaultFilterChain.java:136)
    at org.glassfish.grizzly.filterchain.DefaultFilterChain.process(DefaultFilterChain.java:114)
    at org.glassfish.grizzly.ProcessorExecutor.execute(ProcessorExecutor.java:77)
    at org.glassfish.grizzly.nio.transport.TCPNIOTransport.fireIOEvent(TCPNIOTransport.java:838)
    at org.glassfish.grizzly.strategies.AbstractIOStrategy.fireIOEvent(AbstractIOStrategy.java:113)
    at org.glassfish.grizzly.strategies.WorkerThreadIOStrategy.run0(WorkerThreadIOStrategy.java:115)
    at org.glassfish.grizzly.strategies.WorkerThreadIOStrategy.access$100(WorkerThreadIOStrategy.java:55)
    at org.glassfish.grizzly.strategies.WorkerThreadIOStrategy$WorkerThreadRunnable.run(WorkerThreadIOStrategy.java:135)
    at org.glassfish.grizzly.threadpool.AbstractThreadPool$Worker.doWork(AbstractThreadPool.java:564)
    at org.glassfish.grizzly.threadpool.AbstractThreadPool$Worker.run(AbstractThreadPool.java:544)
    at java.lang.Thread.run(Thread.java:744)

Thank you for your coming help.

Answer

Aniket Kulkarni picture Aniket Kulkarni · Dec 27, 2013

In AddAdmin servlet you have declared

private AdminManager adminManager;

as instance variable. And in init() method you are declaring local variable again with same name that's creating problem

Change

AdminManager adminManager = (AdminManager)context.lookup("java:global/jee-projet-web");  

To

adminManager = (AdminManager)context.lookup("java:global/jee-projet-web");  

Now, this line assigns the value to adminManager

Root cause is

java.lang.NullPointerException
at servlet.add.AddAdmin.doPost(AddAdmin.java:55)  

I guess line number 55 is

adminManager.addAdmin(a);   //variable adminManager is not initialized 

adminManager is null so, calling any method on null throws NPE


Update

Root exception is javax.naming.NameNotFoundException: jee-projet-web not found

This exception is thrown when a component of the name cannot be resolved because it is not bound.

Please ensure that the name jee-projet-web is already bound.

I guess it is typo mistake missing c in jee-projet-web. It should be jee-project-web.