ไฟล์เป็น byte [] ใน Java


757

ฉันจะแปลง a java.io.Fileเป็น a ได้byte[]อย่างไร


การใช้งานอย่างหนึ่งที่ฉันนึกได้คือการอ่านวัตถุที่เป็นอนุกรมจากไฟล์
Mahm00d

2
อีกวิธีหนึ่งคือการค้นหาประเภทไฟล์โดยใช้ส่วนหัว
James P.

ลองใช้ไบต์นี้ [] bytes = null; BufferedInputStream fileInputStream = null; ลอง {File file = ไฟล์ใหม่ (filePath); fileInputStream = new BufferedInputStream (ใหม่ FileInputStream (ไฟล์)); // fileInputStream = Thread.currentThread (). getContextClassLoader (). getResourceAsStream (this.filePath); ไบต์ = ไบต์ใหม่ [(int) file.length ()]; fileInputStream.read (ไบต์); } catch (อดีต FileNotFoundException) {เก่า; }
Rohit Chaurasiya

คำตอบ:


486

ขึ้นอยู่กับว่าอะไรจะดีที่สุดสำหรับคุณ เพิ่มประสิทธิภาพการทำงานอย่าปรับแต่งวงล้อใหม่และใช้ Apache Commons IOUtils.toByteArray(InputStream input)ซึ่งเป็นที่นี่


29
@ymajoros: จริงจัง! ฉันต้องการมีโค้ดพิเศษบางบรรทัดมากกว่าที่ต้องพึ่งพาอีก การพึ่งพามีค่าใช้จ่ายแอบแฝง คุณต้องอยู่กับห้องสมุดที่ทันสมัยรวมถึงการพึ่งพาในการสร้างสคริปต์ของคุณ ฯลฯ สื่อสารกับคนที่ใช้รหัสของคุณ ฯลฯ หากคุณใช้ห้องสมุดที่มีรหัสมันมากกว่าการใช้ที่อื่นฉันจะพูด เขียนมันเอง
Stijn de Witt

11
วิธีนี้จะตอบคำถามว่าจะอ่านไฟล์ได้อย่างไร แต่ไม่ใช่คำถามของวิธีการแปลงออบเจ็กต์ประเภท java.IO.File เป็น byte []
Ingo

5
นี้เป็นวิธีการที่ใช้ในการอ่านFileเพื่อbyte[]? ฉันใช้ Java6 ดังนั้นฉันจึงไม่สามารถใช้วิธีการ NIO :(
PASTRY

4
@ymajoros คุณจะกรุณาแบ่งปัน "มาตรฐาน 3 บรรทัดแก้ปัญหา" ใด ๆ กับเราดังนั้นเราจึงไม่จำเป็นต้องพึ่งพาการพึ่งพานวัตกรรมใหม่ล่าสุด
matteo

3
@matteo: ใด ๆ ดูคำตอบอื่น ๆ เช่น Files.readAllBytes () ง่ายไม่มีการพึ่งพา
ymajoros

1292

จากJDK 7Files.readAllBytes(Path)คุณสามารถใช้

ตัวอย่าง:

import java.io.File;
import java.nio.file.Files;

File file;
// ...(file is initialised)...
byte[] fileContent = Files.readAllBytes(file.toPath());

10
ฉันมีวัตถุไฟล์ไม่ใช่เส้นทาง (จากคำขอโพสต์ http)
aldo.roman.nurena

81
@ aldo.roman.nurena JDK7 แนะนำวิธีการ File.toPath () ที่จะให้เส้นทางวัตถุแก่คุณ
KevinL

6
คุณสามารถรับพา ธ จากไฟล์ ลอง: File file = new File ("/ path"); Path path = Paths.get (file.getAbsolutePath ()); byte [] data = Files.readAllBytes (เส้นทาง);
gfelisberto

2
การปิดการจัดการไฟล์เป็นอย่างไรใน java.nio - กล่าวอีกนัยหนึ่งรหัสด้านบนควรปิดบางสิ่ง?
akauppi

4
@akauppi ดูลิงก์ในคำตอบ: "วิธีการทำให้แน่ใจว่าไฟล์จะถูกปิด ... "
Bernhard Barker

226

ตั้งแต่ JDK 7 - สายการบินเดียว:

byte[] array = Files.readAllBytes(Paths.get("/path/to/file"));

ไม่จำเป็นต้องพึ่งพาภายนอก


13
ตอนนี้เป็นตัวเลือกที่ดีกว่าคำตอบที่ยอมรับซึ่งต้องใช้ Apache Commons
james.garriss

1
ขอบคุณ :) ฉันต้องการสิ่งนี้เช่นกัน: String text = new String (Files.readAllBytes (ไฟล์ใหม่ ("/ พา ธ / ไปยัง / ไฟล์"). toPath ())); ซึ่งมีพื้นเพมาจากstackoverflow.com/a/26888713/1257959
cgl

5
ใน Android นั้นต้องใช้ระดับ API ต่ำสุดเป็น 26
Ashutosh Chamoli

2
คุณจะต้องเพิ่มimport java.nio.file.Files;และimport java.nio.file.Paths;ถ้าคุณยังไม่ได้
แซม

164
import java.io.RandomAccessFile;
RandomAccessFile f = new RandomAccessFile(fileName, "r");
byte[] b = new byte[(int)f.length()];
f.readFully(b);

เอกสารประกอบสำหรับ Java 8: http://docs.oracle.com/javase/8/docs/api/java/io/RandomAccessFile.html


2
คุณต้องตรวจสอบค่าส่งคืนของ f.read () บางครั้งอาจเกิดขึ้นได้ที่นี่คุณจะไม่อ่านไฟล์ทั้งหมด
bugs_

8
สถานการณ์ดังกล่าวสามารถเกิดขึ้นได้หากไฟล์มีการเปลี่ยนแปลงในขณะที่คุณกำลังอ่าน ในกรณีอื่นทั้งหมด IOException จะถูกโยนทิ้ง เพื่อแก้ไขปัญหานี้ฉันแนะนำให้เปิดไฟล์ในโหมดอ่าน - เขียน: RandomAccessFile (ชื่อไฟล์, "rw")
Dmitry Mitskevich

5
ฉันสามารถจินตนาการแหล่งข้อมูลอื่นสำหรับการอ่านเพียงบางส่วนของไฟล์ (ไฟล์อยู่ในเครือข่ายแชร์ ... ) readFully () มีสัญญาที่คุณกำลังค้นหา
คิดว่า

3
จำไว้ว่า RandomAccessFile ไม่ปลอดภัยสำหรับเธรด ดังนั้นการซิงโครไนซ์อาจจำเป็นในบางกรณี
bancer

@DmitryMitskevich มีกรณีอื่นเช่นกันในระบบไฟล์ที่อาจไม่สอดคล้องกัน เช่นการอ่าน "ไฟล์" ใน / proc / บน linux สามารถทำให้เกิดการอ่านสั้น (เช่นคุณต้องห่วงที่จะอ่านมันทั้งหมด)
เลขที่

78

โดยทั่วไปคุณต้องอ่านในหน่วยความจำ เปิดไฟล์จัดสรรอาร์เรย์และอ่านเนื้อหาจากไฟล์ลงในอาร์เรย์

วิธีที่ง่ายที่สุดคือสิ่งที่คล้ายกับสิ่งนี้:

public byte[] read(File file) throws IOException, FileTooBigException {
    if (file.length() > MAX_FILE_SIZE) {
        throw new FileTooBigException(file);
    }
    ByteArrayOutputStream ous = null;
    InputStream ios = null;
    try {
        byte[] buffer = new byte[4096];
        ous = new ByteArrayOutputStream();
        ios = new FileInputStream(file);
        int read = 0;
        while ((read = ios.read(buffer)) != -1) {
            ous.write(buffer, 0, read);
        }
    }finally {
        try {
            if (ous != null)
                ous.close();
        } catch (IOException e) {
        }

        try {
            if (ios != null)
                ios.close();
        } catch (IOException e) {
        }
    }
    return ous.toByteArray();
}

นี้มีบางส่วนที่ไม่จำเป็นของการคัดลอกเนื้อหาของแฟ้ม (ข้อมูลจริงจะถูกคัดลอกสามครั้ง: จากแฟ้มที่จะbufferจากbufferไปByteArrayOutputStreamจากByteArrayOutputStreamอาร์เรย์ที่เกิดขึ้นจริง)

คุณต้องให้แน่ใจว่าคุณอ่านในหน่วยความจำเท่านั้นไฟล์ถึงขนาดที่แน่นอน

คุณต้องปฏิบัติต่อIOExceptionฟังก์ชั่นภายนอกด้วย

อีกวิธีคือ:

public byte[] read(File file) throws IOException, FileTooBigException {
    if (file.length() > MAX_FILE_SIZE) {
        throw new FileTooBigException(file);
    }

    byte[] buffer = new byte[(int) file.length()];
    InputStream ios = null;
    try {
        ios = new FileInputStream(file);
        if (ios.read(buffer) == -1) {
            throw new IOException(
                    "EOF reached while trying to read the whole file");
        }
    } finally {
        try {
            if (ios != null)
                ios.close();
        } catch (IOException e) {
        }
    }
    return buffer;
}

สิ่งนี้ไม่มีการคัดลอกที่ไม่จำเป็น

FileTooBigExceptionเป็นข้อยกเว้นแอปพลิเคชันที่กำหนดเอง MAX_FILE_SIZEคงเป็นพารามิเตอร์ของโปรแกรมประยุกต์

สำหรับไฟล์ขนาดใหญ่คุณอาจคิดว่าอัลกอริทึมการประมวลผลแบบสตรีมหรือใช้การแมปหน่วยความจำ (ดูjava.nio)


iOS ต้องได้รับการประกาศนอกการทดลอง
Daryl Spitzer

คำสั่ง "ios.read (บัฟเฟอร์)" ในตัวอย่างที่สองจะอ่านใน 4096 ไบต์แรกของไฟล์เท่านั้น (สมมติว่าบัฟเฟอร์ 4k เดียวกันกับที่ใช้ในตัวอย่างแรก) สำหรับตัวอย่างที่สองที่ใช้งานได้ฉันคิดว่าการอ่านต้องอยู่ในวงขณะที่ตรวจสอบผลลัพธ์สำหรับ -1 (ถึงจุดสิ้นสุดไฟล์)
Stijn de Witt

ขออภัยยกเลิกคำพูดของฉันด้านบนพลาดการตั้งค่าบัฟเฟอร์ของคำสั่งจนถึงความยาวของไฟล์ ถึงกระนั้นฉันก็ชอบตัวอย่างแรก ๆ มากกว่านี้ การอ่านไฟล์ทั้งหมดในบัฟเฟอร์ในครั้งเดียวนั้นไม่สามารถปรับขนาดได้ คุณจะเสี่ยงต่อการสูญเสียความจำเมื่อไฟล์มีขนาดใหญ่
Stijn de Witt

วิธีที่ "ง่ายที่สุด" จะใช้ประโยชน์จากการลองกับทรัพยากร
Sina Madani

เจ๋ง แต่น้อยไป verbose
Sapphire_Brick

77

ดังที่มีคนกล่าวว่าApache Commons File Utilsอาจมีสิ่งที่คุณต้องการ

public static byte[] readFileToByteArray(File file) throws IOException

ตัวอย่างการใช้ ( Program.java):

import org.apache.commons.io.FileUtils;
public class Program {
    public static void main(String[] args) throws IOException {
        File file = new File(args[0]);  // assume args[0] is the path to file
        byte[] data = FileUtils.readFileToByteArray(file);
        ...
    }
}

23

คุณสามารถใช้ NIO api ได้เช่นกัน ฉันสามารถทำได้ด้วยรหัสนี้ตราบใดที่ขนาดไฟล์ทั้งหมด (เป็นไบต์) จะพอดีกับ int

File f = new File("c:\\wscp.script");
FileInputStream fin = null;
FileChannel ch = null;
try {
    fin = new FileInputStream(f);
    ch = fin.getChannel();
    int size = (int) ch.size();
    MappedByteBuffer buf = ch.map(MapMode.READ_ONLY, 0, size);
    byte[] bytes = new byte[size];
    buf.get(bytes);

} catch (IOException e) {
    // TODO Auto-generated catch block
    e.printStackTrace();
} finally {
    try {
        if (fin != null) {
            fin.close();
        }
        if (ch != null) {
            ch.close();
        }
    } catch (IOException e) {
        e.printStackTrace();
    }
}

ฉันคิดว่ามันเร็วมากตั้งแต่ใช้ MappedByteBuffer


2
ไม่จำเป็นต้องใช้การแมปหน่วยความจำอย่างแน่นอนถ้าคุณจะอ่านไฟล์เพียงครั้งเดียวและมันจะจบลงด้วยการใช้หน่วยความจำมากถึงสองเท่าเหมือนกับการใช้ FileInputStream ปกติ
James

1
น่าเสียดายที่ MappedByteBuffer ไม่ได้เปิดตัวโดยอัตโนมัติ
Tom Hawtin - tackline

2
ตัวอย่างใหม่รวมถึง printStackTrace การจัดการข้อยกเว้นที่ผิดปกติแบบคลาสสิก
James

ฉันเห็นด้วย .. มันเป็นสิ่งที่เป็นค่าเริ่มต้นที่ทำให้เกิดคราสฉันคิดว่าฉันควร rethrow ข้อยกเว้น!
Amit

ฉันเคยทำการเปรียบเทียบ nio เพื่อสร้าง byte [] จากไฟล์ นอกเหนือจากการใช้บัฟเฟอร์โดยตรงมันแน่นอนใช้หน่วยความจำสองเท่า แม้ว่าจะเร็วกว่าสำหรับไฟล์ที่มีขนาดใหญ่มาก (ประมาณสองเท่าเร็วเท่ากับบัฟเฟอร์ IO สำหรับ 200M) แต่ดูเหมือนว่าจะลดลง 5 เท่าสำหรับไฟล์รอบ 5M
Chaffers

22

หากคุณไม่มี Java 8 และเห็นด้วยกับฉันว่าการรวมไลบรารีขนาดใหญ่เพื่อหลีกเลี่ยงการเขียนโค้ดสองสามบรรทัดเป็นความคิดที่ไม่ดี:

public static byte[] readBytes(InputStream inputStream) throws IOException {
    byte[] b = new byte[1024];
    ByteArrayOutputStream os = new ByteArrayOutputStream();
    int c;
    while ((c = inputStream.read(b)) != -1) {
        os.write(b, 0, c);
    }
    return os.toByteArray();
}

ผู้โทรเป็นผู้รับผิดชอบในการปิดสตรีม


21
// Returns the contents of the file in a byte array.
    public static byte[] getBytesFromFile(File file) throws IOException {        
        // Get the size of the file
        long length = file.length();

        // You cannot create an array using a long type.
        // It needs to be an int type.
        // Before converting to an int type, check
        // to ensure that file is not larger than Integer.MAX_VALUE.
        if (length > Integer.MAX_VALUE) {
            // File is too large
            throw new IOException("File is too large!");
        }

        // Create the byte array to hold the data
        byte[] bytes = new byte[(int)length];

        // Read in the bytes
        int offset = 0;
        int numRead = 0;

        InputStream is = new FileInputStream(file);
        try {
            while (offset < bytes.length
                   && (numRead=is.read(bytes, offset, bytes.length-offset)) >= 0) {
                offset += numRead;
            }
        } finally {
            is.close();
        }

        // Ensure all the bytes have been read in
        if (offset < bytes.length) {
            throw new IOException("Could not completely read file "+file.getName());
        }
        return bytes;
    }

นอกจากนี้ให้ใส่ numRead ไว้ในลูป ประกาศตัวแปรในขอบเขตที่เล็กที่สุดที่ถูกต้องที่คุณสามารถทำได้ การวางไว้นอกวงล้อในขณะที่จำเป็นเพียงเพื่อเปิดใช้งานการทดสอบ "ในขณะที่" ที่ซับซ้อน มันจะดีกว่าที่จะทำการทดสอบสำหรับ EOF ภายในวง (และโยน EOFException ถ้ามันเกิดขึ้น)
erickson

throw new IOException("File is too large!");เราควรทำอย่างไรเมื่อไฟล์มีขนาดใหญ่เกินไป มีตัวอย่างเกี่ยวกับมันบ้างไหม?
Fer

21

วิธีง่ายๆในการทำ:

File fff = new File("/path/to/file");
FileInputStream fileInputStream = new FileInputStream(fff);

// int byteLength = fff.length(); 

// In android the result of file.length() is long
long byteLength = fff.length(); // byte count of the file-content

byte[] filecontent = new byte[(int) byteLength];
fileInputStream.read(filecontent, 0, (int) byteLength);

มีวิธีที่ง่ายกว่าเช่นหนึ่ง liners ที่ได้รับการกล่าวถึงแล้ว
Sapphire_Brick

@Sapphire_Brick เรียบง่ายขึ้นใช่ - แต่หนึ่ง liners ไม่เหมาะกับทุกสถานการณ์ เช่น Android
Behr

17

วิธีที่ง่ายที่สุดสำหรับการอ่านไบต์จากไฟล์

import java.io.*;

class ReadBytesFromFile {
    public static void main(String args[]) throws Exception {
        // getBytes from anyWhere
        // I'm getting byte array from File
        File file = null;
        FileInputStream fileStream = new FileInputStream(file = new File("ByteArrayInputStreamClass.java"));

        // Instantiate array
        byte[] arr = new byte[(int) file.length()];

        // read All bytes of File stream
        fileStream.read(arr, 0, arr.length);

        for (int X : arr) {
            System.out.print((char) X);
        }
    }
}

1
ฉันเถียงกันว่าเป็น "วิธีที่ง่ายที่สุด" :)
BlondCode

