h5上传视频到服务端,存到指定位置,url保存到数据库,最后以特定格式显示

一、视频上传到服务器,存到指定位置。

试过n个方法中,最最靠谱的一个:

http://www.cnblogs.com/xdp-gacl/p/4200090.html

二、url保存到数据库

1、项目中新建一个jdbc包

新建类

package jdbc;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.Properties;

public class JdbcUtil {
	private static String driver;
	private static String url;
	private static String user;
	private static String password;
	private static Properties pr=new Properties();
	public JdbcUtil(){}
		static {
			try {
				pr.load(JdbcUtil.class.getClassLoader().getResourceAsStream("dbconfig.properties"));
				driver=pr.getProperty("driver");
				url=pr.getProperty("dburl");
				user=pr.getProperty("user");
				password=pr.getProperty("password");
				Class.forName(driver);

			} catch (Exception e) {
				e.printStackTrace();
			}

		}
		public static Connection getConnection() throws SQLException{
			return DriverManager.getConnection(url,user,password);

		}
		public static void free(ResultSet rs,PreparedStatement st,Connection conn){
			try {
				if(rs!=null) rs.close();
			} catch (SQLException e) {
				e.printStackTrace();
			}
			finally{
				try {
					if(st!=null) st.close();
				} catch (SQLException e2) {
					e2.printStackTrace();
				}
				finally{
					try {
						if(conn!=null) conn.close();
					} catch (SQLException e3) {
						e3.printStackTrace();
					}

				}

			}

		}

		public boolean Write(String s) throws SQLException{
			int n=0;
			Connection conn=getConnection();
			PreparedStatement ps=null;
			try {
				ps=conn.prepareStatement(s);
				n=ps.executeUpdate();
				if(n!=0) return true;
			} catch (Exception e) {
				e.printStackTrace();
			}
			finally{
				free(null, ps, conn);

			}
			return false;
		}

	}

  2、src下新建一个

dbconfig.properties
driver=com.mysql.jdbc.Driver
dburl=jdbc\:mysql\://localhost\:3306/app?useUnicode=true&characterEncoding=UTF-8
user=root
password=123456

  3、新建一个包bean(实体类) 你要存入的可能不只是一个url吧,和一般的实体类一样,getter setter 有参无参的构造函数。

  4、新建一个dao包

新建类

package dao;

import java.sql.SQLException;

import bean.Resourse;

public interface ResourseDao {
	public boolean insert(Resourse r)throws SQLException; 

}

  5、daoImpl包

新建类

package daoImpl;

import java.sql.SQLException;

import bean.Resourse;
import dao.ResourseDao;
import jdbc.JdbcUtil;

public class ResourseDaoImpl implements ResourseDao {
	private JdbcUtil ju;

	public ResourseDaoImpl() {
		ju=new JdbcUtil();
	}

	@Override
	public boolean insert(Resourse r) throws SQLException {
		String sql="insert into resourse values(0,‘"+r.getWord()+"‘,‘"+r.getResourse_path()+"‘,"+r.getIsused()+","+r.getQid()+",‘"+r.getUphone()+"‘)";
		return ju.Write(sql);
	}

}

  6、在步骤一 大神写的servlet里加几句

package servlet;

import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.net.URLEncoder;
import java.util.List;

import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import org.apache.commons.fileupload.FileItem;
import org.apache.commons.fileupload.disk.DiskFileItemFactory;
import org.apache.commons.fileupload.servlet.ServletFileUpload;

import bean.Resourse;
import dao.ResourseDao;
import daoImpl.ResourseDaoImpl;
@WebServlet("/UploadServlet")
public class UploadServlet extends HttpServlet {

    /**
	 *
	 */
	private static final long serialVersionUID = 1L;

