使用嵌入式Jetty提供静态文件

问题描述 投票:52回答:5

我正在尝试构建一个带有嵌入式Jetty的简单演示应用程序,该应用程序提供来自“html”目录的静态文件,该目录是当前工作目录的子目录。我们的想法是,包含演示jar和内容的目录可以移动到新位置并仍然有效。

我尝试过以下各种变体,但我一直在使用404。

ServletContextHandler context = 
                       new ServletContextHandler(ServletContextHandler.SESSIONS);
context.setContextPath("/");

context.getInitParams().put(
                       "org.eclipse.jetty.servlet.Default.resourceBase", "html");
context.addServlet(new ServletHolder(new DefaultServlet()), "/html");

Server jetty = new Server(8080);
jetty.setHandler(context);

jetty.start();

更新:这是Jetty教程中记录的解决方案。如正确答案所述,它使用ResourceHandler而不是ServletContextHandler

    Server server = new Server();
    SelectChannelConnector connector = new SelectChannelConnector();
    connector.setPort(8080);
    server.addConnector(connector);

    ResourceHandler resource_handler = new ResourceHandler();
    resource_handler.setDirectoriesListed(true);
    resource_handler.setWelcomeFiles(new String[]{ "index.html" });

    resource_handler.setResourceBase(".");

    HandlerList handlers = new HandlerList();
    handlers.setHandlers(new Handler[] { resource_handler, new DefaultHandler() });
    server.setHandler(handlers);

    server.start();
    server.join();
java jetty embedded-jetty
5个回答
33
投票

19
投票

使用ResourceHandler和使用DefaultServlet(使用ServletContextHandler)提供静态内容之间存在重要差异。

ResourceHandler(或持有多个HandlerList实例的ResourceHandler)被设置为上下文处理程序时,它直接处理请求并忽略任何已注册的javax.servlet.Filter实例。

如果你需要过滤器,唯一的方法是使用ServletContextHandler,为其添加过滤器,然后添加DefaultServlet,最后设置基础Resource

基础Resource表示ResourceHandler将初始化的resourceBase路径。如果从多个目录提供静态资源,请使用ResourceCollection(仍然是Resource)并使用resourceBase字符串数组初始化它:

ResourceCollection resourceCollection = new ResourceCollection();
resourceCollection.setResources(getArrayOfResourceBaseDirs());

15
投票

在我的小型Web服务器中,我有两个文件,index.htmlinfo.js位于/src/webapp下,我希望它们可以从嵌入式jetty Web服务器提供。

这就是我用静态内容解决问题的方法。

Server server = new Server(8080);

ServletContextHandler ctx = new ServletContextHandler();
ctx.setContextPath("/");

DefaultServlet defaultServlet = new DefaultServlet();
ServletHolder holderPwd = new ServletHolder("default", defaultServlet);
holderPwd.setInitParameter("resourceBase", "./src/webapp/");

ctx.addServlet(holderPwd, "/*");
ctx.addServlet(InfoServiceSocketServlet.class, "/info");

server.setHandler(ctx);

像魅力一样工作!


2
投票

我设法通过在web.xml中为“css”目录添加映射来实现类似的功能。明确告诉它使用DefaultServlet:

<servlet>
  <servlet-name>DefaultServlet</servlet-name>
  <servlet-class>org.eclipse.jetty.servlet.DefaultServlet</servlet-class>
</servlet>

<servlet-mapping>
  <servlet-name>DefaultServlet</servlet-name>
  <url-pattern>/css/*</url-pattern>
</servlet-mapping>

0
投票

这是Main.java文件:

import org.eclipse.jetty.server.Handler;
import org.eclipse.jetty.server.Server;
import org.eclipse.jetty.server.handler.DefaultHandler;
import org.eclipse.jetty.server.handler.HandlerList;
import org.eclipse.jetty.server.handler.ResourceHandler;

public class Main
{
    public static void main(String[] args) throws Exception
    {
        Server server = new Server(8080);
        ResourceHandler resource_handler = new ResourceHandler();
        resource_handler.setResourceBase("C:/Users/serge.klimkovitch/Documents/images");
        HandlerList handlers = new HandlerList();
        handlers.setHandlers(new Handler[] { resource_handler, new DefaultHandler() });
        server.setHandler(handlers);
        server.start();
        server.join();
    }
}

=====================================

这是gradle.build文件:

apply plugin: 'java'
apply plugin: 'application'

mainClassName = 'SheetsQuickstart'
sourceCompatibility = 1.7
targetCompatibility = 1.7
version = '1.0'

repositories {
    mavenCentral()
}

dependencies {
compile group: 'org.eclipse.jetty', name: 'jetty-server', version: '9.4.16.v20190411'

}

jar {
  manifest {
    attributes(
      'Main-Class': 'SheetsQuickstart'
    )
  }
  from {
    configurations.compile.collect { it.isDirectory() ? it : zipTree(it) }
  }
}

=====================================

假设存在以下文件:C:\Users\serge.klimkovitch\Documents\images\image.html

然后,在Eclipse中运行,并在浏览器中转到http://localhost:8080/image.html以查看正在提供的文件。

© www.soinside.com 2019 - 2024. All rights reserved.