คุณอธิบายที่นี่ได้ไหม ทำไมคุณถึงโต้เถียง
มูฮัมหมัด Sadiq

3
ไม่มีอะไรพิเศษ แต่คุณพูดง่ายที่สุดและฉันเห็นวิธีแก้ปัญหาที่ง่ายกว่า -> ในความคิดของฉันมันไม่ใช่วิธีที่ง่ายที่สุด อาจเป็นเมื่อสองสามปีก่อน แต่โลกกำลังเปลี่ยนแปลง ฉันจะไม่ติดฉลากโซลูชันของตัวเองด้วยข้อความดังกล่าว ;) ถ้าคุณแค่เขียนว่า "ในความเห็นของฉันสิ่งที่ง่ายที่สุดคือ .. " หรือ "ที่ง่ายที่สุดที่ฉันพบ .. " อย่ารบกวนคุณเลยแค่คิดว่าจะสื่อสารสิ่งนี้
BlondCode

@ MuhammadSadiq: อย่านำเข้าสิ่งใดเลย.*ถือว่าเป็นการปฏิบัติที่ไม่ดี
Sapphire_Brick

13

Guava มีFiles.toByteArray ()เพื่อเสนอให้คุณ มันมีข้อดีหลายประการ:

  1. ครอบคลุมกรณีมุมที่ไฟล์รายงานความยาว 0 แต่ยังคงมีเนื้อหา
  2. มันได้รับการปรับปรุงให้ดีที่สุดคุณจะได้รับ OutOfMemoryException หากพยายามอ่านในไฟล์ขนาดใหญ่ก่อนที่จะพยายามโหลดไฟล์ (ผ่านการใช้ไฟล์อย่างชาญฉลาดความยาว ())
  3. คุณไม่จำเป็นต้องบูรณาการล้อ


11

การใช้วิธีการเดียวกันกับคำตอบของชุมชน wiki แต่สะอาดและรวบรวมออกจากกล่อง (วิธีการที่แนะนำหากคุณไม่ต้องการนำเข้า Apache Commons libs เช่นบน Android):

public static byte[] getFileBytes(File file) throws IOException {
    ByteArrayOutputStream ous = null;
    InputStream ios = null;
    try {
        byte[] buffer = new byte[4096];
        ous = new ByteArrayOutputStream();
        ios = new FileInputStream(file);
        int read = 0;
        while ((read = ios.read(buffer)) != -1)
            ous.write(buffer, 0, read);
    } finally {
        try {
            if (ous != null)
                ous.close();
        } catch (IOException e) {
            // swallow, since not that important
        }
        try {
            if (ios != null)
                ios.close();
        } catch (IOException e) {
            // swallow, since not that important
        }
    }
    return ous.toByteArray();
}


7

อ่านReadFullyอ่าน b.length ไบต์จากไฟล์นี้ไปยังอาร์เรย์ไบต์เริ่มต้นที่ตัวชี้ไฟล์ปัจจุบัน วิธีนี้อ่านซ้ำ ๆ จากไฟล์จนกว่าจะอ่านจำนวนไบต์ที่ร้องขอ เมธอดนี้บล็อกจนกว่าจะอ่านจำนวนไบต์ที่ร้องขอถูกตรวจพบจุดสิ้นสุดของสตรีมหรือมีข้อผิดพลาดเกิดขึ้น

