Проверка загрузки файла java

Файлы и директории, класс File

Класс File пакета java.io используется для управления информацией о файлах и каталогах. На уровне операционной системы файлы и каталоги имеют существенные отличия, но в Java они описываются одним классом File. Каталог в Java трактуется как обычный файл, но с дополнительным свойством — списком имен файлов, который можно просмотреть с помощью метода list.

В зависимости от назначения объект File — файл или каталог, можно использовать один из конструкторов для создания объекта:

File (String путь_к_каталогу); File (String путь_к_каталогу, String имя_файла); File (File каталог, String имя_файла);

Примеры создания объектов File

// Создание File для каталога File dir = new File("C://dir_test"); // Создание File для файлов, которые находятся в каталоге File file1 = new File("C://dir_test", "Hello1.txt"); File file2 = new File(dir, "Hello2.txt");

Свойства и методы класса File

Для определения стандартных свойств файла в классе File имеются различные методы. Однако класс File несимметричен, т.е. методы определения свойств объекта существуют, но соответствующие функции для изменения этих свойств отсутствуют.

Функции Описание
String getName() Наименование файла или каталога.
String getParent() Наименование родительского каталога.
long length() Функция определения размера файла в байтах.
String getAbsolutePath() Функция определения абсолютного пути файла или каталога.
boolean delete() Удаления файла или каталога.
boolean exists() Проверка существования файла или каталога.
boolean isDirectory() Проверка, является ли данный объект каталогом.
boolean isFile() Проверка, является ли данный объект файлом.
long lastModified() Функция определения даты последней модификации файла.
boolean canRead() Проверка, можно ли читать данные из файла.
boolean canWrite() Проверка, можно ли записывать данные в файл.
boolean isHidden() Проверка, являются ли каталог или файл скрытыми.
String[] list() Чтение массива наименований файлов и подкаталогов.
File[] listFiles() Чтение массива файлов и подкаталогов.
boolean mkdir() Создание нового каталога.
boolean renameTo(File dest) Переименовывание файла или каталога.
Читайте также:  Модуль docx для python

В следующем примере открываем файл «d:/test/MyFile.txt» (Windows) и извлекаем его характеристики:

import java.io.File; public class FileTest < public static void main(String args[]) < File fl = new File("d:\\test\\MyFile.txt"); System.out.println ("Имя файла: " + fl .getName()); System.out.println ("Путь: " + fl.getPath()); System.out.println ("Полный путь: " + fl.getAbsolutePath()); System.out.println ("Родительский каталог: " + fl.getParent()); System.out.println (fl.exists() ? "Файл существует" : "Файл не существует"); System.out.println (fl.canWrite() ? "Свойство - можно записывать" : "Свойство - нельзя записывать"); System.out.println (fl.canRead() ? "Свойство - можно читать" : "Свойство - нельзя читать"); System.out.println ("Это директория ? " + (fl.isDirectory() ? "да": " нет")); System.out.println ("Это обычный файл ? " + (fl.isFile() ? "да" : "нет")); System.out.println ("Последняя модификация файла : " + fl. lastModified()); System.out.println ("Размер файла : " + fl.length() + " bytes"); >>

В консоли будет отпечатана следующая информация:

Имя файла: MyFile.txt Путь: d:\test\MyFile.txt Полный путь: d:\test\MyFile.txt Родительский каталог: d:\test Файл существует Свойство - можно записывать Свойство - можно читать Это директория ? нет Это обычный файл ? да Последняя модификация файла : 1441710053162 Размер файла : 12 bytes

Интерфейс FileFilter

Класс File включает метод, позволяющий прочитать список только определенных файлов.

public File[] listFiles(FileFilter filter)

В отличие от одноименного метода, но без параметра, данный метод отбирает только те файлы каталога, которые удовлетворяют определенному условию. Параметр filter предназначен для задания этого условия. При этом тип параметра FileFilter — это не класс, а интерфейс, который имеет всего один метод, возвращающий true, если файл удовлетворяет определенным условиям, и false в противном случае.

public boolean accept(File pathname)

Метод listFiles будет вызывать метод accept для каждого файла в каталоге, и те, для которых accept вернет true, будут включены в результирующий список. Остальные будут проигнорированы.

Для использования FileFilter необходимо создать объект и определить в нем соответствующий метод accept.

