当前位置:网站首页>JDBC tool class jdbcfiledateutil uploads files and date format conversion, including the latest, simplest and easiest way to upload single files and multiple files
JDBC tool class jdbcfiledateutil uploads files and date format conversion, including the latest, simplest and easiest way to upload single files and multiple files
2022-04-23 20:14:00 【Jiugui wine!!!】
This document introduces the processing method of file upload , Including current end form The coding type of the form is enctype="multipart/form-data" How to deal with ? And the old way to get the name of the uploaded file , The new method uses a function to get the name of the uploaded file . Finally, it explains the difference and code between uploading one file and uploading multiple files .
One 、 File upload considerations
Current end form The form contains the file upload , Have the following knowledge points :
1.form The data coding type in the form should be written enctype="multipart/form-data" To upload files , This encoding type will upload data in binary form .
2. The problem is coming. , When the encoding type is multipart/form-data when , Backstage through request.getParameter(NAME) Will not be able to get the value of text type .
Two 、 Realize file upload and solve the problem that the value cannot be obtained in the background
The core :servlet3.0 Of Part Interface
adopt @MultipartConfig annotation and HttpServletRequest Of Two new methods getPart() and getParts() Mutual assistance To reach the current end form Form use enctype="multipart/form-data" The function of uploading file and text data .
1. Use @MultipartConfig Annotation can not only make the back-end request.getParameter(NAME) Can get the value of text data , You can also use servlet3 Newly added part Interface , There are two new methods in this interface, which can directly obtain the file data and write it to the save path . So it's very convenient and concise .
2.HttpServletRequest Two new methods getPart() and getParts() To receive the front end form File data transmitted from the form ,getPart() Only one file can be received ,getParts() Can receive multiple files .
3、 ... and 、@MultipartConfig Annotation has four attribute values to specify some attributes of the file .
fileSizeThreshold: Integer value setting , The default value is 0, If the size of the uploaded file exceeds this value , Will first write to the cache file .
location: Save path to upload file .
maxFileSize: Limit file upload size . The default value is -1L, It means unlimited size .
maxRequestSize: Limit multipart/form-data Request format , The default value is -1L, Indicates that there is no limit on the number of .
Point four 、 The whole source code of the old method of file upload
package com.jdbc.utils;
import java.io.IOException;
import java.sql.Date;
import java.sql.SQLException;
/* The date data of the form is converted to sql Date format dataTrans(String sr0)
1、 Convert the date in string format of the form to java Date format for
2、 take java The date format of is converted to sql Date format for
Save the uploaded image to the specified storage path savaFile()
*/
import java.text.ParseException;
import java.text.SimpleDateFormat;
import javax.imageio.IIOException;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.Part;
import com.sun.org.apache.bcel.internal.generic.NEW;
public class JdbcFileDateUtil {
public static java.sql.Date dataTrans(String sr0) {
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");// Construct the object according to the string pattern specified by the parameter . Realize the relevant conversion between date type and string
java.util.Date sr1 =new java.util.Date();
try {
sr1=sdf.parse(sr0);// Is used to String Type conversion to Date type
} catch (ParseException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return new java.sql.Date((sr1.getTime()));//getTime Gets the distance of the current object 1970 year 1 month 1 Japan 0 when 0 branch 0 Milliseconds in seconds
}
// Save the file selected for form upload to the upload file path specified by the server
// It is applicable to both cases whether there are uploaded files or not
public static String savaFile(String MyFile,HttpServletRequest request) throws ServletException,SQLException, IOException {
String savaPath = "D:\\Web Back end development technology \\uploadFile";
Part part =request.getPart(MyFile);//MyFile The value is html in input Labeled name value
String header=part.getHeader("Content-Disposition");
int start=header.lastIndexOf("=");
filename=header.substring(start+1);
if (filename.length()>2) {
filename=filename.substring(filename.lastIndexOf('\\')+1);
filename=filename.substring(0,filename.length()-1);// Remove the last quotation mark ”
String temp= new SimpleDateFormat("yyyyMMddHHmmssSSSS").format(new java.util.Date().getTime());// Time stamp , Add before file name , Used to prevent duplicate file names
filename=temp+"."+filename;
part.write(savaPath+"\\"+filename);// Upload the file and write the path to save
}
return filename;
}
}
Optimize the code : Take out the file name processing process separately and modularize it into a method getFileName(Part part).
( One ) How to upload a file : Use getPart(name)
public static String savaFile(String MyFile,HttpServletRequest request) throws ServletException,SQLException, IOException {
String savaPath = "D:\\Web Back end development technology \\uploadFile";
Part part = request.getPart("MyFile");
String filename = getFileName(part);
part.write(savaPath+"\\"+filename);write() Method . You can directly write the uploaded file to disk
return filename; // To return , Used to store in the database
}
public static String getFileName(Part part) {
String header = part.getHeader("Content-Disposition");
int start=header.lastIndexOf("=");
filename=header.substring(start+1);
if (filename.length()>2) {
filename=filename.substring(filename.lastIndexOf('\\')+1);
filename=filename.substring(0,filename.length()-1);// Remove the last quotation mark ”
String temp= new SimpleDateFormat("yyyyMMddHHmmssSSSS").format(new java.util.Date().getTime());// Time stamp , Add before file name , Used to prevent duplicate file names
filename=temp+"."+filename;
return filename;
}
return filename;// If the uploaded file is empty , Then the file name is empty
}
( Two ) How to upload multiple files : Use getParts()
public static String savaFiles(String MyFile,HttpServletRequest request) throws ServletException,SQLException, IOException {
String savaPath = "D:\\Web Back end development technology \\uploadFile";
// From the front end form Get all file data in and store it in a list in
List<Part> parts = (List<Part>) request.getParts();
// Loop through the file , Each loop gets the name of a file and writes the file data to disk
// Get current part Point to the input Labeled name, Only name In order to MyFile Can enter the operation of getting file name only if it starts with the value of ,
// Or jump to the next part, there part.getName().startsWith(MyFile) The key point is to understand and combine the front-end input Of name Value understanding
// startsWith() The parameter of is the corresponding to the upload folder input Labeled name name
for(Part part : parts) {
if (part.getName().startsWith(MyFile)) {
String filename = getFileName(part);
if (filename.length()>2) {
String temp= new SimpleDateFormat("yyyyMMddHHmmssSSSS").format(new java.util.Date().getTime());
filename=temp+"."+filename;
part.write(savaPath+"\\"+filename);//write() Method . You can directly write the uploaded file to disk
}
filenames+=filename+"/";// Multiple files , The filenames Save all file names and store them in the database
}
}
return filenames; // To return , Used to store in the database
}
Focus on the multi file upload process :
chart 1 The file name and... Selected by the front end input Labeled name name , There are three name=photo Of , There is one name=pic In the middle .
chart 2 Printed in the process of background processing files head Information and file name , Only found name=photo Your file was received .
Through this case, I think Key points Yes. , Only the back-end part.getName().startsWith(MyFile) Satisfaction is input Labeled name Named part Will accept the data .
Heavy focus, little five 、 The latest method of uploading single file and multiple files
tomcat8 Use servlet3.0 Upload files , There's a way getSubmittedFileName() Get the file name directly , There's no need to intercept so much trouble .
/*
One 、 The date data of the form is converted to sql Date format dataTrans(String sr0)
1、 Convert the date in string format of the form to java Date format for
2、 take java The date format of is converted to sql Date format for
Two 、 Save the uploaded image to the specified storage path savaFile(), Here is a single file upload
*/
package com.jdbc.utils;
import java.io.IOException;
import java.sql.Date;
import java.sql.SQLException;
import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.List;
import javax.imageio.IIOException;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.Part;
import com.sun.org.apache.bcel.internal.generic.NEW;
public class JdbcFileDateUtil {
// Date format conversion tool
public static java.sql.Date dataTrans(String sr0) {
// Construct the object according to the string pattern specified by the parameter . Realize the relevant conversion between date type and string
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
java.util.Date sr1 =new java.util.Date();
try {
sr1=sdf.parse(sr0);// Is used to String Type conversion to Date type
} catch (ParseException e) {
e.printStackTrace();
}
//getTime Gets the distance of the current object 1970 year 1 month 1 Japan 0 when 0 branch 0 Milliseconds in seconds
return new java.sql.Date((sr1.getTime()));
}
// Save the file selected for form upload to the upload file path specified by the server
// It is applicable to both cases whether there are uploaded files or not , If the file is not uploaded, it will be empty .
//1. Single file upload
public static String savaFile(String MyFile,HttpServletRequest request) throws ServletException,SQLException, IOException {
String savaPath = "D:\\【1】 School professional courses \\ Junior year \\Web Back end development technology \\uploadFile";
Part part =request.getPart(MyFile);
//tomcat8 Use servlet3.0 Upload files , There's a way getSubmittedFileName Get the file name directly , There's no need to intercept so much trouble
String filename = part.getSubmittedFileName();
if (filename.length()>2) {
// Add a timestamp to the file name , Prevent duplicate files .
String temp= new SimpleDateFormat("yyyyMMddHHmmssSSSS").format(new java.util.Date().getTime());
filename=temp+"."+filename;
part.write(savaPath+"\\"+filename);//write() Method . You can directly write the uploaded file to disk
}
System.out.println(filename);
return filename;
}
//2. Upload multiple files
public static String savaFiles(String MyFile,HttpServletRequest request) throws ServletException,SQLException, IOException {
String savaPath = "D:\\【1】 School professional courses \\ Junior year \\Web Back end development technology \\uploadFile";
// From the front end form Get all file data in and store it in a list in
List<Part> parts = (List<Part>) request.getParts();
String filenames ="";
// Loop through the file , Each loop gets the name of a file and writes the file data to disk
for(Part part : parts) {
// Get current part Point to the input Labeled name, Only name In order to MyFile Can enter the operation of getting file name only if it starts with the value of ,
// Or jump to the next part, there part.getName().startsWith(MyFile) The key point is to understand and combine the front-end input Of name Value understanding
// startsWith() The parameter of is the corresponding to the upload folder input Labeled name name
if (part.getName().startsWith(MyFile)) {
String filename = part.getSubmittedFileName();// Get the current part The file name that points to
if (filename.length()>2) {
String temp= new SimpleDateFormat("yyyyMMddHHmmssSSSS").format(new java.util.Date().getTime());
filename=temp+"."+filename;
part.write(savaPath+"\\"+filename);//write() Method . You can directly write the uploaded file to disk
}
filenames+=filename+"/";// Multiple files , The filenames Save all file names and store them in the database
}
}
return filenames; // To return , Used to store in the database
}
}
版权声明
本文为[Jiugui wine!!!]所创,转载请带上原文链接,感谢
https://yzsam.com/2022/04/202204210556006860.html
边栏推荐
- Devops integration - environment variables and building tools of Jenkins service
- R language ggplot2 visual facet_wrap, and use the lineheight parameter to customize the height of the facet icon tab (gray label bar)
- MySQL数据库 - 数据库和表的基本操作(二)
- 如何做产品创新?——产品创新方法论探索一
- Fundamentals of network communication (LAN, Wan, IP address, port number, protocol, encapsulation and distribution)
- 图书管理数据库系统设计
- Azkaban recompile, solve: could not connect to SMTP host: SMTP 163.com, port: 465 [January 10, 2022]
- 记录:调用mapper报空指针;<foreach>不去重的用法;
- MySQL数据库 - 单表查询(二)
- CVPR 2022 | QueryDet:使用级联稀疏query加速高分辨率下的小目标检测
猜你喜欢
Grafana shares links with variable parameters
Project training of Software College of Shandong University - Innovation Training - network security shooting range experimental platform (V)
Mfcc: Mel frequency cepstrum coefficient calculation of perceived frequency and actual frequency conversion
Mysql database backup scheme
Software College of Shandong University Project Training - Innovation Training - network security shooting range experimental platform (8)
Openharmony open source developer growth plan, looking for new open source forces that change the world!
MySQL advanced lock - overview of MySQL locks and classification of MySQL locks: global lock (data backup), table level lock (table shared read lock, table exclusive write lock, metadata lock and inte
WordPress plug-in: WP CHINA Yes solution to slow domestic access to the official website
如何在BNB链上创建BEP-20通证
如何在BNB鏈上創建BEP-20通證
随机推荐
nc基础用法
PHP reference manual string (7.2000 words)
Distinction between pointer array and array pointer
Fundamentals of network communication (LAN, Wan, IP address, port number, protocol, encapsulation and distribution)
R语言使用econocharts包创建微观经济或宏观经济图、indifference函数可视化无差异曲线、自定义计算交叉点、自定义配置indifference函数的参数丰富可视化效果
aqs的学习
R language uses the preprocess function of caret package for data preprocessing: BoxCox transform all data columns (convert non normal distribution data columns to normal distribution data and can not
STM32基础知识
Redis distributed lock
Five minutes to show you what JWT is
Devops integration - environment variables and building tools of Jenkins service
中金财富公司怎么样,开户安全吗
Lpc1768 optimization comparison of delay time and different levels
How does onlyoffice solve no route to host
PCL点云处理之直线与平面的交点计算(五十三)
SIGIR'22 "Microsoft" CTR estimation: using context information to promote feature representation learning
山东大学软件学院项目实训-创新实训-网络安全靶场实验平台(六)
Unity创建超写实三维场景的一般步骤
R语言ggplot2可视化:ggplot2可视化散点图并使用geom_mark_ellipse函数在数据簇或数据分组的数据点周围添加椭圆进行注释
Still using listview? Use animatedlist to make list elements move