RandomAccessFile f = new RandomAccessFile(fileName, "r");
byte[] b = new byte[(int)f.length()];
f.readFully(b);

5

หากคุณต้องการอ่านไบต์เป็นบัฟเฟอร์ไบต์ที่จัดสรรไว้ล่วงหน้าคำตอบนี้อาจช่วยได้

InputStream read(byte[])เดาแรกของคุณอาจจะใช้ อย่างไรก็ตามวิธีนี้มีข้อบกพร่องที่ทำให้ใช้งานได้ยากอย่างไม่มีเหตุผลไม่มีการรับประกันว่าอาร์เรย์จะถูกเติมเต็มจริง ๆ แม้ว่าจะไม่พบ EOF ก็ตาม

DataInputStream readFully(byte[])แต่จะดูที่ นี่คือ wrapper สำหรับอินพุตสตรีมและไม่มีปัญหาที่กล่าวถึงข้างต้น นอกจากนี้วิธีการนี้จะโยนเมื่อพบ EOF ดีกว่ามาก


4

วิธีต่อไปนี้ไม่เพียง แต่แปลง java.io.File ให้เป็นไบต์ [] ฉันยังพบว่ามันเป็นวิธีที่เร็วที่สุดในการอ่านไฟล์เมื่อทำการทดสอบวิธีการอ่านไฟล์ Java ที่ต่างกัน:

