日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關咨詢
選擇下列產品馬上在線溝通
服務時間:8:30-17:00
你可能遇到了下面的問題
關閉右側工具欄

新聞中心

這里有您想知道的互聯網營銷解決方案
如何將上傳的文件保存到數據庫中(上傳文件怎么保存到數據庫)

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

創(chuàng)新互聯專業(yè)成都網站設計、網站建設,集網站策劃、網站設計、網站制作于一體,網站seo、網站優(yōu)化、網站營銷、軟文發(fā)稿等專業(yè)人才根據搜索規(guī)律編程設計,讓網站在運行后,在搜索中有好的表現,專業(yè)設計制作為您帶來效益的網站!讓網站建設為您創(chuàng)造效益。

一、創(chuàng)建數據庫表格

在將上傳的文件保存到數據庫中前,必須創(chuàng)建一個數據庫表格。這個表格將存儲文件的相關信息。表格的結構如下:

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則是文件內容,這里采用longblob類型存儲。

二、編寫上傳文件頁面

在編寫上傳文件頁面時,需要使用到表格的結構信息。為了更好地操作數據庫,我們需引入一些數據庫處理的類。

需要引用的文件包如下:

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) {}

}

}

}

以上代碼中,我們首先獲取上傳的文件信息,如文件名、文件類型、文件大小和文件內容等。接著,我們獲取數據源,從而得到數據庫連接。我們將文件的信息插入到數據庫表格中。

三、瀏覽上傳的文件

為了查看數據庫中已上傳的文件,我們需要構建一個用來顯示上傳文件列表的頁面。這個頁面需要連接數據庫,并從數據庫中獲取文件列表信息,并顯示到頁面中。

以下是用來顯示文件列表的代碼:

@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) {}

}

}

}

以上代碼中,我們首先獲取數據源,并連接數據庫。接著,我們查詢數據庫中的文件列表信息,并將其顯示到頁面中。如果用戶想下載文件,我們可以提供一個鏈接,使用戶可以下載文件。在鏈接中,我們也會傳入文件編號,以便告訴下載程序需要下載哪個文件。

四、下載文件

為了下載數據庫中的文件,我們需要編寫一個下載文件的Servlet程序。在這個程序中,我們首先根據文件的編號從數據庫中查找文件信息,然后發(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) {}

}

}

}

以上代碼中,我們從請求中獲取下載的文件編號,然后連接數據庫,查找該文件的信息,最后將文件的內容發(fā)回給客戶端供下載。

本文介紹了。需要注意的是,在存儲文件到數據庫過程中,必須將文件的內容存儲為二進制字節(jié)數組,同時需要注意數據庫表格中的每個字段的屬性定義。此外,為了方便我們將文件瀏覽和下載,我們還需要編寫相應的頁面和程序來實現這些功能。

成都網站建設公司-創(chuàng)新互聯,建站經驗豐富以策略為先導10多年以來專注數字化網站建設,提供企業(yè)網站建設,高端網站設計,響應式網站制作,設計師量身打造品牌風格,熱線:028-86922220

asp.net怎么上傳文件并將文件路徑保存到數據庫呢?

使用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;//數據庫存放路徑

}

上傳文件怎么保存到數據庫的介紹就聊到這里吧,感謝你花時間閱讀本站內容,更多關于上傳文件怎么保存到數據庫,如何將上傳的文件保存到數據庫中,asp.net怎么上傳文件并將文件路徑保存到數據庫呢?的信息別忘了在本站進行查找喔。

創(chuàng)新互聯【028-86922220】值得信賴的成都網站建設公司。多年持續(xù)為眾多企業(yè)提供成都網站建設,成都品牌建站設計,成都高端網站制作開發(fā),SEO優(yōu)化排名推廣服務,全網營銷讓企業(yè)網站產生價值。


本文名稱:如何將上傳的文件保存到數據庫中(上傳文件怎么保存到數據庫)
分享網址:http://m.5511xx.com/article/dpdocos.html