All Downloads are FREE. Search and download functionalities are using the official Maven repository.

javax.web.skeleton4j.remote.InterfaceInvokerFactory Maven / Gradle / Ivy

There is a newer version: 1.0.2
Show newest version
/**
 * RNKRSOFT OPEN SOURCE SOFTWARE LICENSE TERMS ver.1
 * - 氡氪网络科技(重庆)有限公司 开源软件许可条款(版本1)
 * 氡氪网络科技(重庆)有限公司 以下简称Rnkrsoft。
 * 这些许可条款是 Rnkrsoft Corporation(或您所在地的其中一个关联公司)与您之间达成的协议。
 * 请阅读本条款。本条款适用于所有Rnkrsoft的开源软件项目,任何个人或企业禁止以下行为:
 * .禁止基于删除开源代码所附带的本协议内容、
 * .以非Rnkrsoft的名义发布Rnkrsoft开源代码或者基于Rnkrsoft开源源代码的二次开发代码到任何公共仓库,
 * 除非上述条款附带有其他条款。如果确实附带其他条款,则附加条款应适用。
 * 

* 使用该软件,即表示您接受这些条款。如果您不接受这些条款,请不要使用该软件。 * 如下所述,安装或使用该软件也表示您同意在验证、自动下载和安装某些更新期间传输某些标准计算机信息以便获取基于 Internet 的服务。 *

* 如果您遵守这些许可条款,将拥有以下权利。 * 1.阅读源代码和文档 * 如果您是个人用户,则可以在任何个人设备上阅读、分析、研究Rnkrsoft开源源代码。 * 如果您经营一家企业,则禁止在任何设备上阅读Rnkrsoft开源源代码,禁止分析、禁止研究Rnkrsoft开源源代码。 * 2.编译源代码 * 如果您是个人用户,可以对Rnkrsoft开源源代码以及修改后产生的源代码进行编译操作,编译产生的文件依然受本协议约束。 * 如果您经营一家企业,不可以对Rnkrsoft开源源代码以及修改后产生的源代码进行编译操作。 * 3.二次开发拓展功能 * 如果您是个人用户,可以基于Rnkrsoft开源源代码进行二次开发,修改产生的元代码同样受本协议约束。 * 如果您经营一家企业,不可以对Rnkrsoft开源源代码进行任何二次开发,但是可以通过联系Rnkrsoft进行商业授予权进行修改源代码。 * 完整协议。本协议以及开源源代码附加协议,共同构成了Rnkrsoft开源软件的完整协议。 *

* 4.免责声明 * 该软件按“原样”授予许可。 使用本文档的风险由您自己承担。Rnkrsoft 不提供任何明示的担保、保证或条件。 * 5.版权声明 * 本协议所对应的软件为 Rnkrsoft 所拥有的自主知识产权,如果基于本软件进行二次开发,在不改变本软件的任何组成部分的情况下的而二次开发源代码所属版权为贵公司所有。 */ package javax.web.skeleton4j.remote; import com.rnkrsoft.logtrace4j.ErrorContext; import com.rnkrsoft.logtrace4j.ErrorContextFactory; import javax.web.skeleton4j.enums.InterfaceCall; import java.util.Hashtable; import java.util.Iterator; import java.util.Map; import java.util.ServiceLoader; /** * Created by rnkrsoft.com on 2018/1/22. * 接口执行器工厂 */ public class InterfaceInvokerFactory { final static Map CACHE = new Hashtable(); /** * 构建一个Skeleton4j配置服务实例 * * @param type 实现类全限定名 * @return Skeleton4j配置服务实例 */ public static InterfaceInvoker newInstance(InterfaceCall type) { InterfaceInvoker invoker = CACHE.get(type); if (invoker != null) { return invoker; } ServiceLoader serviceLoader = ServiceLoader.load(InterfaceInvoker.class); Iterator iterator = serviceLoader.iterator(); int count = 0; while (iterator.hasNext()) { InterfaceInvoker invoker0 = iterator.next(); if (invoker0 != null) { if (invoker0.getType() == type) { count++; if (invoker == null) { invoker = invoker0; } } } } if (count == 0 || invoker == null) { ErrorContext errorContext = ErrorContextFactory.instance().reset(); errorContext.message("未发现'{}' 执行器", type) .solution("在META-INF/services/{}检查", InterfaceInvoker.class.getName()); Iterator it = serviceLoader.iterator(); int i = 0; while (it.hasNext()) { i++; InterfaceInvoker invoker0 = it.next(); errorContext.extra("found", "实现[{}] '{}' {}", i, invoker0.getType(), invoker0.getClass().getName()); } throw errorContext.runtimeException(); } else if (count > 1) { ErrorContext errorContext = ErrorContextFactory.instance().reset(); errorContext.message("发现'{}' 执行器存在多个", type) .solution("在META-INF/services/{}检查", InterfaceInvoker.class.getName()); Iterator it = serviceLoader.iterator(); int i = 0; while (it.hasNext()) { i++; InterfaceInvoker invoker0 = it.next(); errorContext.extra("found", "实现[{}] '{}' {}", i, invoker0.getType(), invoker0.getClass().getName()); } throw errorContext.runtimeException(); } CACHE.put(invoker.getType(), invoker); return invoker; } /** * 构建一个Skeleton4j配置服务实例 * * @return Skeleton4j配置服务实例 */ public static InterfaceInvoker newInstance() { return newInstance(InterfaceCall.LOCAL); } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy