欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

javaweb中上传视频,并且播放,用上传视频信息为例

程序员文章站 2023-11-13 09:18:28
1.上传视频信息的jsp页面uploadVideo.jsp

1.上传视频信息的jsp页面uploadvideo.jsp

<body background="image/bk_hero.jpg">
<div id="upld" style="height:300px;width:300px;margin-left: 300px;margin-top: 100px;">
<table>
<!-- form表单用了enctype="multipart/form-data"类型后,所有的值 都是以二进制进行传递的 -->
<form action="videoservlet?method=upvideo" method="post" enctype="multipart/form-data" target="middle">
<tr>
<td style="text-align:center;"colspan="2"><font size="5">上传课程</font></td>
</tr>
<tr>
<td height="40px"><div style="width:100px">视频内容:</div></td>
<td><input type="text" name="v_detail" id="v_detail"></td>
</tr>
<tr>
<td height="40px" >上传视频:</td>
<td><input type="file" name="v_video" id="v_video"></td>
</tr>

<tr>
<td height="40px">课程名称:</td>
<td>
<select name="coursename" id="coursename">
<option value="0">请你选择以下数据</option>
<c:foreach items="${list_displaycourse_name}" var ="course">
<option value="${course.c_name}">${course.c_name}</option>
</c:foreach>
</select>
</td>
</tr>

<tr>
<td height="40px">课程代号:</td>
<td>
<select name="c_id" id="c_id">
<option value="0">请你选择以下数据</option>
<c:foreach items="${list_displaycourse_name}" var ="course">
<option value="${course.c_id}">${course.c_id}</option>
</c:foreach>
</select>
</td>
</tr>
<tr>
<td><input type="reset" value="重置"></td>
<td style="padding-left:100px"><input type="submit" value="上传"></td>
</tr>
</form>
</table>
</div>
</body>

2.xyadmin.jsp里面查看已上传视频

<div style="height:100px"><a href="videoservlet?method=displayvideo"  target="middle">查看已上传视频</a></div>

3.显示视频信息页面displayvideo

<%@ page language="java" contenttype="text/html; charset=utf-8"
pageencoding="utf-8"%>
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %>
<!doctype html public "-//w3c//dtd html 4.01 transitional//en" "http://www.w3.org/tr/html4/loose.dtd">
<html>
<head>
<meta http-equiv="content-type" content="text/html; charset=utf-8">
<script src="http://lib.sinaapp.com/js/jquery/1.9.1/jquery-1.9.1.min.js"></script>
<script type="text/javascript" src="js/displayvideo.js"></script>
<title>显示视频</title>
</head>
<body>
<table border="0"cellspacing="0" cellpadding="0">
<tr>
<td style="width:50px;text-align: center">序号</td>
<td style="width:100px;text-align: center">视频内容</td>
<td style="text-align: center">视频</td>
<td style="text-align: center">课程代号</td>
<td style="width:100px;text-align: center">课程名称</td>
</tr>


<c:foreach items="${list_displayvideo}" var="video" varstatus="i">
<tr style="background: #faebd7">
<td style="width:50px;text-align: center">${i.count} </td>
<td style="text-align: center"><font style="font-size:12px;">${video.v_detail}</font></td>
<td style="text-align: center">
<div id="box">
<video id="video" controls preload="auto" width="100px" height="50px">
<source src="upload/${video.v_path}" type="video/mp4">
</video>
</div>
</td>
<td style="width:100px;text-align: center">${video.c_id}</td>
<td style="width:100px;text-align: center">${video.c_name}</td>
</tr>
</c:foreach>
</table>
</body>
</html>

播放脚本displayvideo.js

播放视频
*/
layer.open({
type: 1,
title: false,
shadeclose: true,
area: ['400px', '350px'],
content: $('#box'),
success: function(layero){
//layer样式layer-anim导致全屏样式错乱,移除该样式即可
settimeout(function() {
$(layero).removeclass('layer-anim');
}, 0);
}
});

