Java之旅EJB(4)——如何注入其他EJB服务

2024-05-26 07:38
文章标签 java 服务 注入 之旅 ejb

本文主要是介绍Java之旅EJB(4)——如何注入其他EJB服务,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

  在讲解如何注入其他EJB服务之前,我们首先先来看看什么是本地接口,第一个例子用的是远程接口,我们来介绍一下什么是本地接口。

 1.      本地接口调用

  之前我们讲解的远程调用接口的过程如下:


  详解:首先客户端需要与ejb建立起socket通信,在通信管道上他们之间需要来回发送IIOP协议消息,因为数据要在网络进行传输,存放数据的java对象必须要进行序列化。这个过程有网络通信的开销,协议解析的开销(Internet Inter-ORB Protocol(互联网内部对象请求代理协议))原因在于ejb是分布式技术,它允许客户端与ejb应用在不同机器上面,所以这些性能开销是必然的。

  但是实际的生活中我们不可能避免这种情况,那就是客户端与ejb应用运行在同一个jboss中,那么这个时候还是否有必要跟ejb之间走上面的网络通信呢?其实是不必要的,他们之间是完全可以通过内存进行交互的。这样就避免了上面的性能开销,故而引进了本地接口。通过本地接口调用ejb,直接通过内存进行交互。

  但是需要注意一点:本地接口的调用,ejb和客户端的调用都在一个jvm内运行才可以的,才能调用本地接口,否则只能是调用远程接口,可能有人问,什么是在一个jvm呢运行呢?最简单的理解就是只要ejb和客户端发布在同一个jboss内,我们就认为是调用的本地接口。

  此时将之前的接口改为local弹出,再次进行调用出现远程接口找不到。

  开发一个web客户端

  代码如下:

<%@ page language="java" import="java.util.*" pageEncoding="GB18030"%>
<%@ page import="javax.naming.*,baidu.com.ejb.*" %><%
String path = request.getContextPath();
String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
%><!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html><head><base href="<%=basePath%>"><title>My JSP 'index.jsp' starting page</title><meta http-equiv="pragma" content="no-cache"><meta http-equiv="cache-control" content="no-cache"><meta http-equiv="expires" content="0">    <meta http-equiv="keywords" content="keyword1,keyword2,keyword3"><meta http-equiv="description" content="This is my page"></head><body>
<%--  其实java.lang.NoSuchMethodException这个异常的根本原因有两个:第一,缺少某些jar文件;第二, 某些jar文件有重复。--%>
<%--  之前总是报上面的错误,原因在于已经引进了ejb服务项目,在web端又进行了引用,故而弹出了这样的错误,删除引用即可--%>
<%--并且在web端引用ejb服务--%>
<%--因为没有书写<% %>导致输出的是源码输出,后台代码必须写上<% %>--%><%try {InitialContext ctx = new InitialContext();HelloWorld helloWorld = (HelloWorld) ctx.lookup("HelloWorldBean/local");System.out.println(helloWorld.sayHello("小明"));} catch (NamingException e) {System.out.println(e.getMessage());}%></body>
</html>

  因为是在jsp页面书写代码而非html,需要用<%%>来编写后台的代码

 2.      注解方式注入其他ejb

  介绍完了本地接口的调用,那么下面我们开看看如何注入其他的ejb服务?

  再声明一个接口和实现类为other
  Other接口

package baidu.com.ejb;public interface Other {String sayMe();
}
   OtherBean

package baidu.com.ejb.impl;import javax.ejb.Stateless;import baidu.com.ejb.Other;//默认是本地调用
@Stateless
public class OtherBean implements Other {@Overridepublic String sayMe() {return "Other";}}

  第一种是jndi查找

 

@Stateless
@Local(HelloWorld.class)
public class HelloWorldBean implements HelloWorld {// 这种方式是错误的,得到的不是ejb对象,而仅仅是一个java对象// private Other other = new OtherBean();// 第二种是ejb注入,实现的原理是:根据接口类型去寻找是否有实现了接口的ejb,寻找到结果的时候会把ejb注入进来// 如果寻找到多个的时候,怎么办?明确指明调用的是哪一个即可。一种方式是修改实现bean的名字,使得变得唯一,另一种方式@Overridepublic String sayHello(String name) {// 第一种调用方式是:jndi查找InitialContext ctx;try {ctx = new InitialContext();Other other = (Other) ctx.lookup("OtherBean/local");return name + "说:你好,世界!" + other.sayMe();} catch (NamingException e) {e.printStackTrace();}// InitialContext ctx = new InitialContext();return name;}
}

  第二种是注解注入

