新聞中心
隨著互聯(lián)網(wǎng)的快速發(fā)展和大數(shù)據(jù)時代的到來,人們對于網(wǎng)站或應(yīng)用程序的需求也不斷增加,其中對于文件上傳功能的需求也越來越大。然而,傳統(tǒng)的文件上傳只能將文件存儲到服務(wù)器的文件系統(tǒng)上,對于管理和維護都存在一定的困難。因此,將上傳的文件保存到數(shù)據(jù)庫中已成為一種較為流行的文件管理方式。本文將介紹。

創(chuàng)新互聯(lián)專業(yè)成都網(wǎng)站設(shè)計、網(wǎng)站建設(shè),集網(wǎng)站策劃、網(wǎng)站設(shè)計、網(wǎng)站制作于一體,網(wǎng)站seo、網(wǎng)站優(yōu)化、網(wǎng)站營銷、軟文發(fā)稿等專業(yè)人才根據(jù)搜索規(guī)律編程設(shè)計,讓網(wǎng)站在運行后,在搜索中有好的表現(xiàn),專業(yè)設(shè)計制作為您帶來效益的網(wǎng)站!讓網(wǎng)站建設(shè)為您創(chuàng)造效益。
一、創(chuàng)建數(shù)據(jù)庫表格
在將上傳的文件保存到數(shù)據(jù)庫中前,必須創(chuàng)建一個數(shù)據(jù)庫表格。這個表格將存儲文件的相關(guān)信息。表格的結(jié)構(gòu)如下:
CREATE TABLE `upload_file` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`file_name` varchar(200) NOT NULL,
`file_type` varchar(50) NOT NULL,
`file_size` int(11) NOT NULL,
`file_content` longblob NOT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;
以上表格中的字段:id表示文件的編號,file_name表示文件名稱,file_type表示文件類型,file_size表示文件大小,file_content則是文件內(nèi)容,這里采用longblob類型存儲。
二、編寫上傳文件頁面
在編寫上傳文件頁面時,需要使用到表格的結(jié)構(gòu)信息。為了更好地操作數(shù)據(jù)庫,我們需引入一些數(shù)據(jù)庫處理的類。
需要引用的文件包如下:
import java.io.*;
import java.sql.*;
import java.util.*;
import javax.servlet.*;
import javax.servlet.http.*;
import javax.sql.*;
import javax.naming.*;
以下是上傳文件的主要代碼:
@WebServlet(name = “UploadServlet”, urlPatterns = { “/UploadServlet” })
@MultipartConfig
public class UploadServlet extends HttpServlet {
@Override
public void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
response.setContentType(“text/html”);
PrintWriter out = response.getWriter();
String fileName = “”;
String fileType = “”;
int fileSize = 0;
InputStream fileContent = null;
Part filePart = request.getPart(“file”);
if (filePart != null) {
fileName = filePart.getSubmittedFileName();
fileType = filePart.getContentType();
fileSize = (int) filePart.getSize();
fileContent = filePart.getInputStream();
}
if (fileName.equals(“”)) {
out.println(“
Please select a file.
“);
return;
}
Connection conn = null;
PreparedStatement stmt = null;
try {
InitialContext ctx = new InitialContext();
DataSource ds = (DataSource) ctx.lookup(“java:comp/env/jdbc/MySQLDB”);
conn = ds.getConnection();
stmt = conn.prepareStatement(“INSERT INTO upload_file(file_name, file_type, file_size, file_content) VALUES (?, ?, ?, ?)”);
stmt.setString(1, fileName);
stmt.setString(2, fileType);
stmt.setInt(3, fileSize);
stmt.setBinaryStream(4, fileContent, fileSize);
stmt.execute();
out.println(“
Upload successfully.
“);
} catch (Exception e) {
out.println(“
Error: ” + e.getMessage() + “
“);
} finally {
try {
if (stmt != null) {
stmt.close();
}
if (conn != null) {
conn.close();
}
} catch (Exception e) {}
}
}
}
以上代碼中,我們首先獲取上傳的文件信息,如文件名、文件類型、文件大小和文件內(nèi)容等。接著,我們獲取數(shù)據(jù)源,從而得到數(shù)據(jù)庫連接。我們將文件的信息插入到數(shù)據(jù)庫表格中。
三、瀏覽上傳的文件
為了查看數(shù)據(jù)庫中已上傳的文件,我們需要構(gòu)建一個用來顯示上傳文件列表的頁面。這個頁面需要連接數(shù)據(jù)庫,并從數(shù)據(jù)庫中獲取文件列表信息,并顯示到頁面中。
以下是用來顯示文件列表的代碼:
@WebServlet(name = “FileListServlet”, urlPatterns = { “/FileListServlet” })
public class FileListServlet extends HttpServlet {
@Override
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
response.setContentType(“text/html”);
PrintWriter out = response.getWriter();
Connection conn = null;
Statement stmt = null;
ResultSet rs = null;
try {
InitialContext ctx = new InitialContext();
DataSource ds = (DataSource) ctx.lookup(“java:comp/env/jdbc/MySQLDB”);
conn = ds.getConnection();
stmt = conn.createStatement();
rs = stmt.executeQuery(“SELECT * FROM upload_file”);
out.println(“
“);
out.println(“
“);
out.println(“
“);
out.println(“
“);
out.println(“
“);
out.println(“
“);
while (rs.next()) {
int id = rs.getInt(“id”);
String fileName = rs.getString(“file_name”);
String fileType = rs.getString(“file_type”);
int fileSize = rs.getInt(“file_size”);
out.println(“
“);
out.println(“
“);
out.println(“
“);
out.println(“
“);
out.println(“
“);
out.println(“
“);
}
out.println(“
out.println(“
out.println(“
out.println(“
| ID | FileName | FileType | FileSize | Download |
|---|---|---|---|---|
| ” + id + “ | ” + fileName + “ | ” + fileType + “ | ” + fileSize + “ | Download |
“);
} catch (Exception e) {
out.println(“
Error: ” + e.getMessage() + “
“);
} finally {
try {
if (rs != null) {
rs.close();
}
if (stmt != null) {
stmt.close();
}
if (conn != null) {
conn.close();
}
} catch (Exception e) {}
}
}
}
以上代碼中,我們首先獲取數(shù)據(jù)源,并連接數(shù)據(jù)庫。接著,我們查詢數(shù)據(jù)庫中的文件列表信息,并將其顯示到頁面中。如果用戶想下載文件,我們可以提供一個鏈接,使用戶可以下載文件。在鏈接中,我們也會傳入文件編號,以便告訴下載程序需要下載哪個文件。
四、下載文件
為了下載數(shù)據(jù)庫中的文件,我們需要編寫一個下載文件的Servlet程序。在這個程序中,我們首先根據(jù)文件的編號從數(shù)據(jù)庫中查找文件信息,然后發(fā)回給客戶端下載。以下是下載文件的Servlet程序:
@WebServlet(name = “DownloadServlet”, urlPatterns = { “/DownloadServlet” })
public class DownloadServlet extends HttpServlet {
@Override
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
response.setContentType(“application/octet-stream”);
PrintWriter out = response.getWriter();
String fileId = request.getParameter(“id”);
if (fileId == null || fileId.equals(“”)) {
out.println(“
Wrong file ID.
“);
return;
}
Connection conn = null;
PreparedStatement stmt = null;
ResultSet rs = null;
try {
InitialContext ctx = new InitialContext();
DataSource ds = (DataSource) ctx.lookup(“java:comp/env/jdbc/MySQLDB”);
conn = ds.getConnection();
stmt = conn.prepareStatement(“SELECT * FROM upload_file WHERE id = ?”);
stmt.setInt(1, Integer.parseInt(fileId));
rs = stmt.executeQuery();
if (!rs.next()) {
out.println(“
File doesn’t exist.
“);
return;
}
String fileName = rs.getString(“file_name”);
String fileType = rs.getString(“file_type”);
InputStream fileContent = rs.getBinaryStream(“file_content”);
response.setHeader(“Content-Disposition”, “attachment;filename=” + fileName);
response.setContentType(fileType);
OutputStream outputStream = response.getOutputStream();
byte[] buffer = new byte[1024];
int bytesRead = -1;
while ((bytesRead = fileContent.read(buffer)) != -1) {
outputStream.write(buffer, 0, bytesRead);
}
} catch (Exception e) {
out.println(“
Error: ” + e.getMessage() + “
“);
} finally {
try {
if (rs != null) {
rs.close();
}
if (stmt != null) {
stmt.close();
}
if (conn != null) {
conn.close();
}
} catch (Exception e) {}
}
}
}
以上代碼中,我們從請求中獲取下載的文件編號,然后連接數(shù)據(jù)庫,查找該文件的信息,最后將文件的內(nèi)容發(fā)回給客戶端供下載。
:
本文介紹了。需要注意的是,在存儲文件到數(shù)據(jù)庫過程中,必須將文件的內(nèi)容存儲為二進制字節(jié)數(shù)組,同時需要注意數(shù)據(jù)庫表格中的每個字段的屬性定義。此外,為了方便我們將文件瀏覽和下載,我們還需要編寫相應(yīng)的頁面和程序來實現(xiàn)這些功能。
成都網(wǎng)站建設(shè)公司-創(chuàng)新互聯(lián),建站經(jīng)驗豐富以策略為先導(dǎo)10多年以來專注數(shù)字化網(wǎng)站建設(shè),提供企業(yè)網(wǎng)站建設(shè),高端網(wǎng)站設(shè)計,響應(yīng)式網(wǎng)站制作,設(shè)計師量身打造品牌風(fēng)格,熱線:028-86922220asp.net怎么上傳文件并將文件路徑保存到數(shù)據(jù)庫呢?
使用Upload控件:
string UserDirectory = “news”;//存放圖片的文件夾
string UserPath = Server.MapPath(“../UploadFiles”).ToString() + “\\” + UserDirectory + “\\” + “新聞” + “\\” + “Img” + “\\” + DateTime.Now.ToString(“yyyy”) + DateTime.Now.ToString(“MM”);//圖片存放路徑
string ImgFileName;
string FileName;
string FileType;
string UploadImgName = FileUploadImg.PostedFile.FileName; //文件在本地的原始位置
FileName = UploadImgName.Substring(UploadImgName.LastIndexOf(‘\\’) + 1).ToString();//得到文件名
FileType = UploadImgName.Substring(UploadImgName.LastIndexOf(“.”) + 1);//得到后綴名
if (StringFun.GetimgFileName.Getimg(FileUploadImg, UserPath, out ImgFileName))
{
imgDataUrl = “UploadFiles/” + UserDirectory + “/” + “新聞” + “/” + “Img” + “/” + DateTime.Now.ToString(“yyyy”) + DateTime.Now.ToString(“MM”) + “/” + ImgFileName;//數(shù)據(jù)庫存放路徑
}
上傳文件怎么保存到數(shù)據(jù)庫的介紹就聊到這里吧,感謝你花時間閱讀本站內(nèi)容,更多關(guān)于上傳文件怎么保存到數(shù)據(jù)庫,如何將上傳的文件保存到數(shù)據(jù)庫中,asp.net怎么上傳文件并將文件路徑保存到數(shù)據(jù)庫呢?的信息別忘了在本站進行查找喔。
創(chuàng)新互聯(lián)【028-86922220】值得信賴的成都網(wǎng)站建設(shè)公司。多年持續(xù)為眾多企業(yè)提供成都網(wǎng)站建設(shè),成都品牌建站設(shè)計,成都高端網(wǎng)站制作開發(fā),SEO優(yōu)化排名推廣服務(wù),全網(wǎng)營銷讓企業(yè)網(wǎng)站產(chǎn)生價值。
新聞名稱:如何將上傳的文件保存到數(shù)據(jù)庫中(上傳文件怎么保存到數(shù)據(jù)庫)
瀏覽路徑:http://www.dlmjj.cn/article/dpdocos.html


咨詢
建站咨詢
