`
snoopy7713
  • 浏览: 1155489 次
  • 性别: Icon_minigender_2
  • 来自: 火星郊区
博客专栏
Group-logo
OSGi
浏览量:0
社区版块
存档分类
最新评论

在equinox环境开发web应用的"利器" -- registerResources()方法 详解

    博客分类:
  • OSGi
阅读更多

registerResources()方法详解

1、简介
registerResources(...)是org.osgi.service.http.HttpService类中提供的方法,可以直接向jetty服务器中注册静态的资源。


2、使用说明
registerResources(String alias, String name, HttpContext context)

A、参数 alias

作用:
           
设置访问内容相对的URL地址

约束:

1)不能为空 null
2)必须以 / 开始
3)可以设置为 /
4)不能以 / 结束
5)不能和已经用过的alias相同,包括使用registeServlet使用的alias
6)支持通配符 * 
7)可以作为过滤器使用,见举例2的用法
8)alias的设定遵循Servlet 2.5规范的规定,下面图中举例说明设置和使用 (参见Servlet规范 2.5种 SRV.3.4 Request Path Elements章节)
如果alias为指定的具体文件,则在name参数(目录)中当中也要指向此文件,否则会出现服务器访问目录而不访问文件的情况,访问目录当然不能得到需要文件的内容,所以会报找不到文件的错误。

B、参数name
作用: 设置alias中目录以及文件在bundle中的位置。
           name实际上是一个目录名称,目录中存在alias中设定的访问内容
           当alias设定为具体的文件名称时,name也需要设定为相应路径下文件的全名
约束:
1)name不能以 / 结尾
2)name可以为 /

C、参数context
作用:context当前bundle的上下文内容。
      如果为空,equinox自动创建一个默认的context。

3、使用举例

举例1:


假设 网站为  http://www.teamlet.org   alias="/test" 
     registerResources("/test", "/", null)
     则通过  http://www.teamlet.org/test   可以访问 test下的所有静态文件内容

举例2:

假设 网站为  http://www.teamlet.org   alias="/test/*.jsp" 
     registerResources("/test/*.jsp", "/", null)
     则通过  http://www.teamlet.org/test   可以访问 test下的所有jsp内容,而所有html等其他静态内容不可以访问


4、ResourceServlet与registerResources的比较

A、相同:
registerResources是HttpService提供的方法,可以直接向jetty服务器中注册静态的资源。
ResourceServlet类通过几个的ServletAdaptor向Jetty服务器注册静态资源。

两者都只允许http请求中的三个请求方法:"GET"、"POST"和"HEAD"使用,其他的http请求方法不允许执行。

HTTP规范定义了8种可能的请求方法:
GET               检索URI中标识资源的一个简单请求
HEAD              与GET方法相同,服务器只返回状态行和头标,并不返回请求文档
POST              服务器接受被写入客户端输出流中的数据的请求
PUT               服务器保存请求数据作为指定URI新内容的请求
DELETE            服务器删除URI中命名的资源的请求
OPTIONS           关于服务器支持的请求方法信息的请求
TRACE             Web服务器反馈Http请求和其头标的请求
CONNECT           已文档化但当前未实现的一个方法,预留做隧道处理

B、区别

registerResources可以直接注册静态资源不需要filter实例,不需要ServletAdaptor适配器。
ResourceServlet可以利用ServletAdaptor设置filter来保护资源,设置字符集等预处理。

5、实用代码:

package  org.teamlet.osgi.test.servlet.filter;

import  java.io.IOException;
import  javax.servlet. * ;
import  javax.servlet.Filter;
import  javax.servlet.FilterConfig;
import  javax.servlet.Servlet;
import  javax.servlet.ServletException;
import  javax.servlet.ServletRequest;

import  org.eclipse.equinox.http.helper.BundleEntryHttpContext;
import  org.eclipse.equinox.http.helper.ContextPathServletAdaptor;
import  org.eclipse.equinox.http.helper.FilterServletAdaptor;
import  org.eclipse.equinox.http.helper.ResourceServlet;
import  org.eclipse.equinox.jsp.jasper.JspServlet;
import  org.osgi.framework.BundleActivator;
import  org.osgi.framework.BundleContext;
import  org.osgi.framework.ServiceReference;
import  org.osgi.service.http.HttpContext;
import  org.osgi.service.http.HttpService;
import  org.osgi.util.tracker.ServiceTracker;

public   class  Activator  implements  BundleActivator {

 
private  ServiceTracker httpServiceTracker;

 
public   void  start(BundleContext context)  throws  Exception {
  httpServiceTracker 
=   new  HttpServiceTracker(context);
  httpServiceTracker.open();
 }

 
public   void  stop(BundleContext context)  throws  Exception {
  httpServiceTracker.close();
 }

 
private   class  HttpServiceTracker  extends  ServiceTracker {

  
public  HttpServiceTracker(BundleContext context) {
   
super (context, HttpService. class .getName(),  null );
  }

  
public  Object addingService(ServiceReference reference) {
   
final  HttpService httpService  =  (HttpService) context.getService(reference);
   
try  {
    HttpContext commonContext 
=   new  BundleEntryHttpContext(context.getBundle(),  " /webroot " ); 
    httpService.registerResources(
" /jsp/*.jsp " " / " , commonContext); 
    httpService.registerResources(
" /jsp/*.html " " /test " , commonContext);
   } 
catch  (Exception e) {
    e.printStackTrace();
   }
   
return  httpService;
  }

  
public   void  removedService(ServiceReference reference, Object service) {
   
final  HttpService httpService  =  (HttpService) service;
   httpService.unregister(
" /jsp " ); 
   httpService.unregister(
" /jsp/*.jsp " ); 
   
super .removedService(reference, service);
  }   
 }
}
分享到:
评论

相关推荐

    equinox-SDK-3.7.zip equinox-SDK-3.7.zip

    equinox-SDK-3.7.zip equinox-SDK-3.7.zip equinox-SDK-3.7.zip equinox-SDK-3.7.zip equinox-SDK-3.7.zip equinox-SDK-3.7.zip

    equinox-SDK-3.6.1

    eclipse de osgi框架 equinox-SDK-3.6.1.part1

    使用Equinox开发OSGI应用程序工程及源码

    **使用Equinox开发OSGI应用程序工程及源码详解** OSGi(Open Service Gateway Initiative)是一种模块化系统和Java服务框架,它允许在运行时动态发现、安装、卸载和更新软件模块。Equinox是Eclipse基金会提供的一个...

    equinox-SDK-Oxygen

    综上所述,"equinox-SDK-Oxygen"提供了基于Eclipse Oxygen的Equinox OSGi框架实现,包含了开发、运行和管理OSGi应用程序所需的各种组件和工具。通过这个SDK,开发者能够构建模块化的Java应用,并利用OSGi的强大功能...

    基于Eclipse的Equinox框架开发OSGi Bundle应用

    【标题】基于Eclipse的Equinox框架开发OSGi Bundle应用 在Java世界中,OSGi(Open Services Gateway Initiative)是一种模块化系统,它允许开发者创建可独立更新和依赖管理的模块,即Bundle。Eclipse的Equinox是...

    基于Equinox开发OSGi应用(一)

    总结来说,基于Equinox的OSGi应用开发是一种强大的模块化开发方式,它提供了高度的灵活性和可扩展性。通过学习和实践,我们可以创建更加健壮、易于维护的Java应用程序。"helloworld"项目是一个很好的起点,它能帮助...

    equinox-SDK-3.8

    在"equinox-SDK-3.8"这个源码包中,我们可以看到以下几个关键的文件和目录: 1. **content.jar**:这是一个包含 Equinox 运行时环境核心组件的JAR文件。它包含了OSGi框架的核心类和实现,使得开发者可以启动和运行...

    使用Equinox开发OSGi应用程序

    由于IBM的强力支持,Equinox不仅具有良好的文档和社区资源,也成为开发者进行OSGi应用开发的首选框架。 【OSGi应用开发】 开发OSGi应用程序通常包括以下几个步骤: 1. **环境准备**:确保拥有一个支持OSGi R4的...

    深入理解OSGi:Equinox原理、应用与最佳实践源代码+equinox-SDK-3.8源代码

    本资源包括两部分:《深入理解OSGi:Equinox原理、应用与最佳实践》的源代码和equinox-SDK-3.8的源代码。 深入理解OSGi这本书提供了对OSGi,特别是Equinox实现的全面洞察。书中可能涵盖以下几个知识点: 1. **OSGi...

    equinox-SDK-3.8.2

    Equinox SDK提供了一个完整的开发环境,包含了运行时、工具和文档,使开发者能够创建、调试和部署基于OSGi的应用程序。 3. **SDK内容**: - **content.jar**:这个文件通常包含SDK的基本信息和元数据,用于描述SDK...

    Equinox开发OSGi应用程序

    ### Equinox开发OSGi应用程序 #### OSGi及框架简介 **OSGi**(Open Service Gateway Initiative)是一种用于创建模块化Java应用程序和服务的框架。它最初是为了满足嵌入式设备和家庭网关的需求而设计的,但随着...

    equinox-SDK-Mars.2.zip

    在标题中提到的"equinox-SDK-Mars.2.zip"是一个针对Eclipse Mars.2版本的Equinox SDK。Eclipse Mars.2是Eclipse IDE的4.5.2版本,发布于2016年,包含了对开发人员的各种增强功能和错误修复。Eclipse Mars版本主要...

    equinox-1.7

    Appfuse是一个开源框架,用于快速开发基于Web的应用程序。它结合了多个Java框架,如Spring、Hibernate和Struts,以简化开发过程。提到"Appfuse的缩小版",意味着这个"equinox-1.7"可能是一个定制的、精简过的Equinox...

    equinox-SDK-4.22M1.zip

    Equinox SDK 4.22M1 是 Eclipse ...总结来说,Equinox SDK 4.22M1 是一个用于 OSGi 开发的强大工具集,提供了完整的开发环境、运行时支持以及软件管理功能,使得开发者能够高效地构建模块化的、可维护的 Java 应用。

    深入理解OSGi:Equinox原理、应用与最佳实践.pdf

    4. 尽量将共享库打包成Fragment Bundle,而不是将它们包含在应用Bundle中。 5. 明确每个Bundle的作用和责任,合理规划 Bundle 的生命周期管理。 6. 使用白名单方式来控制服务的导出和导入,以增强模块的封装性。 7. ...

    pax-web基本配置包

    **Pax Web基本配置包详解** Pax Web是一款开源的...理解Pax Web的基本配置和使用方法,对于在OSGi平台进行Web应用开发至关重要。在实际项目中,需要根据具体需求灵活调整配置和集成策略,以实现最佳性能和可维护性。

    Equinox Server-side Examples Community-开源

    Eclipse Equinox支持JSP的执行和开发,因此这些示例可能会展示如何在Equinox环境中配置和运行JSP应用,以及如何与其他OSGi服务交互。 在这些示例中,你可能会学到以下知识点: 1. **OSGi服务基础**:了解OSGi服务...

    equinox-SDK-4.18.zip

    在"equinox-SDK-4.18.zip"压缩包中,包含了以下几个关键文件和目录: 1. **p2.index**: 这个文件与Eclipse的Platform Update Manager(P2)有关。P2是一个强大的软件管理和更新系统,它负责管理OSGi组件的安装、...

Global site tag (gtag.js) - Google Analytics