Java上传图片并存入MySQL数据库涉及几个关键概念:
使用HTML和JavaScript实现文件上传功能:
<!DOCTYPE html>
<html>
<head>
<title>Upload Image</title>
</head>
<body>
<h1>Upload Image</h1>
<form action="upload" method="post" enctype="multipart/form-data">
<input type="file" name="image" accept="image/*">
<input type="submit" value="Upload">
</form>
</body>
</html>
使用Java Servlet处理文件上传并将图片路径存入数据库:
import java.io.*;
import javax.servlet.ServletException;
import javax.servlet.annotation.MultipartConfig;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.Part;
import java.sql.*;
@WebServlet("/upload")
@MultipartConfig(fileSizeThreshold = 1024 * 1024 * 2, // 2MB
maxFileSize = 1024 * 1024 * 10, // 10MB
maxRequestSize = 1024 * 1024 * 50) // 50MB
public class UploadServlet extends HttpServlet {
private static final String UPLOAD_DIRECTORY = "uploads";
private static final String DB_URL = "jdbc:mysql://localhost:3306/mydatabase";
private static final String DB_USER = "username";
private static final String DB_PASSWORD = "password";
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
String uploadPath = getServletContext().getRealPath("") + File.separator + UPLOAD_DIRECTORY;
File uploadDir = new File(uploadPath);
if (!uploadDir.exists()) uploadDir.mkdir();
Part filePart = request.getPart("image");
String fileName = getFileName(filePart);
String filePath = uploadPath + File.separator + fileName;
try (InputStream fileContent = filePart.getInputStream();
OutputStream out = new FileOutputStream(filePath)) {
byte[] buffer = new byte[1024];
int bytesRead;
while ((bytesRead = fileContent.read(buffer)) != -1) {
out.write(buffer, 0, bytesRead);
}
}
saveToDatabase(fileName, filePath);
response.getWriter().println("File " + fileName + " has uploaded successfully!");
}
private String getFileName(Part part) {
for (String content : part.getHeader("content-disposition").split(";")) {
if (content.trim().startsWith("filename")) {
return content.substring(content.indexOf('=') + 1).trim().replace("\"", "");
}
}
return null;
}
private void saveToDatabase(String fileName, String filePath) {
try (Connection conn = DriverManager.getConnection(DB_URL, DB_USER, DB_PASSWORD);
PreparedStatement ps = conn.prepareStatement("INSERT INTO images (filename, filepath) VALUES (?, ?)")) {
ps.setString(1, fileName);
ps.setString(2, filePath);
ps.executeUpdate();
} catch (SQLException e) {
e.printStackTrace();
}
}
}
创建一个简单的MySQL表来存储图片信息:
CREATE TABLE images (
id INT AUTO_INCREMENT PRIMARY KEY,
filename VARCHAR(255) NOT NULL,
filepath VARCHAR(255) NOT NULL
);
原因:可能是由于文件大小限制、文件类型不匹配或服务器配置问题。
解决方法:
web.xml
或@MultipartConfig
中的文件大小限制。accept
属性的要求。原因:可能是数据库连接问题、SQL语句错误或权限问题。
解决方法:
原因:可能是文件保存路径配置错误或文件名生成逻辑有误。
解决方法:
通过以上步骤和解决方案,你可以实现Java上传图片并存入MySQL数据库的功能。
领取专属 10元无门槛券
手把手带您无忧上云