java.nio.file.Files.readAllBytes ()

import java.io.File;
import java.io.IOException;
import java.nio.file.Files;

public class ReadFile_Files_ReadAllBytes {
  public static void main(String [] pArgs) throws IOException {
    String fileName = "c:\\temp\\sample-10KB.txt";
    File file = new File(fileName);

    byte [] fileBytes = Files.readAllBytes(file.toPath());
    char singleChar;
    for(byte b : fileBytes) {
      singleChar = (char) b;
      System.out.print(singleChar);
    }
  }
}

3

ให้ฉันเพิ่มโซลูชันอื่นโดยไม่ใช้ห้องสมุดบุคคลที่สาม มันใช้รูปแบบการจัดการข้อยกเว้นที่นำเสนอโดยScott ( ลิงก์ ) อีกครั้ง และฉันย้ายส่วนที่น่าเกลียดไปเป็นข้อความที่แยกต่างหาก (ฉันจะซ่อนในบาง FileUtils class;))

public void someMethod() {
    final byte[] buffer = read(new File("test.txt"));
}

private byte[] read(final File file) {
    if (file.isDirectory())
        throw new RuntimeException("Unsupported operation, file "
                + file.getAbsolutePath() + " is a directory");
    if (file.length() > Integer.MAX_VALUE)
        throw new RuntimeException("Unsupported operation, file "
                + file.getAbsolutePath() + " is too big");

    Throwable pending = null;
    FileInputStream in = null;
    final byte buffer[] = new byte[(int) file.length()];
    try {
        in = new FileInputStream(file);
        in.read(buffer);
    } catch (Exception e) {
        pending = new RuntimeException("Exception occured on reading file "
                + file.getAbsolutePath(), e);
    } finally {
        if (in != null) {
            try {
                in.close();
            } catch (Exception e) {
                if (pending == null) {
                    pending = new RuntimeException(
                        "Exception occured on closing file" 
                             + file.getAbsolutePath(), e);
                }
            }
        }
        if (pending != null) {
            throw new RuntimeException(pending);
        }
    }
    return buffer;
}