	public void doGet(HttpServletRequest request, HttpServletResponse response)
            throws ServletException, IOException {
		String value="";
		ResourseDao rd=new ResourseDaoImpl();// new!
		response.setCharacterEncoding("utf-8");
                //得到上传文件的保存目录,将上传的文件存放于WEB-INF目录下,不允许外界直接访问,保证上传文件的安全
                String savePath = this.getServletContext().getRealPath("/teach/video");
                File file = new File(savePath);
                //判断上传文件的保存目录是否存在
                if (!file.exists() && !file.isDirectory()) {
                    System.out.println(savePath+"目录不存在,需要创建");
                    //创建目录
                    file.mkdir();
                }
                //消息提示
                String message = "";
                try{
                    //使用Apache文件上传组件处理文件上传步骤:
                    //1、创建一个DiskFileItemFactory工厂
                    DiskFileItemFactory factory = new DiskFileItemFactory();
                    //2、创建一个文件上传解析器
                    ServletFileUpload upload = new ServletFileUpload(factory);
                     //解决上传文件名的中文乱码
                    upload.setHeaderEncoding("UTF-8");
                    //3、判断提交上来的数据是否是上传表单的数据
                    if(!ServletFileUpload.isMultipartContent(request)){
                        //按照传统方式获取数据
                        return;
                    }
                    //4、使用ServletFileUpload解析器解析上传数据,解析结果返回的是一个List<FileItem>集合,每一个FileItem对应一个Form表单的输入项
                    List<FileItem> list = upload.parseRequest(request);
                    for(FileItem item : list){
                        //如果fileitem中封装的是普通输入项的数据
                        if(item.isFormField()){
                            String name = item.getFieldName();
                            //解决普通输入项的数据的中文乱码问题
                            value = item.getString("UTF-8");
                            //value = new String(value.getBytes("iso8859-1"),"UTF-8");
                            System.out.println(name + "=" + value);
                        }else{//如果fileitem中封装的是上传文件
                        	//得到上传的文件名称,
                        	String filenamee=item.getName();
                            String filename = "http://localhost:8080/soga/teach/video/"+item.getName();//new!
                            //添加到数据库!!!

                            filename=checkString(filename);//new!
                            System.out.println(filename);//new!
                            Resourse r=new Resourse(value,filename,0,"188*******");//这里是你自己写的实体类里的构造函数
                            System.out.println(rd.insert(r));//new!
                            if(filenamee==null || filenamee.trim().equals("")){
                                continue;
                            }
                            //注意:不同的浏览器提交的文件名是不一样的,有些浏览器提交上来的文件名是带有路径的,如:  c:\a\b\1.txt,而有些只是单纯的文件名,如:1.txt
                            //处理获取到的上传文件的文件名的路径部分,只保留文件名部分
                            filenamee = filenamee.substring(filenamee.lastIndexOf("\\")+1);
                            //获取item中的上传文件的输入流
                            InputStream in = item.getInputStream();
                            //创建一个文件输出流
                            FileOutputStream out = new FileOutputStream(savePath + "\\" + filenamee);
                            //创建一个缓冲区
                            byte buffer[] = new byte[1024];
                            //判断输入流中的数据是否已经读完的标识
                            int len = 0;
                            //循环将输入流读入到缓冲区当中,(len=in.read(buffer))>0就表示in里面还有数据
                            while((len=in.read(buffer))>0){
                                //使用FileOutputStream输出流将缓冲区的数据写入到指定的目录(savePath + "\\" + filename)当中
                                out.write(buffer, 0, len);
                            }
                            //关闭输入流
                            in.close();
                            //关闭输出流
                            out.close();
                            //删除处理文件上传时生成的临时文件
                            item.delete();
                            message = "文件上传成功!";
                        }
                    }
                }catch (Exception e) {
                    message= "文件上传失败!";
                    e.printStackTrace();

                }
                request.setAttribute("message",message);
                request.getRequestDispatcher("/message.jsp").forward(request, response);
    }

    public void doPost(HttpServletRequest request, HttpServletResponse response)
            throws ServletException, IOException {

        doGet(request, response);
    }
    public String checkString(String str){  //new!
        String returnStr = "";
        if(str.indexOf("‘") != -1){//判断字符串是否含有单引号
            returnStr = str.replace("‘", "‘‘");
            str = returnStr;
        }
        return str;
    }  
}

  

