Comment utiliser Java pour crypter et décrypter des fichiers Excel ?
Présentation
Lors de la configuration de la protection des fichiers Excel, vous pouvez généralement choisir de crypter l'intégralité du classeur et vous devez saisir un mot de passe lors de l'ouverture du fichier ou vous pouvez crypter la feuille de calcul spécifiée, c'est-à-dire définir le contenu du tableau ; en lecture seule et la feuille de calcul ne peut pas être modifiée. En outre, vous pouvez également définir la protection de zones spécifiques de la feuille de calcul, c'est-à-dire définir la zone spécifiée pour qu'elle soit modifiable ou masquer les formules de données pour protéger la source des informations sur les données. Lorsqu'il n'est pas nécessaire de définir la protection du document, la protection par mot de passe peut être révoquée, c'est-à-dire que le document peut être déchiffré.
Exemple de plan
1. ExcelCahier d'exercices
1.1 Cahier d'exercices crypté
1.2 Cahier d'exercices déchiffré
2. 2.2 Feuille de calcul cryptée Spécifiez la plage de données
2.3 Définissez la formule de la feuille de calcul pour qu'elle soit invisible 2.4 Décryptez la feuille de calcul Excel OutilOutil :
Free Spire Téléchargez le package jar, décompressez-le et importez le fichier jar dans le dossier lib dans le programme java ou téléchargez-le ; , installez-le et importez-le via le référentiel maven.Remarque 2
: Lors de la définition de la protection des feuilles de calcul ici, plusieurs types de protection différents peuvent être pris en charge (comme indiqué ci-dessous).
Exemples de code Java
Exemple 1 Chiffrer le classeurimport com.spire.xls.*;
public class ProtectWb {
public static void main(String[] args) {
//加载测试文档
Workbook wb = new Workbook();
wb.loadFromFile("sample.xlsx");
//使用密码加密工作簿
wb.protect("123456");
//保存文档
wb.saveToFile("ProtectWorkbook.xlsx", ExcelVersion.Version2010);
wb.dispose();
}
}
Exemple 2 Décrypter le classeur
import com.spire.xls.*; public class UnprotectWb { public static void main(String[] args) { //加载文档 Workbook wb = new Workbook(); wb.setOpenPassword("123456");//源文档密码 wb.loadFromFile("ProtectWorkbook.xlsx"); //解除密码保护 wb.unProtect(); //保存文档 wb.saveToFile("UnprotectWb.xlsx"); wb.dispose(); } }
Exécutez le programme, le fichier du classeur généré ne sera plus protégé par mot de passe.
Exemple 3 Chiffrer la feuille de calcul
import com.spire.xls.*; import java.util.EnumSet; public class ProtectSheet { public static void main(String[] args) { //加载测试文档 Workbook wb = new Workbook(); wb.loadFromFile("sample.xlsx"); //获取第一个工作表 Worksheet sheet = wb.getWorksheets().get(0); //使用密码加密保护 sheet.protect("654321", EnumSet.of(SheetProtectionType.All)); //保存文档 wb.saveToFile("ProtectWorksheet.xlsx", ExcelVersion.Version2010); wb.dispose(); } }
Résultat du cryptage de la feuille de calcul :
Exemple 4 Chiffrer la feuille de calcul pour spécifier la plage de données
import com.spire.xls.*; import java.util.EnumSet; public class ProtectRange { public static void main(String[] args) { //加载测试文档 Workbook wb = new Workbook(); wb.loadFromFile("sample.xlsx"); //获取第一个工作表 Worksheet sheet = wb.getWorksheets().get(0); //密码加密工作表 sheet.protect("123654", EnumSet.of(SheetProtectionType.All)); //指定可编辑的区域 sheet.addAllowEditRange("AllowEdit",sheet.getCellRange(3,1,11,8)); //保存文档 wb.saveToFile("ProtectRange.xlsx", ExcelVersion.Version2010); wb.dispose(); } }
Spécifier le résultat du cryptage de la zone :
Exemple 5 Définir la formule de la feuille de calcul à masquerimport com.spire.xls.*; import java.util.EnumSet; public class ProtectAndHideFormula { public static void main(String[] args) { //加载文档 Workbook wb = new Workbook(); wb.loadFromFile("sample.xlsx"); //获取工作表 Worksheet sheet = wb.getWorksheets().get(0); //设置加密 sheet.protect("123", EnumSet.of(SheetProtectionType.All)); //隐藏公式 sheet.getAllocatedRange().isFormulaHidden(true); //保存文档 wb.saveToFile("HideFormula.xlsx",FileFormat.Version2010); wb.dispose(); } }

import com.spire.xls.*; public class UnprotectSheet { public static void main(String[] args) { //加载文档 Workbook wb = new Workbook(); wb.loadFromFile("ProtectWorksheet.xlsx"); //获取工作表 Worksheet sheet = wb.getWorksheets().get(0); //解除密码保护(需输入源文档密码) sheet.unprotect("654321"); //保存文档 wb.saveToFile("UnprotectSheet.xlsx",ExcelVersion.Version2010); wb.dispose(); } }

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Sujets chauds

Guide de la racine carrée en Java. Nous discutons ici du fonctionnement de Square Root en Java avec un exemple et son implémentation de code respectivement.

Guide du nombre parfait en Java. Nous discutons ici de la définition, comment vérifier le nombre parfait en Java ?, des exemples d'implémentation de code.

Guide du générateur de nombres aléatoires en Java. Nous discutons ici des fonctions en Java avec des exemples et de deux générateurs différents avec d'autres exemples.

Guide de Weka en Java. Nous discutons ici de l'introduction, de la façon d'utiliser Weka Java, du type de plate-forme et des avantages avec des exemples.

Guide du numéro Armstrong en Java. Nous discutons ici d'une introduction au numéro d'Armstrong en Java ainsi que d'une partie du code.

Guide du nombre de Smith en Java. Nous discutons ici de la définition, comment vérifier le numéro Smith en Java ? exemple avec implémentation de code.

Dans cet article, nous avons conservé les questions d'entretien Java Spring les plus posées avec leurs réponses détaillées. Pour que vous puissiez réussir l'interview.

Java 8 présente l'API Stream, fournissant un moyen puissant et expressif de traiter les collections de données. Cependant, une question courante lors de l'utilisation du flux est: comment se casser ou revenir d'une opération FOREAK? Les boucles traditionnelles permettent une interruption ou un retour précoce, mais la méthode Foreach de Stream ne prend pas directement en charge cette méthode. Cet article expliquera les raisons et explorera des méthodes alternatives pour la mise en œuvre de terminaison prématurée dans les systèmes de traitement de flux. Lire plus approfondie: Améliorations de l'API Java Stream Comprendre le flux Forach La méthode foreach est une opération terminale qui effectue une opération sur chaque élément du flux. Son intention de conception est