3
public static byte[] readBytes(InputStream inputStream) throws IOException {
    byte[] buffer = new byte[32 * 1024];
    int bufferSize = 0;
    for (;;) {
        int read = inputStream.read(buffer, bufferSize, buffer.length - bufferSize);
        if (read == -1) {
            return Arrays.copyOf(buffer, bufferSize);
        }
        bufferSize += read;
        if (bufferSize == buffer.length) {
            buffer = Arrays.copyOf(buffer, bufferSize * 2);
        }
    }
}

1

อีกวิธีหนึ่งในการอ่านไบต์จากไฟล์

Reader reader = null;
    try {
        reader = new FileReader(file);
        char buf[] = new char[8192];
        int len;
        StringBuilder s = new StringBuilder();
        while ((len = reader.read(buf)) >= 0) {
            s.append(buf, 0, len);
            byte[] byteArray = s.toString().getBytes();
        }
    } catch(FileNotFoundException ex) {
    } catch(IOException e) {
    }
    finally {
        if (reader != null) {
            reader.close();
        }
    }

อย่าใช้บล็อกจับกลวง มันทำให้การดีบักอย่างหนัก
Sapphire_Brick

1
//The file that you wanna convert into byte[]
File file=new File("/storage/0CE2-EA3D/DCIM/Camera/VID_20190822_205931.mp4"); 

