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


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

    <body background="image/bk_hero.jpg">
    <div id="upld" style="height:300px;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="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="50px;text-align: center">序号</td>
    <td style="100px;text-align: center">视频内容</td>
    <td style="text-align: center">视频</td>
    <td style="text-align: center">课程代号</td>
    <td style="100px;text-align: center">课程名称</td>
    </tr>


    <c:forEach items="${list_displayVideo}" var="video" varStatus="i">
    <tr style="background: #FAEBD7">
    <td style="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="100px;text-align: center">${video.c_id}</td>
    <td style="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);
    }
    }

  • 相关阅读:
    markdown文件的基本常用编写语法
    ajax练习习题一弹窗查看
    jQuery练习二球队移动
    jQuery Ajax
    jQuery练习一好友列表变色
    jq
    jQuery基础知识
    php pod
    php常用代码(一)
    php多维数组化一维数组
  • 原文地址:https://www.cnblogs.com/97chen629/p/10667571.html
Copyright © 2020-2023  润新知