- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
当试图像#{bean.entity.property}
这样在EL中引用托管bean时,有时会抛出javax.el.PropertyNotFoundException: Target Unreachable
异常,通常是在设置bean属性或调用bean操作时。
似乎有五种不同的消息:
Target Unreachable, identifier 'bean' resolved to null
Target Unreachable, 'entity' returned null
Target Unreachable, 'null' returned null
Target Unreachable, ''0'' returned null
Target Unreachable, 'BracketSuffix' returned null
它们都是什么意思?它们是如何引起的,应该如何解决?
最佳答案
1.无法到达目标,标识符“ bean”解析为空
归结为,像#{bean}
这样,在EL中不能完全通过标识符(托管Bean名称)来找到托管Bean实例本身。
查明原因可以分为三个步骤:
一种。谁在管理bean?
b。 (默认)托管Bean名称是什么?
C。支持bean类在哪里?
1a。谁在管理bean?
第一步是检查哪个bean管理框架负责管理bean实例。是通过@ManagedBean
的JSF吗?还是通过@Named
的CDI?还是通过@Component
通过Spring?您能确定不会在同一个支持bean类上混合使用多个特定于bean管理框架的注释吗?例如。 @Named @Component
或@Named @ManagedBean
或@ManagedBean @Component
。错了该bean必须最多由一个bean管理框架管理,并且该框架必须正确配置。如果您不知道该选择哪个,请转至Backing beans (@ManagedBean) or CDI Beans (@Named)?和Spring JSF integration: how to inject a Spring component/service in JSF managed bean?
如果是JSF通过@ManagedBean
管理Bean,那么您需要确保以下几点:faces-config.xml
根声明与JSF 2.0兼容。因此,XSD文件和version
必须至少指定JSF 2.0或更高版本,因此不能指定1.x。
<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">
2_0
和
2.0
替换
2_1
和
2.1
。
xmlns.jcp.org
命名空间而不是
java.sun.com
。
<faces-config
xmlns="http://xmlns.jcp.org/xml/ns/javaee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-facesconfig_2_2.xsd"
version="2.2">
2_2
和
2.2
替换
2_3
和
2.3
。
javax.annotation.ManagedBean
而不是
javax.faces.bean.ManagedBean
。使用IDE自动完成功能当心,众所周知Eclipse会自动建议错误的列表中的第一项。
@ManagedBean
中的JSF 1.x样式
<managed-bean>
条目覆盖
faces-config.xml
以及不同的托管bean名称。该优先于
@ManagedBean
。从JSF 2.0开始,不必在
faces-config.xml
中注册托管bean,只需删除它即可。
/META-INF/faces-config.xml
。另见
How to reference JSF managed beans which are provided in a JAR file?
<managed-bean>
在
faces-config.xml
而不是
@ManagedBean
中注册Bean。不要忘记修复项目构建路径,以使您不再拥有JSF 2.x库(这样,
@ManagedBean
批注就不会令人困惑地成功编译)。
@Named
管理Bean,那么您需要确保以下几点:
/WEB-INF/beans.xml
文件。它可以为空,也可以仅包含以下内容:
<?xml version="1.0" encoding="UTF-8"?>
<beans 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/beans_1_0.xsd">
</beans>
beans.xml
或空
beans.xml
文件或具有与上述CDI 1.0兼容的
beans.xml
的
CDI 1.1 (Java EE 7)的行为与CDI 1.0相同。当存在与CDI 1.1兼容的
beans.xml
和显式
version="1.1"
时,默认情况下,它将仅注册具有显式CDI范围注释的
@Named
bean,例如
@RequestScoped
,
@ViewScoped
,
@SessionScoped
,
@ApplicationScoped
,等等。如果您打算将所有bean注册为CDI管理的bean,即使没有明确的CDI范围的bean,也请使用以下与CDI 1.1兼容的
/WEB-INF/beans.xml
设置为
bean-discovery-mode="all"
(默认为
bean-discovery-mode="annotated"
)。
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://xmlns.jcp.org/xml/ns/javaee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee
http://xmlns.jcp.org/xml/ns/javaee/beans_1_1.xsd"
version="1.1" bean-discovery-mode="all">
</beans>
bean-discovery-mode="annotated"
一起使用(默认)时,请确保您没有意外导入JSF范围(例如
javax.faces.bean.RequestScoped
)而不是CDI范围
javax.enterprise.context.RequestScoped
。使用IDE自动完成功能当心。
bean-discovery-mode="annotated"
(默认)一起使用时,由于
bug,您需要将Mojarra升级到2.3.3或更高版本。如果无法升级,则需要在
bean-discovery-mode="all"
中设置
beans.xml
,或将JSF 2.3特定的
@FacesConfig
批注放在WAR中的任意类上(通常是某种应用程序范围的启动类)。
/META-INF/beans.xml
(可以将其保留为空)。
@Component
管理Bean,那么您需要确保以下几点:
web.xml
中包含以下内容:
<listener>
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
faces-config.xml
中:
<application>
<el-resolver>org.springframework.web.jsf.el.SpringBeanFacesELResolver</el-resolver>
</application>
var
属性(例如,
<h:dataTable var="item">
,
<ui:repeat var="item">
,
<p:tabView var="item">
等)管理(嵌套的)bean,而您实际上得到了“ Target Unreachable,标识符'item”解析为null”,那么您需要确保以下几点:
#{item}
属性中均未引用
binding
。这是不正确的,因为
binding
属性在视图构建期间而不是在视图渲染期间运行。此外,组件树中实际上只有一个组件,在每个迭代回合中都可以简单地重用该组件。换句话说,您实际上应该使用
binding="#{bean.component}"
而不是
binding="#{item.component}"
。但是更好的方法是完全摆脱组件装订到bean的问题,并针对您认为解决此问题的方法研究/询问正确的方法。另见
How does the 'binding' attribute work in JSF? When and how should it be used?
FooBean
支持bean类,
@Named
public class FooBean {}
#{fooBean}
。
FOOBean
支持bean类,
@Named
public class FOOBean {}
#{FOOBean}
完全相同的默认托管Bean名称,并且也符合JavaBeans规范。在CDI中,2015年6月之前发布的Weld版本中也是如此,但由于
an oversight in CDI spec,在2015年6月之后发布的Weld版本(2.2.14 / 2.3.0.B1 / 3.0.0.A9)或OpenWebBeans中也是如此。 。在那些Weld版本和所有OWB版本中,只有第一个字符小写的
#{fOOBean}
。
foo
,如下所示,
@Named("foo")
public class FooBean {}
@ManagedBean(name="foo")
或
@Component("foo")
等效,则只能由
#{foo}
使用,因此,
#{fooBean}
不可用。
.class
文件必须位于其
/WEB-INF/classes
中的包结构中。或者,当将其打包为JAR模块的一部分时,包含已编译的
.class
文件的JAR必须驻留在
/WEB-INF/lib
中,因此不能驻留在例如EAR的
/lib
或其他位置。
src
中,而不是
WebContent
中,并确保启用了Project> Build Automatically。如果使用的是Maven,请确保后备bean类在
src/main/java
中,因此不在
src/main/resources
或
src/main/webapp
中。
entity
如
#{bean.entity.property}
返回
null
。这通常仅在JSF需要通过如下所示的输入组件为
property
设置值时公开,而
#{bean.entity}
实际上返回了
null
。
<h:inputText value="#{bean.entity.property}" />
@PostConstruct
或
<f:viewAction>
方法,或者也许是
add()
操作方法准备了模型实体。
@Named
@ViewScoped
public class Bean {
private Entity entity; // +getter (setter is not necessary).
@Inject
private EntityService entityService;
@PostConstruct
public void init() {
// In case you're updating an existing entity.
entity = entityService.getById(entityId);
// Or in case you want to create a new entity.
entity = new Entity();
}
// ...
}
@PostConstruct
的重要性;如果您使用的是使用
proxies的bean管理框架(例如CDI),则在常规构造函数中执行此操作将失败。始终使用
@PostConstruct
挂接托管bean实例初始化(并使用
@PreDestroy
挂接托管bean实例销毁)。此外,在构造函数中,您将无法访问任何注入的依赖项,另请参见
NullPointerException while trying to access @Inject bean in constructor。
entityId
是通过
<f:viewParam>
提供的,则需要使用
<f:viewAction>
而不是
@PostConstruct
。另见
When to use f:viewAction / preRenderView versus PostConstruct?
null
模型,以防仅在
add()
动作方法中创建它。最简单的方法是将bean放入视图范围。另见
How to choose the right bean scope?
#{bean.entity.subentity.subsubentity.property}
这样的嵌套属性时,这才使调试和修复变得更加困难。
null
。
[]
中那样在EL中使用大括号符号
#{bean.collection[index]}
时(其中
#{bean.collection}
本身不为空,但指定索引处的项不存在)时,此函数才会显示。然后,必须将此类消息解释为:
]
。当您在集合中有多个项目时,这只会使调试和修复工作更加困难。
javax.el.PropertyNotFoundException
的其他可能原因:
关于jsf - 识别和解决javax.el.PropertyNotFoundException:目标不可达,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30136732/
有点迷茫.. 在git community manual , 它说 The git log command can show lists of commits. On its own, it show
我是一名优秀的程序员,十分优秀!