- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我创建了一个 Web 应用程序,它具有使用 JSF 技术的 createBook.xhtml
并且它使用托管 Bean。在此页面中,用户必须在输入字段中填写所需信息,然后点击提交按钮。然后应使用 doCreateBook()
方法将此信息保存到数据库中。我为此 Web 应用程序使用 Tomcat 7.0 服务器。
让我们先从收到的错误消息开始,它是:
javax.naming.NameNotFoundException:名称 [com.mysite.bookecommerce.beans.BookController/bookEJB] 未在此上下文中绑定(bind)。无法找到 [com.mysite.bookecommerce.beans.BookController]。
BookController 是 EJB,其代码是:
package com.mysite.bookecommerce.beans;
import java.io.Serializable;
import javax.ejb.EJB;
import javax.faces.bean.ManagedBean;
import javax.faces.bean.RequestScoped;
import com.mysite.bookecommerce.entities.Book;
@ManagedBean(name = "BookController")
@RequestScoped
public class BookController implements Serializable {
private static final long serialVersionUID = 1L;
@EJB
private BookEJB bookEJB;
private Book book = new Book();
public String doCreateBook() throws Exception{
book = bookEJB.createBook(book);
return "bookCreationSuccessful.xhtml";
}
public void doDeleteBook() throws Exception{
bookEJB.deleteBook(book);
}
public void doUpdateBook() throws Exception {
book = bookEJB.updateBook(book);
}
public BookController() {
super();
}
}
BookEJB 类是:
package com.mysite.bookecommerce.beans;
import java.util.List;
import javax.ejb.Stateful;
import javax.persistence.EntityManager;
import javax.persistence.PersistenceContext;
import javax.persistence.PersistenceContextType;
import javax.persistence.Query;
import com.mysite.bookecommerce.entities.Book;
@Stateful
public class BookEJB {
@PersistenceContext(unitName = "BookECommercePU", type = PersistenceContextType.EXTENDED)
private EntityManager em;
public Book createBook(Book book) throws Exception {
em.persist(book);
return book;
}
public void deleteBook(Book book) throws Exception {
em.remove(book);
}
public Book updateBook(Book book) throws Exception {
em.merge(book);
return book;
}
@SuppressWarnings("unchecked")
public List<Book> getBooks() throws Exception {
Query query = em.createQuery("SELECT b from Book AS b");
return query.getResultList();
}
}
书是实体类,代码是:
@Entity
@Table(name = "BOOKS")
public class Book {
@Id
@GeneratedValue(strategy = GenerationType.AUTO)
private Long ID;
@Column(nullable = false)
private String name;
@Column(nullable = false, length = 2000)
private String description;
@Length(max = 10)
@Column(nullable = false)
private int isbn10;
@Length(max = 14)
private String isbn13;
@Column(nullable = false)
private String author;
private String publisher;
private int publishYear;
@Column(nullable = false)
private int numberOfPages;
@Column(nullable = false)
private double price;
private boolean illustrations;
private String dimension;
private double weight;
private int quantity;
//getters and setters
还有faces-config.xml文件:
<?xml version="1.0" encoding="UTF-8"?>
<faces-config
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-facesconfig_2_0.xsd"
version="2.0">
<managed-bean>
<managed-bean-name>BookController</managed-bean-name>
<managed-bean-class>com.mysite.bookecommerce.beans.BookController</managed-bean-class>
<managed-bean-scope>request</managed-bean-scope>
</managed-bean>
最后是 web.xml 代码:
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns="http://java.sun.com/xml/ns/javaee" xmlns:web="http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"
xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd"
id="WebApp_ID" version="3.0">
<display-name>BookECommerce</display-name>
<welcome-file-list>
<welcome-file>index.html</welcome-file>
<welcome-file>index.htm</welcome-file>
</welcome-file-list>
<servlet>
<servlet-name>Faces Servlet</servlet-name>
<servlet-class>javax.faces.webapp.FacesServlet</servlet-class>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>Faces Servlet</servlet-name>
<url-pattern>/faces/*</url-pattern>
</servlet-mapping>
<servlet-mapping>
<servlet-name>Faces Servlet</servlet-name>
<url-pattern>*.jsf</url-pattern>
</servlet-mapping>
<servlet-mapping>
<servlet-name>Faces Servlet</servlet-name>
<url-pattern>*.faces</url-pattern>
</servlet-mapping>
<servlet-mapping>
<servlet-name>Faces Servlet</servlet-name>
<url-pattern>*.xhtml</url-pattern>
</servlet-mapping>
<context-param>
<param-name>javax.faces.PROJECT_STAGE</param-name>
<param-value>Development</param-value>
</context-param>
<context-param>
<param-name>javax.servlet.jsp.jstl.fmt.localizationContext</param-name>
<param-value>resources.application</param-value>
</context-param>
<context-param>
<description>State saving method: 'client' or 'server' (=default). See JSF Specification 2.5.2</description>
<param-name>javax.faces.STATE_SAVING_METHOD</param-name>
<param-value>client</param-value>
</context-param>
<context-param>
<param-name>org.apache.myfaces.ALLOW_JAVASCRIPT</param-name>
<param-value>true</param-value>
</context-param>
<context-param>
<param-name>org.apache.myfaces.PRETTY_HTML</param-name>
<param-value>true</param-value>
</context-param>
<context-param>
<param-name>org.apache.myfaces.DETECT_JAVASCRIPT</param-name>
<param-value>false</param-value>
</context-param>
<context-param>
<param-name>org.apache.myfaces.AUTO_SCROLL</param-name>
<param-value>true</param-value>
</context-param>
<listener>
<listener-class>org.apache.myfaces.webapp.StartupServletContextListener</listener-class>
</listener>
问题似乎是我的 Web 应用程序没有找到 BookController EJB。我该如何解决这个问题?我读到必须将它添加到 faces-config.xml 文件中,但我已经添加了它,但仍然出现此错误。
请注意,我从 Book 实体类中提取了所有导入行,因为它会使代码片段变长。
最佳答案
这里有几点需要注意:
CDI 和 EJB 不适用于普通的 Tomcat,因为 Tomcat 只是一个 servlet 容器,而不是真正的 Java EE 应用服务器,如 Glassfish或 JBoss .在 this question你会发现更多细节。
如果您真的想使用 CDI,则必须使用 javax.enterprise.context
包中的注释(例如 javax.enterprise.context.RequestScoped
).
faces-config.xml
中的 bean 声明在 JSF 2+ 中是可选的。
关于jsf - javax.naming.NameNotFoundException : Name [attribute name] is not bound in this Context. 无法找到 [类名],我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19201602/
我有一堆字符串,其中包含以姓氏,名字格式命名的名称列表,并用逗号分隔,如下所示: names 序列化字符串中的“first name last name”,我们在Stack Overflow上找到一个
在尝试合并多个数据框时,我得到了一些非常奇怪的东西。帮助! 我需要通过“RID”和“VISCODE”列合并一堆数据框。这是它的外观示例: d1 = data.frame(ID = sample(9,
让我们尽可能简单地做第一个例子。 我想知道如何应用这个宏;像这里适用于例如printf("%s",macro(arg)); #include #include #include #define
以下2个bean声明之间有什么区别吗? @Bean(name = "bean1") public A getA() { return new A(); } @Bean @Quali
if(c.get_name(&name) && name && !strcmp(name, contName)) 谁能告诉我这行代码在 C++ 中的含义 最佳答案 如果 c 有一个名字并且它等于 co
我是 Rails 的初学者,在改进我的搜索查询时遇到了一些问题: 在我调用的 Controller 中: def index if params[:search] @persons = Pers
谁能帮我解决这段代码的最后一部分的编译错误它的说法创建构造函数请帮助 public class Officer { public static void main(String args[]
关闭。这个问题需要details or clarity .它目前不接受答案。 想改进这个问题吗? 通过 editing this post 添加细节并澄清问题. 关闭 8 年前。 Improve t
我创建了一个 Web 应用程序,它具有使用 JSF 技术的 createBook.xhtml 并且它使用托管 Bean。在此页面中,用户必须在输入字段中填写所需信息,然后点击提交按钮。然后应使用 do
嘿,我正在尝试弄清楚如何将在 mySQL 中工作的语句转换为 PostgreSQL 并且很好奇是否有人知道解决方案。 这是在 mySQL 中有效的语句: def self.by_name(keywor
如果我要创建所有类型的类型,而不是使用字符串和原始类型,那么最大的缺点是什么? 通常它看起来像: String name = person.getName(); int age = person.ge
我正在尝试从以下内容中提取郊区名称: 12 street name, suburb name, CTG 1234 在 PHP 中使用正则表达式。 街道和郊区名称都可以是任意数量的单词长度。 CTG 是
我有一个呈现个人详细信息组件的父组件,并且正在注入(inject)父组件的验证器范围。如果我使用 v-validate 指令和 this.$validator.validateAll() 或 this
现在,据我了解,name[] 声明中的 extern 告诉编译器它的定义在其他地方(在我的程序中,我定义了它低于我使用它的部分)。但是为什么 strlen() 和 sizeof 会有不同的结果?str
我一直在解决一个问题: "Design a program that asks the user for a series of names (in no particular order). Aft
我的 XML 如下所示: 我想使用 JAXB 来阅读该内容。 我知道我能做到 @XmlRootElement(name="thing") public class Thing{
对于字符串 name[],我们可以使用 strlen(name)+1 和 sizeof(name) 互换 在我们的代码中没有经过深思熟虑?他们不一样吗?我检查了一下,发现两者的返回类型都是相同的,si
我正在尝试从以下内容中提取郊区名称: 12 street name, suburb name, CTG 1234 在 PHP 中使用正则表达式。 街道和郊区名称的长度可以是任意数量。 CTG 是 st
关闭。这个问题需要details or clarity .它目前不接受答案。 想改进这个问题吗? 通过 editing this post 添加细节并澄清问题. 关闭 8 年前。 Improve t
bash 手册列出了 for 的语法。复合语句为for name [ [ in [ word ... ] ] ; ] do list ; done这意味着 do 之前的分号如果 in 是可选的子句省略
我是一名优秀的程序员,十分优秀!