FileInputStream fileInputStream=new FileInputStream(file);
byte[] data=new byte[(int) file.length()];
BufferedInputStream bufferedInputStream=new BufferedInputStream(fileInputStream);
bufferedInputStream.read(data,0,data.length);

//Now the bytes of the file are contain in the "byte[] data"

1
ในขณะที่รหัสนี้อาจให้คำตอบสำหรับคำถาม แต่ก็ควรเพิ่มบริบทว่าทำไมมันถึงทำงานอย่างไร สิ่งนี้สามารถช่วยผู้ใช้ในอนาคตเรียนรู้และนำความรู้นั้นไปใช้กับรหัสของตนเอง คุณมีแนวโน้มที่จะได้รับการตอบรับเชิงบวกจากผู้ใช้ในรูปแบบของ upvotes เมื่ออธิบายรหัส
borchvm

นั่นคือส่วนสำคัญที่ฉันจะจำไว้ในการโพสต์ในอนาคต ขอบคุณสำหรับข้อมูลเชิงลึกที่เป็นประโยชน์ของคุณ
Usama Mehmood

0

ลองสิ่งนี้:

import sun.misc.IOUtils;
import java.io.IOException;

try {
    String path="";
    InputStream inputStream=new FileInputStream(path);
    byte[] data=IOUtils.readFully(inputStream,-1,false);
}
catch (IOException e) {
    System.out.println(e);
}

ที่ต้องมีการใช้งาน JRE โดยเฉพาะซึ่งจะทำลายแอปหากทำงานบน JRE อื่น
rattaman

2
ข้อผิดพลาดเล็กน้อย: เป็น IOException และไม่ใช่ IOexception แต่ต้องขอบคุณ :)
Matan Marciano

1
@MatanMarciano: bad ของฉัน
Sapphire_Brick

-7

ในJDK8

Stream<String> lines = Files.lines(path);
String data = lines.collect(Collectors.joining("\n"));
lines.close();

2
อ่านคำถามที่เพื่อนที่พูดภาษาฝรั่งเศสของฉันมันถามเกี่ยวกับการแปลงเป็น "byte []" และคำตอบของคุณไม่ได้ให้
ไกเซอร์ Keister

2
นี่ไม่ใช่ตัวเลือกระยะไกลแม้กระทั่งเพื่อตอบการแปลงเป็นไบต์ []!
Anddo
โดยการใช้ไซต์ของเรา หมายความว่าคุณได้อ่านและทำความเข้าใจนโยบายคุกกี้และนโยบายความเป็นส่วนตัวของเราแล้ว
Licensed under cc by-sa 3.0 with attribution required.