红色的是我新添加的。??怎么没有,不过我在新加的代码后注释了://new!

三、从数据库读出url,内容显示在网页上。

这里就和json有关了。完整步骤见:jsonp跨域访问servlet接口获取json数组,并且渲染数据,前后端完整

时间: 2024-10-26 01:12:31

h5上传视频到服务端,存到指定位置,url保存到数据库,最后以特定格式显示的相关文章

H5+上传注意要点及服务端代码

// 上传文件 function upload(num) { console.log("num:" + num); console.log("headImg.src.:" + headImg.src); if(num == 0 && headImg.src.indexOf('img/header.png') > -1) { plus.nativeUI.alert("请添加头像图片文件!"); return; } consol

图片上传客户端与服务端

//一万年太久,只争朝夕package uploadImg; import java.io.BufferedReader; import java.io.FileInputStream; import java.io.IOException; import java.io.InputStreamReader; import java.io.OutputStream; import java.net.Socket; import java.net.UnknownHostException; /*建

Wince 6.0适用 .NET 使用HttpRequest的Post上传文件,服务端的Web API接收Post上传上来的文件 代码

//调用的示例 private string fileName = "InStorageData.csv"; string filePath = parentPath + CommonHelper.UPLOAD + "\\" + fileName;//文件的全路径含文件名称及扩展名 string strResult = CommonHelper.SendFile(filePath, new Uri(CommonHelper.strURL + "PostFo

01 ftp上传简单示例服务端

import json import socket import struct server = socket.socket() server.bind(('127.0.0.1',8001)) server.listen() conn,addr = server.accept() #首先接收文件的描述信息的长度 struct_data_len = conn.recv(4) data_len = struct.unpack('i',struct_data_len)[0] # 通过文件信息的长度将文

视频电商网站vue+七牛JSSDK集成(3)上传视频时暂停和续传

1.准备2个图片 2.这是我们用来控制视频上传/暂停 的按钮显示图片. 在vue.js的data() 里准备好变量(切换2个按钮图片的变量) options:{ iconsrc:'/icons/pause.png', uploadpause:'/icons/pause.png', uploadstart:'/icons/start.png' }, 3.编写切换按钮的事件 在vue.js的methods 里: pauseUpload(){ if (this.options.iconsrc == t

ajax 异步上传视频带进度条并提取缩略图

最近在做一个集富媒体功能于一身的项目.需要上传视频.这里我希望做成异步上传,并且有进度条,响应有状态码,视频连接,缩略图. 1 { 2 "thumbnail": "/slsxpt//upload/thumbnail/6f05d4985598160c548e6e8f537247c8.jpg", 3 "success": true, 4 "link": "/slsxpt//upload/video/6f05d498559

上传视频时自动完成截取缩略图(二)

从上篇文章中我们知道了ffmpeg是怎么使用的.那么这篇文章给大家介绍下我是怎么通过调用ffmpeg实现在视频上传的同时自动截取图片的. 首先我们不能直接调用ffmpeg实现想要的功能是防止cmd命令执行时出现的黑窗口.所以我们可以封装一个类,然后调用里面的方法只需传递参数就可以实现功能了. 这里我写了一个VideoConverToImg类: public class VideoConverToImg { /// <summary> /// 从视频中截取img格式图片 /// </sum

关于上传视频到七牛的一些解决方案

<div class="form-group"> <label>上传视频:</label> <div class="my-upload"> <div class=""> <input type="file" id="fileupload" name="fileupload" class="" />

七牛云上传视频如何有效做到节省空间

在上传视频的时候,我们通常会保存到第三方[七牛云]平台.不过大多数程序员在系统后台上传视频后,一般都是保存到了本地,如果视频非常多或者视频容量特别大的情况下,那么我们的服务器迟早有一天会满,为了节省空间,下面教大家再上传视频时,如何以有效的节省服务器空间,一般情况下会把这些文件存到第三方,也就是需要我们下载qiniusdk,把qiniusdk放如Vendor目录下. 这里我们以课程视频为例子,实现的hmtl源代码如下:<tr> <td class="text">