OSGI.NET mainfest.xml 配置

在使用 OSGI.NET进行插件式的开发时,需要对 Mainfest.xml 进行配置, Mainfest 文件是插件的重要配置文件,其中暴露了插件启动方式以及插件启动时所依赖的程序集或其它资源的信息.一个完整的Mainfest 文件的信息如下

<?xml version="1.0" encoding="utf-8"?>
<Bundle xmlns="urn:uiosp-bundle-manifest-2.0" Name="Wisdo.HomePlugin" SymbolicName="Wisdo.HomePlugin" Version="1.0.0.0" InitializedState="Active" StartLevel="3">
  <Activator Type="Wisdo.HomePlugin.BundleActivator" Policy="Immediate" />
  <Runtime>
    <Assembly Path="bin/Wisdo.HomePlugin.dll" Share="false" />
    <Assembly Path="bin\Wisdo.EFDataModels.dll" Share="false" />
    <Assembly Path="bin\Wisdo.Commons.dll" Share="false" />
    <Assembly Path="bin\EntityFramework.dll" Share="false" />
    <Dependency BundleSymbolicName="UIShell.NavigationService" Resolution="Mandatory" />
    <Dependency BundleSymbolicName="UIShell.PermissionService" Resolution="Mandatory" />
    <Dependency BundleSymbolicName="UIShell.PageFlowService" Resolution="Mandatory" />
  </Runtime>
  <Extension Point="PageFlowService.PageNode">
    <PageNode Name="LoginPage" Priority="30" Value="~/Wisdo.HomePlugin/Hello/Index" />
  </Extension>
</Bundle>

节点 Bundle 描述插件名称[Name] xml 文件架构[xmlns] 对应的命名空间名字[SymbolicName] 版本号[]Version  以及激活状态[InitializedState]

节点 Activator 描述插件启动时所要调用的激活器[Type], 以及启动的方式[Policy] 另外还有个属性 Level 表示启动的顺序,默认是2,最大是50,数字越小,启动的越早

Runtime 节点定义了插件启动时所需要的资源:

[Assembly] 表示所依赖的本地的程序集,一般指向插件的bin 目录,

[Dependency] 表示依赖的其它的插件,类型是 xml 文件,也是就其它插件的 Mainfest .xml 文件

Extension 是扩展,表示对插件进行扩展 ,其中的属性 Point 是定义的扩展点

[PageNode] 表示在插件页面上的一些导航节点,即一个超连接,可以连接到另外一个页面上

 

接下来看看 Activator 激活器的定义

using System;
using System.Collections.Generic;
using System.Text;
using UIShell.OSGi;
using UIShell.PageFlowService;
using UIShell.PermissionService;

namespace Wisdo.HomePlugin
{
    public class BundleActivator : IBundleActivator
    {
        public static AppNavigationModel NavigationModel { get; private set; }
        public static IBundle Bundle { get; private set; }
        public static ServiceTracker<IPermissionService> PermissionServiceTracker { get; private set; }
        public static ServiceTracker<IPageFlowService> PageFlowServiceTracker { get; private set; }

        public static PageNode LayoutPageNode
        {
            get
            {
                return PageFlowServiceTracker.DefaultOrFirstService.GetPageNode("LayoutPage");
            }
        }

        public void Start(IBundleContext context)
        {
        // 插件启动的相关内容  比如 打开数据库连接
            Bundle = context.Bundle;
            NavigationModel = new AppNavigationModel(context.Bundle);
            PermissionServiceTracker = new ServiceTracker<IPermissionService>(context);
            PageFlowServiceTracker = new ServiceTracker<IPageFlowService>(context);
        }

        public void Stop(IBundleContext context)
        {
           // 插件停止的相关内容 比如 翻译数据库连接
        }
    }
}
时间: 2024-12-19 14:20:21

OSGI.NET mainfest.xml 配置的相关文章

Ninject之旅之五:Ninject XML配置

