P实现数据库文件上传 (jsp基于数据库实上传)
随着互联网的飞速发展,越来越多的信息在网上进行传输和共享,如何让用户快速、方便地上传和下载文件成为了不可忽视的问题。而在网站开发中,P作为一种热门的Web开发语言,被广泛应用于网站开发和文件上传等功能实现中。
本文将介绍如何利用功能,为网站的安全性和稳定性提供保障。
一、前置条件
在实现数据库文件上传之前,需要确定以下的前置条件:
1. 数据库环境:需要有一个可用的数据库环境,可选择MySql或Oracle等。同时,需要创建一个用于存储文件信息的表。
2. 文件上传组件:需要选择一个文件上传组件,本文选取的是apache的commons-fileupload组件。
3. P环境:需要建立一个P开发环境,可以将P文件部署在Tomcat或者Jetty等服务器上。
二、实现文件上传功能
在确定了前置条件后,就可以开始实现文件上传功能了。下文将以实现一个简单的上传功能为例,详细介绍实现步骤。
1. 引入文件上传组件
在jsp文件中引入文件上传组件,如下所示:
“`
“`
2. 定义上传表单
在jsp页面中定义一个表单,包含上传文件的相关信息,如下所示:
“`
请选择要上传的文件:
文件描述:
“`
其中,enctype为上传文件的类型,需设置为”multipart/form-data”。
3. 处理文件上传
在jsp页面中实现文件上传处理的代码,如下所示:
“`
String fileUploadPath=”C:\\upload\\”; //设置上传目录
String fileName=null; //文件名
File tmpFile=null; //临时文件
DiskFileItemFactory factory=new DiskFileItemFactory(); //设置缓冲区大小和临时文件路径
factory.setSizeThreshold(1024 * 1024); //设置缓冲区大小为1M
factory.setRepository(new File(System.getProperty(“java.io.tmpdir”)));//设置临时文件保存的路径
ServletFileUpload upload=new ServletFileUpload(factory); //创建解析器
upload.setHeaderEncoding(“UTF-8”); //解决上传文件命名的中文乱码问题
if(!ServletFileUpload.isMultipartContent(request)){ //判断请求是否有文件上传
return;
}
try {
List items=upload.parseRequest(request); //解析请求
for(FileItem item:items){
if(item.isFormField()){
String name=item.getFieldName();
String value=item.getString(“UTF-8”); //设置编码
System.out.println(name+”=”+value);
}
else{ //上传文件处理
fileName=item.getName();
if(fileName==null||fileName.trim().equals(“”)){
continue;
}
fileName=fileName.substring(fileName.lastIndexOf(“\\”)+1); //去掉绝对路径
fileName=UUID.randomUUID().toString()+”_”+fileName; //生成新的文件名
tmpFile=new File(fileUploadPath+fileName); //创建临时文件
item.write(tmpFile);
System.out.println(“上传成功”+fileName+”到”+fileUploadPath);
}
}
} catch (FileUploadException e) {
e.printStackTrace();
} catch (Exception e) {
e.printStackTrace();
}
“`
上述代码中,定义了上传文件的路径、上传文件的名称、临时文件路径等相关信息,并使用DiskFileItemFactory类创建一个缓冲区,使用ServletFileUpload类解析HTTP请求中的文件流。接着,通过List items=upload.parseRequest(request)方法解析HTTP请求中的各个文件项。如果该文件项是表单数据,就获取该文件项的属性值;如果该文件项是文件数据,就获取文件名和文件大小等属性信息,生成一个临时文件,最后将文件保存到指定路径中。
4. 存储文件信息到数据库中
在上传文件成功后,需要将文件信息存储到数据库中。这里需要先在数据库中创建一个表,用于存储文件信息。同时,需要在P文件中加入相应的代码,将文件信息存储到数据库中,如下所示:
“`
String description=request.getParameter(“description”); //获取文件描述信息
String sql=”insert into file_upload(file_name,real_name,file_size,description) values(?,?,?,?)”; //定义SQL语句
try {
Class.forName(“com.mysql.jdbc.Driver”); //加载数据库驱动
Connection conn=DriverManager.getConnection(“jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=utf-8”, “root”, “123456”); //创建数据库连接
PreparedStatement pstmt=conn.prepareStatement(sql); //创建SQL语句执行器
pstmt.setString(1, fileName); //设置参数
pstmt.setString(2, tmpFile.getAbsolutePath());
pstmt.setLong(3, tmpFile.length());
pstmt.setString(4, description);
pstmt.executeUpdate(); //执行SQL语句,将文件信息存储到数据库中
} catch (ClassNotFoundException e) {
e.printStackTrace();
} catch (SQLException e) {
e.printStackTrace();
}
“`
上述代码中,通过获取用户上传文件的描述信息,将文件信息存储到数据库中,实现了文件信息的持久化存储。
三、
本文介绍了如何利用功能,通过使用apache的commons-fileupload组件实现文件上传,并将文件信息持久化存储到数据库中,为网站的安全性提供了保障。
相关问题拓展阅读:
- 用jsp+servlet+javabean上传图片到数据库中,不是存路径
用jsp+servlet+javabean上传图片到数据库中,不是存路径
%@ page language=”java”源明粗%>
显示图片
0)
response.getOutputStream().write(b,0,len);
in.close();
rs.close(); javabean上传实例package com.brainysoftware.web;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.ServletInputStream;
import java.util.Dictionary;
import java.util.Hashtable;
import java.io.PrintWriter;
import java.io.BufferedWriter;
import java.io.FileWriter;
import java.io.IOException;
public class FileUploadBean {
private String savePath, filepath, filename, contentType;
private Dictionary fields;
public String getFilename() {
return filename;
}
public String getFilepath() {
return filepath;
}
public void setSavePath(String savePath) {
this.savePath = savePath;
}
public String getContentType() {
return contentType;
}
public String getFieldValue(String fieldName) {
if (fields == null || fieldName == null)
return null;
return (String) fields.get(fieldName);
}
private void setFilename(String s) {
if (s==null)
return;
int pos = s.indexOf(“filename=\””);
if (pos != -1) {
filepath = s.substring(pos+10, s.length()-1);
// Windows浏览器发送完整的文件路径和名字
// 但Linux/Unix和Mac浏览器只发送文件名字
pos = filepath.lastIndexOf(“\\”);
if (pos != -1)
filename = filepath.substring(pos + 1);
else
filename = filepath;
}
}
private void setContentType(String s) {
if (s==null)
return;
int pos = s.indexOf(“: “);
if (pos != -1)
contentType = s.substring(pos+2, s.length());
}
public void doUpload(HttpServletRequest request) throws IOException {
ServletInputStream in = request.getInputStream();
byte line = new byte;
int i = in.readLine(line, 0, 128);
if (i 添加图片尺脊
添加图片
图像ID:
选择图像:
第三步:插入数据库(InsertImg.jsp)
第四步:显示图岩困燃片(ShowImg.jsp)
0)
response.getOutputStream().write(b,0,len);
in.close();
rs.close();
关于jsp基于数据库实上传的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。
香港服务器首选后浪云,2H2G首月10元开通。
后浪云(www.IDC.Net)提供简单好用,价格厚道的香港/美国云服务器和独立服务器。IDC+ISP+ICP资质。ARIN和APNIC会员。成熟技术团队15年行业经验。