- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
SessionContext.getBusinessObject() 在文档中描述如下,
Obtain an object that can be used to invoke the current bean through the given business interface.
Parameters: businessInterface - One of the local business interfaces or remote business interfaces for this session bean.
Returns: The business object corresponding to the given business interface.
我不能在 Java 中使用“this”关键字来完成相同的任务吗?这些有何不同?
最佳答案
这里的动机是大多数 EJB 实现都在代理上工作。将其视为老派的 AOP 并不过分。业务接口(interface)由 EJB 容器实现,通常是通过一个简单的 java.lang.reflect.Proxy,这个对象被传递给系统中通过@EJB 或 JNDI 查找请求 ejb 的每个人。
代理连接到容器,对它的所有调用都直接转到容器,容器将执行安全检查、启动/停止/暂停事务、调用拦截器等,然后最终将调用委托(delegate)给 bean实例——当然,由于抛出任何异常而需要进行任何清理——然后最终通过代理将返回值移交给调用者。
直接调用 this.foo() 或将“this”传递给调用者以便他们也可以进行直接调用,将跳过所有这些,并且容器将有效地从图片中删除。 “getBusinessObject(Class)”方法允许 bean 实例从本质上获得对自身的代理,因此它可以调用自己的方法并利用与其关联的容器管理服务——拦截器、事务管理、安全实现等。
关于java - SessionContext.getBusinessObject() 的返回值与 bean 中使用的 'this' 关键字有何不同?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3381002/
我正在使用 Glassfish 4 来部署应用程序。它曾经有一个 EJB,其中 SessionContext 通过 @Resource 注释注入(inject)。 @Stateless @Declar
我将 SessionContext 作为资源注入(inject) EJB(实现容器管理的事务): @Stateless(name = "XXX", mappedName = "PPP-MMM-CCC"
在 Java EE 上下文中,特别是在 CDI 中 ApplicationScoped对象,我需要强制回滚容器管理的事务。 (它是 JPA(事务)操作和一些文件系统操作的组合,后者并不是真正的事务性操
我有一个简单的 (webprofile) EJB 3.1 应用程序并尝试确定 @ApplicationScoped CDI Bean 中的当前用户,所以我使用: Principal callerPri
我不确定以下问题的正确答案是什么。 A developer writes a stateful session bean FooBean with two local business interfa
在 EJB 项目中,我需要替换“javax.ejb.SessionContext”中的调用主体名称。我使用 Jboss AS 6.0 Final 作为应用服务器。 我定义了一个扩展 UsernameP
在 EJB2 ,当调用另一个(本地/远程)bean 时,需要在 EJB 中使用 getEJBBusinessObject() 方法来传递对自身的引用。 是否同样适用于 EJB3 ? 例如 @State
我有一个方法,如果该人具有特定角色并且他们与 JIRA 中的特定组相关联,则可以调用该方法。由于 JIRA 中的组是动态的,因此我无法为每个 JIRA 组分配一个角色。 @DeclareRoles({
由于各种原因,我需要手动查找 SessionContext。在JBoss5中,解决方案 InitialContext initialContext = new InitialContext(); Se
背景: 我正在使用使用 Java 安全性的程序化身份验证(基本身份验证)。我有一个无状态 session bean(EJB 3)。我可以注入(inject) Sessioncontext 以获取安全主
我正在使用 Java EE 6,这是第一次使用 jax-rs 并且我有这个资源类,但我不知道为什么在访问服务时没有检索到我的 session 。登录工作正常,并且可以在应用程序的其他部分检索主体。 @
我需要编写一个 session bean,在代码中的某个位置检查当前用户是否具有某些角色。 为了对我的 EJB3 进行单元测试,我正在尝试 OpenEJB。我按照他们的例子 testing secur
我将单例 EJB 公开为 Restful 服务;要求是通过 Rest API 启动计时器。因为这将是 Web 应用程序,所以我将 ejb 类打包到 war 文件中。我能够成功部署 bean 并调用 W
SessionContext.getBusinessObject() 在文档中描述如下, Obtain an object that can be used to invoke the current
我有一个使用 Keycloak 保护的 JEE 服务 (JaxRx),身份验证有效,但是当我想使用 @RolesAllowed 应用安全性时,我得到了 EJBAccessException。 该服务部
我有一个 EJB 类,它具有 @Resource private SessionContext objSessionContext; 如果我为此属性提供 setter 和 getter,注入(inje
我收到以下 NullPointerException: Caused by: java.lang.NullPointerException at FacadeBean.createRegistrati
我的工作是使用 Servlet 编写一种 Web 服务适配器,然后调用适配器 EJB(SOAP Web 服务),而适配器 EJB 又调用现有的服务方法(也是 EJB)。现有的架构基于EJB 2.0,我
我是一名优秀的程序员,十分优秀!