class Filter implements FileFilter < String[] ext; Filter(String ext) < this.ext = ext.split(","); >private String getExtension(File pathname) < String filename = pathname.getPath(); int i = filename.lastIndexOf('.'); if ((i >0) && (i < filename.length()-1)) < return filename.substring(i+1).toLowerCase(); >return ""; > public boolean accept(File pathname) < if (!pathname.isFile()) return false; String extension = getExtension(pathname); for (String e : ext) < if (e.equalsIgnoreCase(extension)) return true; >return false; > >

Пример использования фильтра FileFilter

import java.io.File; import java.io.FileFilter; public class FileTest < public static void main(String args[]) < // Определение директории File dir = new File("."); // Чтение полного списка файлов каталога File[] lst1 = dir.listFiles(); // Чтение списка файлов каталога // с расширениями "png" и "jpg" File[] lst2 = dir.listFiles(new Filter("png,jpg")); System.out.println ("lst1.length = " + lst1.length + ", lst2.length = " + lst2.length); >>

Чтение содержимого файла FileInputStream

Для чтения содержимого файла можно использовать класс FileInputStream, который является наследником класса InputStream и реализует все его методы. Конструктор класса FileInputStream :

FileInputStream(String fileName) throws FileNotFoundException

Если файл не может быть открыт то генерируется исключение FileNotFoundException.

Пример считывания данных из файла и вывод содержимого в консоль:

import java.io.FileInputStream; public class FilesApp < public static void main(String[] args) < try < FileInputStream fis; fis=new FileInputStream("C:\\test_dir\\test.txt"); System.out.println("Размер файла: " + fis.available() + " байт(а)"); int i = -1; while(( i = fis.read()) != -1)< System.out.print((char)i); >fis.close(); > catch(IOException e) < System.out.println(e.getMessage()); >> >

Данные файла можно считать в массив байтов :

byte[] buffer = new byte[fis.available()]; // чтение файла в буфер fis.read (buffer, 0, fis.available()); System.out.println («Содержимое файла:»); for(int i = 0; i

Класс FileInputStream предназначен прежде всего для работы с двоичными файлами. Его можно использовать для работы с текстовыми файлами, но все же для этой задачи больше подходят другие классы.

Пример использования FileInputStream для чтения файла свойств в кодировке UTF-8:

Файл свойств «data.properties» в кодировке UTF-8:

# # Параметры сервера SMTP # company=Рога и копыта manager=Остап Бендер
import java.io.Reader; import java.io.IOException; import java.io.InputStream; import java.io.FileInputStream; import java.io.InputStreamReader; import java.util.Properties; public class Main < public static void main(String[] args) < try < InputStream is; is = new FileInputStream("data.properties"); if (is != null) < Reader reader; reader = new InputStreamReader(is, "UTF-8"); Properties props = new Properties(); props.load(reader); System.out.println ( props.getProperty ("company") + ", " props.getProperty ("manager")); is.close(); >> catch (IOException e) < e.printStackTrace(); >> >

Запись в файл FileOutputStream

Класс FileOutputStream, является производным от класса OutputStream, поэтому наследует всю его функциональность.

Пример записи строки в файл:

import java.io.FileOutputStream; public class FilesApp < public static void main(String[] args) < String text = "Hello world!"; // строка для записи try < FileOutputStream fos; fos=new FileOutputStream("C:\\test_dir\\test.txt"); // перевод строки в байты byte[] buffer = text.getBytes(); fos.write(buffer, 0, buffer.length); >catch(IOException e) < System.out.println(e.getMessage()); >> >

Для создания объекта FileOutputStream используется конструктор, принимающий в качестве параметра путь к файлу для записи. Для записи строки ее сначала переводим в массив байт и с помощью метода write строка записывается в файл. Необязательно записывать весь массив байтов. Используя перегрузку метода write(), можно записать и одиночный байт:

fos.write(buffer[0]); // запись только первого байта

Пример перезаписи содержимого из одного файла в другой:

import java.io.FileInputStream; import java.io.FileOutputStream; public class FilesApp < public static void main(String[] args) < try < FileInputStream fis; FileOutputStream fos; fis=new FileInputStream("C:\\test_dir\\test.txt"); fos=new FileOutputStream("C:\\test_dir\\new.txt"); byte[] buffer = new byte[fis.available()]; // считываем буфер fis.read(buffer, 0, buffer.length); // записываем из буфера в файл fos.write(buffer, 0, buffer.length); fis.close(); fos.close(); >catch(IOException e) < System.out.println(e.getMessage()); >> >