摘要 使用XML配置,需要添加Ninject XML扩展的引用.下一步是添加一个或多个包含类型注册的XML文件.记得这些文件应该跟应用程序一起发布.因此不要忘记将XML文件的属性设置成“Copy if newer”. XML配置文件像下面的配置一样: <module name="moduleName"> <bind service="Namespace.IService1, AssemblyName" to="Namespace.Conc

web.xml 配置applicationContext.xml

web.xml中classpath:和classpath*:  有什么区别? classpath:只会到你的class路径中查找找文件; classpath*:不仅包含class路径,还包括jar文件中(class路径)进行查找. 有时候会用模糊匹配的方式配置多配置文件. 但是如果配置文件是在jar包里,模糊匹配就找不到了.可以用逗号隔开的方式配置多个配置文件. 如: <listener>  <listener-class>org.springframework.web.conte

笔记:MyBatis XML配置详解

MyBatis 的配置文件包含了影响 MyBatis 行为甚深的设置(settings)和属性(properties)信息.文档的顶层结构如下: configuration 配置 properties 属性 settings 设置 typeAliases 类型命名 typeHandlers 类型处理器 objectFactory 对象工厂 plugins 插件 environments 环境 environment 环境变量 transactionManager 事务管理器 dataSource

[刘阳Java]_Spring AOP基于XML配置介绍_第9讲

基于注解配置的Spring AOP固然简单,但是这节我们会给大家介绍基于XML配置的AOP是如何应用的.为什么这么说了,因为后面我们还会介绍到Spring对Dao操作的事务管理(基于AOP的XML文件方式来配置事务) 1. 基于XML文件方式来配置Spring的AOP,则我们需要的一些基本元素如下 <aop:config.../>,此标签很重要.它是在XML里配置AOP功能的核心标签 all aspect and advisor elements must be placed within a

可视化、高智能、多功能、XML配置型工业条码打印、标签打印解决方案

前言 现代工业生产中,标签打印无处不在,可以说标签就是产品的脸面.标签种类繁琐,特别是在工业生产中,标签信息需要与生产系统相关联,动态地获取打印信息.当然我们可以为每个标签写一个生成程序,但如果标签种类成千上万,那么就需要投入大量的人力.物力.比如一个很小的布局变动也去修改程序代码,显然是不明智的.如何构建一个可视化.高智能.多功能的工业条码打印解决框架,正是我们迫切需要解决的难题. 可视化.高智能.多功能.XML配置型工业条码打印解决方案应运而生,旨在解决上述难题.下面简要的给出部分截图,有兴

Spring 中 Xml配置文件属性的说明

Xml配置文件属性的说明: <bean id="TheAction" ⑴ class="net.xiaxin.spring.qs.UpperAction" ⑵ singleton="true" ⑶ init-method="init" ⑷ destroy-method="cleanup" ⑸ depends-on="ActionManager" ⑹ > <propert

通过struts.xml配置为属性注入值_2015.01.04

01:web.xml配置: <?xml version="1.0" encoding="UTF-8"?> <web-app version="2.4" xmlns="http://java.sun.com/xml/ns/j2ee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="h

解决struts2中validation.xml配置无效的问题

解决struts2中validation.xml配置无效的问题,我使用了xml的验证,却始终发现无法生效,后面发现才是xml的头文件的格式问题,修改了一下就好了. 成功的xml <!DOCTYPE validators PUBLIC "-//Apache Struts//XWork Validator 1.0.2//EN" "http://struts.apache.org/dtds/xwork-validator-1.0.2.dtd"> <val

spring管理SessionFactory中XML配置

1. 综合练习目标 2. 综合练习需求 3.模块划分 1. 综合练习目标 <1>复习 Java 基本语法 <2>熟悉掌握Java开发常用API <3>尝试建立面向对象思想 2. 综合练习需求 <1>接收用户的命令行输入 <2>以文件为基础完成数据的增删改查操作          3.模块划分 UI模块:(Java存在文本中都是以字符型式) 数据验证模块:验证用户输入是否合法 spring管理SessionFactory中XML配置,布布扣,bub