我在Java /
jetty应用程序上有一个简单的ResourceHandler,jetty提供了2个简单文件,一个是html5页面,另一个是我的video.mp4视频文件。
<!DOCTYPE html>
<html>
<head><title>TEST</title></head>
<body>
<video style="width: 400px; height: 300px" src="video.mp4" autoplay="autoplay" loop="loop" preload="auto"></video>
</body>
</html>
问题是…当我第一次打开html页面时,下载并缓存了视频,并且在第一次播放后停止播放,并保持冻结状态,如果我刷新页面,循环将按预期播放(永远连续播放)回放)。
以下是Java / Jetty代码
ResourceHandler om = new ResourceHandler();
om.setDirectoriesListed(true);
om.setResourceBase(BASE_PATH);
handlers.setHandlers(new Handler[] { om });
问题是,有人知道为什么码头9.2.3投放的html5视频只播放第一个循环,然后在chrome
3.7.0上冻结…还是给出一些指导,以避免在码头播放首次播放后冻结视频?
这适用于 Jetty 9.2.3.v20140905
package org.eclipse.jetty.demo;
import java.io.File;
import java.io.IOException;
import java.io.PrintWriter;
import java.net.URLEncoder;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.eclipse.jetty.server.Server;
import org.eclipse.jetty.servlet.DefaultServlet;
import org.eclipse.jetty.servlet.ServletContextHandler;
import org.eclipse.jetty.servlet.ServletHolder;
public class VideoServerMain
{
@SuppressWarnings("serial")
public class IndexerServlet extends HttpServlet
{
@Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException
{
resp.setContentType("text/html");
PrintWriter out = resp.getWriter();
out.println("<!DOCTYPE html>");
out.println("<html><head><title>Videos</title></head>");
out.println("<body>");
for (File file : baseDir.listFiles())
{
if (file.isFile() && file.getName().endsWith(".mp4"))
{
String encodedFilename = URLEncoder.encode(file.getName(), "UTF-8");
out.println("<video style=\"width: 400px; height: 300px\" controls loop>");
out.printf(" <source src=\"%s\" type=\"video/mp4\">%n",encodedFilename);
out.println("</video>");
out.printf("<p>%s</p>%n",file.getName());
out.println("<hr/>");
}
}
out.println("</body>");
out.println("</html>");
}
}
public static void main(String[] args)
{
if (args.length != 1)
{
System.err.printf("ERROR: Usage %s [videos-dir]%n",VideoServerMain.class.getName());
System.exit(-1);
}
File baseDir = new File(args[0]);
if (!baseDir.exists() || !baseDir.isDirectory())
{
System.err.printf("ERROR: not a valid directory: %s%n",baseDir);
System.exit(-1);
}
try
{
new VideoServerMain(baseDir).start();
}
catch (Throwable t)
{
t.printStackTrace(System.err);
}
}
private final File baseDir;
public VideoServerMain(File baseDir)
{
this.baseDir = baseDir;
}
public void start() throws Exception
{
Server server = new Server(8080);
// Establish Scratch directory for the servlet context (used by JSP compilation)
File tempDir = new File(System.getProperty("java.io.tmpdir"));
File scratchDir = new File(tempDir.toString(),"embedded-jetty-html5-vide-server");
if (!scratchDir.exists())
{
if (!scratchDir.mkdirs())
{
throw new IOException("Unable to create scratch directory: " + scratchDir);
}
}
// Setup the basic application "context" for this application at "/"
// This is also known as the handler tree (in jetty speak)
ServletContextHandler context = new ServletContextHandler(ServletContextHandler.SESSIONS);
context.setContextPath("/");
context.setAttribute("javax.servlet.context.tempdir",scratchDir);
context.setResourceBase(baseDir.toURI().toASCIIString());
// Add servlet to present html for found videos
ServletHolder holderIndexer = new ServletHolder(new IndexerServlet());
context.addServlet(holderIndexer,"/indexer");
// Make sure that our welcome-file is the indexer servlet
context.setWelcomeFiles(new String[]{ "indexer" });
// Allow static file serving of videos themselves, via DefaultServlet
// Add Default Servlet (must be named "default")
ServletHolder holderDefault = new ServletHolder("default",DefaultServlet.class);
holderDefault.setInitParameter("resourceBase",baseDir.getAbsolutePath());
holderDefault.setInitParameter("dirAllowed","true");
holderDefault.setInitParameter("welcomeServlets","true");
holderDefault.setInitParameter("redirectWelcome","true");
context.addServlet(holderDefault,"/");
server.setHandler(context);
server.start();
server.join();
}
}
您似乎有2个问题。
ResourceHandler
是需求,关于它的浏览器整合太简单了。浏览器似乎会执行很多部分请求,长时间请求以及在需要时进行恢复。此类请求最好与DefaultServlet
用于视频标记的HTML无法正常工作,但是当我将其更改为以下代码时,它可以正常工作。
chrome似乎又高兴了。
我在读维基百科上的Favicon页面。他们提到了Favicon的HTML5规范: 当前的HTML5规范建议使用标记中的属性rel=“icon”sizes=“图标尺寸的空格分隔列表”指定多个尺寸的尺寸图标。[源]通过在标签中包含type=“file content-type”形式的图标内容类型,可以提供多种图标格式,包括诸如Microsoft.ico和Macintosh.icns文件等容器格式,以及
主要内容:HTML5 浏览器支持,将 HTML5 元素定义为块元素,实例,为 HTML 添加新元素,实例,Internet Explorer 浏览器问题,完美的 Shiv 解决方案,实例你可以让一些较早的浏览器(不支持HTML5)支持 HTML5。 HTML5 浏览器支持 现代的浏览器都支持 HTML5。 此外,所有浏览器,包括旧的和最新的,对无法识别的元素会作为内联元素自动处理。 正因为如此,你可以 "教会" 浏览器处理 "未知" 的 HTML 元素。 甚至你可以教会 IE6 (Windows
你可以让一些较早的浏览器(不支持HTML5)支持 HTML5。 HTML5 浏览器支持 现代的浏览器都支持 HTML5。 此外,所有浏览器,包括旧的和最新的,对无法识别的元素会作为内联元素自动处理。 正因为如此,你可以 "教会" 浏览器处理 "未知" 的 HTML 元素。 甚至你可以教会 IE6 (Windows XP 2001) 浏览器处理未知的 HTML 元素。 将 HTML5 元素定义为块元
我正在尝试使用JSoup获取此URL http://betatruebaonline.com/img/parte/330/ciguen%c3%91al.jpg 相反,正确的 http://betatruebaonline.com/img/parte/330/ciguen%cc%83al.jpg 我该怎么解决这个?多谢了。
本文向大家介绍HTML5如何调用摄像头?相关面试题,主要包含被问及HTML5如何调用摄像头?时的应答技巧和注意事项,需要的朋友参考一下 嘿,这个我知道。 window.navigator.getUserMedia() 然后接收三个参数,第一个是视频或者音频以及分辨率{video:true} 第二个是成功回调,第三个是失败回调。 还有一种调用 window.navigator.mediaDevice
问题内容: 我正在考虑如何使Android的支持库在Eclipse之外包含和编译。我使用Linux作为构建环境,没有使用任何IDE来创建应用程序,仅使用基本的Android SDK。我仅获得了有关Eclipse的此问题的答案,但是如何仅使用Ant和Android SDK呢? 问题答案: 假设您没有使用: 步骤1:将SDK 复制或从SDK 复制到项目目录中。 步骤2:没有步骤2。 选择是否要使用本机