Класс FileOutputStream предназначен прежде всего для записи двоичных файлов. Его можно использовать для работы с текстовыми файлами, но все же для этой задачи больше подходят другие классы.

Источник

Проверить, существует ли файл в Java

В этом посте будет обсуждаться, как проверить, существует ли файл в Java.

При проверке существования файла возможны три результата:

  • Файл существует.
  • Файл не существует.
  • Статус файла неизвестен, так как у программы нет доступа к файлу.

Есть несколько способов проверить существование файла в Java. Каждое из следующих решений возвращает true, если файл существует; false в противном случае, когда файл не существует или его статус неизвестен.

1. Использование File.exists() метод

Идея состоит в том, чтобы использовать File.exists() метод, чтобы определить, существует ли файл, обозначенный указанным путем. Этот метод возвращает true, если файл существует; ложно в противном случае.

Обратите внимание, что File.exists() возвращает true, когда ваш путь указывает на каталог. Поэтому рекомендуется вызывать этот метод вместе с File.isDirectory() метод, который проверяет каталог. Это показано ниже:

Обратите внимание, что при работе с томами, смонтированными по NFS, java.io.File.exists иногда возвращается ЛОЖЬ хотя указанный файл действительно существует. См. сведения об ошибке здесь.

2. Использование File.isFile() метод

Мы видели это File.exists() возвращает true, если ваш путь указывает на каталог. Чтобы явно избежать проверки каталога, рекомендуется использовать File.isFile() метод вместо File.exists() метод. File.isFile() метод проверяет, является ли файл, обозначенный указанным путем, обычным файлом, т. е. файл не является каталогом.

3. Использование NIO

Начиная с Java 7, мы можем использовать java.nio.file.Files , который предоставляет несколько статических методов для работы с файлами, каталогами или другими типами файлов. Чтобы просто проверить существование файла, мы можем использовать exists() а также notExists() метод java.nio.file.Files учебный класс. exists() метод возвращает true, если файл существует, тогда как метод notExists() метод возвращает true, если он не существует. Если оба exists() а также notExists() вернуть false, существование файла невозможно проверить. Это может произойти, когда программа не имеет доступа к файлу.

Обратите внимание, что Files.exists() возвращает true, когда ваш путь указывает на каталог. Поэтому рекомендуется использовать этот метод вместе с Files.isDirectory() метод, который проверяет файл на наличие каталога. Это показано ниже:

Источник

Рекомендации по проверке загрузки файлов Java

Как лучше всего проводить эту проверку?
Насколько мне известно, проверка размера и типа может выполняться только на стороне сервера.
Т.е. сервлет (MyUploadServlet расширяет HttpServlet) выполняет фактическую загрузку файла.
Это единственное место? Как будет лучше всего проводить такие проверки?

Кроме того, если я смогу получить код проверки (тип и размер файла изображения), это будет здорово 🙂

2 ответы

Проверка может быть лучше выполнена на стороне сервера. В основном я бы рекомендовал вам 2 шага для проверки размера:

1) Проверить заголовки HTTP на длину содержимого. request.getContentLength ()

2) Если заголовки недоступны, выполните проверку фактического размера при чтении входного потока. Поэтому, если вы достигнете предела, вы можете сгенерировать исключение.

На стороне клиента gwt вы можете проверить исключение и показать соответствующую ошибку.

Определить тип файла может быть не так просто. Вы можете просто проверить расширение имени файла или использовать проверки для конкретного типа файла после того, как файл фактически загружен на сервер.

ответ дан 15 мар ’12, в 10:03

Спасибо, Алексей. Что меня больше интересовало в лучших практиках (с точки зрения организации кода), которым мы должны следовать, чтобы выполнять такую ​​проверку, например, должен быть другой класс валидатора? или это может быть в том же сервлете? откуда должны поступать значения проверки — из файла Spring или где-то еще? Надеюсь, на этот раз я смогу объяснить 🙂 — user1270392

Если вы используете Spring, вы можете использовать Spring mvc для обработки загрузки. В весенней конфигурации вы должны определить MultipartResolver: Таким образом, Spring framework позаботится о валидации. — Алексей А.

Спасибо, Алексей, это будет полезно. Попробую это. Еще раз спасибо! — user1270392

Источник

Оцените статью