@Stateless
@Local(HelloWorld.class)
public class HelloWorldBean implements HelloWorld {// 这种方式是错误的,得到的不是ejb对象,而仅仅是一个java对象// private Other other = new OtherBean();// 第二种是ejb注入,实现的原理是:根据接口类型去寻找是否有实现了接口的ejb,寻找到结果的时候会把ejb注入进来// 如果寻找到多个的时候,怎么办?明确指明调用的是哪一个即可。一种方式是修改实现bean的名字,使得变得唯一,另一种方式// 指明使用的哪一个即可(beanName="OtherBean")@EJB(beanName = "OtherBean")Other other;@Overridepublic String sayHello(String name) {// 第一种调用方式是:jndi查找try {return name + "说:你好,世界!" + other.sayMe();} catch (NamingException e) {e.printStackTrace();}return name;}
}

  此外我们还可以使用其他的注入,这个自己可以亲自实践。

 3.      小结

  讲到这里,ejb的讲解也算讲解了一部分了,在接下来的学习中会持续深入,更多地与大家分享和交流,还有一篇就是实体bean的讲解了,请持续关注~

这篇关于Java之旅EJB(4)——如何注入其他EJB服务的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1003840

相关文章

JVM 的类初始化机制

前言 当你在 Java 程序中new对象时,有没有考虑过 JVM 是如何把静态的字节码(byte code)转化为运行时对象的呢,这个问题看似简单,但清楚的同学相信也不会太多,这篇文章首先介绍 JVM 类初始化的机制,然后给出几个易出错的实例来分析,帮助大家更好理解这个知识点。 JVM 将字节码转化为运行时对象分为三个阶段,分别是:loading 、Linking、initialization

Spring Security 基于表达式的权限控制

前言 spring security 3.0已经可以使用spring el表达式来控制授权,允许在表达式中使用复杂的布尔逻辑来控制访问的权限。 常见的表达式 Spring Security可用表达式对象的基类是SecurityExpressionRoot。 表达式描述hasRole([role])用户拥有制定的角色时返回true (Spring security默认会带有ROLE_前缀),去

浅析Spring Security认证过程

类图 为了方便理解Spring Security认证流程,特意画了如下的类图,包含相关的核心认证类 概述 核心验证器 AuthenticationManager 该对象提供了认证方法的入口,接收一个Authentiaton对象作为参数; public interface AuthenticationManager {Authentication authenticate(Authenti

Spring Security--Architecture Overview

1 核心组件 这一节主要介绍一些在Spring Security中常见且核心的Java类,它们之间的依赖,构建起了整个框架。想要理解整个架构,最起码得对这些类眼熟。 1.1 SecurityContextHolder SecurityContextHolder用于存储安全上下文(security context)的信息。当前操作的用户是谁,该用户是否已经被认证,他拥有哪些角色权限…这些都被保

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

Java架构师知识体认识

源码分析 常用设计模式 Proxy代理模式Factory工厂模式Singleton单例模式Delegate委派模式Strategy策略模式Prototype原型模式Template模板模式 Spring5 beans 接口实例化代理Bean操作 Context Ioc容器设计原理及高级特性Aop设计原理Factorybean与Beanfactory Transaction 声明式事物

Java进阶13讲__第12讲_1/2

多线程、线程池 1.  线程概念 1.1  什么是线程 1.2  线程的好处 2.   创建线程的三种方式 注意事项 2.1  继承Thread类 2.1.1 认识  2.1.2  编码实现  package cn.hdc.oop10.Thread;import org.slf4j.Logger;import org.slf4j.LoggerFactory

JAVA智听未来一站式有声阅读平台听书系统小程序源码

智听未来,一站式有声阅读平台听书系统 🌟&nbsp;开篇:遇见未来,从“智听”开始 在这个快节奏的时代,你是否渴望在忙碌的间隙,找到一片属于自己的宁静角落?是否梦想着能随时随地,沉浸在知识的海洋,或是故事的奇幻世界里?今天,就让我带你一起探索“智听未来”——这一站式有声阅读平台听书系统,它正悄悄改变着我们的阅读方式,让未来触手可及! 📚&nbsp;第一站:海量资源,应有尽有 走进“智听

【区块链 + 人才服务】可信教育区块链治理系统 | FISCO BCOS应用案例

伴随着区块链技术的不断完善,其在教育信息化中的应用也在持续发展。利用区块链数据共识、不可篡改的特性, 将与教育相关的数据要素在区块链上进行存证确权,在确保数据可信的前提下,促进教育的公平、透明、开放,为教育教学质量提升赋能,实现教育数据的安全共享、高等教育体系的智慧治理。 可信教育区块链治理系统的顶层治理架构由教育部、高校、企业、学生等多方角色共同参与建设、维护,支撑教育资源共享、教学质量评估、