后台videoservlet

public void upload(httpservletrequest request, httpservletresponse response) throws servletexception, ioexception {
string filename = null;
// 获得磁盘文件条目工厂
diskfileitemfactory factory = new diskfileitemfactory();
// 获取文件需要上传到的路径
string path = request.getrealpath("/upload");

// 如果没以下两行设置的话,上传大的 文件 会占用 很多内存,
// 设置暂时存放的 存储室 , 这个存储室,可以和 最终存储文件 的目录不同
/**
* 原理 它是先存到 暂时存储室,然后在真正写到 对应目录的硬盘上, 按理来说 当上传一个文件时,其实是上传了两份,第一个是以 .tem
* 格式的 然后再将其真正写到 对应目录的硬盘上
*/
factory.setrepository(new file(path));
// 设置 缓存的大小,当上传文件的容量超过该缓存时,直接放到 暂时存储室
factory.setsizethreshold(1024 * 1024);

// 高水平的api文件上传处理
servletfileupload upload = new servletfileupload(factory);
inputstream in =null;
byte[] buf=null;//字节数组表示照片
try {
// 可以上传多个文件
list<fileitem> list = (list<fileitem>) upload.parserequest(request);

for (fileitem item : list) {
// 获取表单的属性名字
string name = item.getfieldname();// title

// 如果获取的 表单信息是普通的 文本 信息
if (item.isformfield()) {
// 获取用户具体输入的字符串 ,名字起得挺好,因为表单提交过来的是 字符串类型的,表示表单的普通文本,如下拉列表,文本框,密码框等
string value = item.getstring("utf-8");// title content
request.setattribute(name, value);
}
// 对传入的非 简单的字符串进行处理 ,比如说二进制的 图片,电影这些
else {
/**
* 以下三步,主要获取 上传文件的名字,表示文本是上传控件
* 名字采用随机的方式设置的
*/
// 获取路径名
string value = item.getname();
string suffix = value.substring(value.lastindexof("."));
filename = "pro"+string.valueof(((new date()).gettime())%10000000)+suffix;
request.setattribute(name, filename);


// 真正写到磁盘上
// 它抛出的异常 用exception 捕捉

// item.write( new file(path,filename) );//第三方提供的

// 手动写的,是将我电脑里的照片写在我服务器建立的upload文件夹下下面
outputstream out = new fileoutputstream(new file(path,
filename));

in = item.getinputstream();

int length = 0;
buf = new byte[1024];//读1024个字节

system.out.println("获取上传文件的总共的容量:" + item.getsize());

// in.read(buf) 每次读到的数据存放在 buf 数组中
while ((length = in.read(buf)) != -1) {
// 在 buf 数组中 取出数据 写到 (输出流)磁盘上
out.write(buf, 0, length);

}

in.close();
out.close();
}
}

} catch (fileuploadexception e) {
e.printstacktrace();
} catch (exception e) {
e.printstacktrace();
}
string v_detail=request.getattribute("v_detail").tostring();
string coursename=request.getattribute("coursename").tostring();
int c_id=integer.parseint(request.getattribute("c_id").tostring());

video video=new video();
video.setv_detail(v_detail);
video.setc_id(c_id);
video.setv_path(filename);
boolean flag=videoservice.uploadvideo(video);
if(flag){
request.getrequestdispatcher("xyadmin.jsp").forward(request, response);
}else{
request.getrequestdispatcher("uploadvideo.jsp").forward(request, response);
}
}
/**
* @see httpservlet#dopost(httpservletrequest request, httpservletresponse response)
*/
protected void dopost(httpservletrequest request, httpservletresponse response) throws servletexception, ioexception {
string method=request.getparameter("method");
if("upvideo".equals(method)){
upload(request,response);
}else if("displayvideo".equals(method)){
list<videolink> listvideo=videoservice.displayvideo();
request.setattribute("list_displayvideo", listvideo);
request.getrequestdispatcher("displayvideo.jsp").forward(request, response);
}
}