java - 如何使用 apache poi 检查 xlsx 文件是否受密码保护

标签 java apache-poi

如何检查 xlsx 文件是否受密码保护。我们可以按如下方式检查 xls 文件

FileInputStream fin = new FileInputStream(new File("C:/Book1.xls"));
            POIFSFileSystem poifs = new POIFSFileSystem(fin);
            EncryptionInfo info = new EncryptionInfo(poifs);
            Decryptor d = Decryptor.getInstance(info);

            try {
                if (!d.verifyPassword(Decryptor.DEFAULT_PASSWORD)) {
                    throw new RuntimeException("Unable to process: document is encrypted");
                }

                InputStream dataStream = d.getDataStream(poifs);
                HSSFWorkbook wb = new HSSFWorkbook(dataStream);
                // parse dataStream

            } catch (GeneralSecurityException ex) {
                throw new RuntimeException("Unable to process encrypted document", ex);
            }

但上面的代码只适用于 xls,不适用于 xlsx。

最佳答案

首先,

public boolean isEncrypted(String path) {

    try {
        try {
            new POIFSFileSystem(new FileInputStream(path));
        } catch (IOException ex) {

        }
        System.out.println("protected");
        return true;
    } catch (OfficeXmlFileException e) {
        System.out.println("not protected");
        return false;
    }
}

然后,

if (isEncrypted(sourcepath)) {
        org.apache.poi.hssf.record.crypto.Biff8EncryptionKey.setCurrentUserPassword("1234");
        POIFSFileSystem filesystem = new POIFSFileSystem(new FileInputStream(inpFn));
        EncryptionInfo info = new EncryptionInfo(filesystem);
        Decryptor d = Decryptor.getInstance(info);

        if (!d.verifyPassword("1234")) {
            System.out.println("Not good");
        } else {
            System.out.println("Good!");
        }

        in = d.getDataStream(filesystem);
    } else {
        in = new FileInputStream(inpFn);
    }
    try {
        XSSFWorkbook wbIn = new XSSFWorkbook(in);
.
.
.

关于java - 如何使用 apache poi 检查 xlsx 文件是否受密码保护,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28604371/

相关文章:

java - 为什么父类(super class)在这个程序中首先被执行 - 尽管我没有 main 方法?

java - 如何将此方法 AsyncTask 转换为 RxAndroid

java - 为什么这个字体不改变大小?

设计excel文件的java android错误

java - 使用 Apache POI 对 .XLS Excel 文件进行密码保护

java - 如何使用 apache POI 创建包含两个 CategoryAxis 的 LineChart?

java - 如何在android中顺序播放一组图像?

c# - Android 上的 Base64 编码/解码

java - 如何从 Excel 文件中提取外部引用列表

java - 如何使用 apache poi 更改 docx 的 style.xml 中的字体大小