Protéger les applications JavaSE

Vidéos de démarrage

▶️ YouTube

▶️ Bilibili

Téléchargement

Visitez https://protector4j.com/download pour télécharger la dernière version

Installation

Windows et Linux

Il n'y a pas d'étapes d'installation particulières, il suffit de télécharger l'archive et de l'extraire.

macOS

Téléchargez le fichier dmg et faites glisser Protector4J dans Applications. Le contenu réel de cet outil se trouve dans /Applications/Protector4J.app/Contents/protector4j-mac

Chiffrer les applications JavaSE avec l'outil GUI

Accédez au dossier Protector4J, exécutez p4j-ui[.exe], vous verrez l'interface utilisateur suivante.

Pour les utilisateurs macOS, double-cliquez simplement sur Protector4J.app comme une application Mac classique.

Connexion

Si vous avez déjà acheté la licence, veuillez cliquer sur le bouton de connexion dans le coin supérieur droit et saisir vos informations utilisateur. Si vous n'avez pas de licence, vous pouvez quand même essayer cet outil.

Sélectionner le type d'application

Cliquez sur le bouton « JavaSE Application » sur la page de type d'application.

Sélectionner le fichier jar/war à chiffrer

Sélectionnez les fichiers jar/war que vous souhaitez chiffrer, vous pouvez sélectionner un ou plusieurs fichiers

Options

Chiffrer uniquement les fichiers jar

Chiffre uniquement les fichiers jar, sans déployer l'ensemble du JRE. Cette option est généralement utilisée en combinaison avec la fonctionnalité KeySeed pour mettre à jour des programmes existants.

Créer un fichier exécutable

Créez un fichier exécutable pour lancer l'application, veuillez ne pas ajouter l'extension .exe.

Console masquée

Cette option n'est effective que pour les programmes GUI sous Windows et sert à masquer la fenêtre de ligne de commande pendant l'exécution du programme.

Options JVM

Définissez les options JVM, telles que -Xmx et -Xms, séparées par des espaces ou des retours à la ligne.

Sortie

Sélection de la version Java

Choisissez la version Java, avec support de Java 8, Java 11, Java 17 et Java 21

Créer un nouveau dossier

Sélectionné par défaut, la tâche de chiffrement créera un fichier nommé p4j-[task-id] dans le dossier de sortie. Le résultat est stocké dans ce dossier.

Inclure JavaFX

S'il s'agit d'une application JavaFX, veuillez sélectionner cette option

Application SWT

S'il s'agit d'une application SWT, veuillez sélectionner cette option.

KeySeed

La tâche de chiffrement demande par défaut une clé aléatoire au serveur pour le chiffrement. Les fichiers générés par différentes tâches de chiffrement ne peuvent pas être utilisés ensemble. Si un KeySeed est spécifié, le même KeySeed générera la même clé de chiffrement. Cette option peut être utilisée avec l'option précédente « Chiffrer uniquement les fichiers jar » pour mettre à jour les applications existantes. Cette option n'est valide que pour les utilisateurs licenciés.

Exécuter la tâche de chiffrement

Veuillez patienter un moment. Une fois la tâche de chiffrement terminée, vous pouvez voir le résultat de l'application chiffrée dans le dossier de sortie.

Exécuter les applications chiffrées

Il existe trois façons d'exécuter l'application chiffrée

  1. Exécuter avec le fichier exe

Si la plateforme cible est Windows, vous pouvez exécuter l'application chiffrée avec le fichier exécutable généré lors de la tâche de chiffrement.

  1. Exécuter avec un script

Si la plateforme cible est Linux ou macOS, vous trouverez un fichier script avec le nom exe-name.sh, vous pouvez exécuter l'application avec ce script.

  1. Exécuter le programme avec la commande Java traditionnelle

Vous pouvez également exécuter manuellement le programme avec vlxjre/bin/java, le format de cette commande est le même que celui de la commande java normale.

On peut voir un dossier nommé vlxjre dans le répertoire de sortie, qui est notre JRE personnalisé, et les fichiers jar chiffrés sont stockés dans le dossier vlxlib.

vlxjre/bin/java -jar vlxlib/xxx.jar
vlxjre/bin/java -cp vlxlib/xxx.jar MainClass
vlxjre/bin/java -cp "vlxlib/*" MainClass
vlxjre/bin/java -Xms512M -Xmx1024m -cp "vlxlib/*" MainClass

Java 8 ne supporte actuellement pas l'exécution via vlxjre/bin/java -jar. Veuillez utiliser vlxjre/bin/java -cp xx MainClass

Remarques

Si la plateforme cible de ce programme est macOS ou Linux, mais qu'il est compilé sous Windows, veuillez exécuter add-executable-permission.sh sur la plateforme cible pour accorder les permissions d'exécution au programme avant le premier démarrage.

Modifier les paramètres JVM du fichier exe

Windows

Si vous devez modifier les paramètres JVM du fichier exe, éditez exe-name.json et modifiez les valeurs dans le tableau JArgs.

"JArgs": [
  "-DParam1=value1",
  "-DParam2=value2"
]

Linux et macOS

Ouvrez simplement le fichier script et ajoutez ou modifiez les paramètres JVM.

Chiffrer les applications JavaSE avec l'outil CLI

Fichier de configuration

L'outil CLI nécessite de spécifier un fichier de tâche en paramètre.

Accédez au dossier protector4j/task-templates, trouvez java-task.yml, copiez-le et modifiez-le.

# Available values: 8,11,17,21
javaVersion: 17

# The jar files that need to be encrypted
jarFiles: []
# Only encrypt the jar files, do not deploy the runtime
# This option is used while upgrading an existing application
onlyEncryptJarFiles: false

## [ Executable file information ]
# The executable file name
exeFileName: ''
# Hide command line window, only valid for Windows
hideConsole: false
# The main class of this Java Application
mainClass: ''
# The splash image
splash: ''
# JVM Options
jvmOptions: []

## [ Output Options ]
# The output folder
outputFolder: ''
# Create a new and unique folder for the application, the folder name is like p4j-<taskId>
createNewFolder: true
# Whether this is a JavaFX application
includeJavaFX: false
# Whether this a swt gui application
swtApplication: false
# Fixed key seed, only avaiable for licensed user
# Jars encrypted in different tasks can be used together with same key seed
keySeed: ''
# The target platforms
# available values: [win, linux, mac] or empty for current platform
platforms: []

Exécuter la tâche de chiffrement

Accédez au dossier Protector4J et exécutez la commande suivante.

Linux ou macOS

Pour les utilisateurs macOS, vous pouvez trouver l'outil CLI dans /Applictions/Protector4J.app/Contents/protector4j-mac.

./p4j -t java -f path-of-task-file

Windows

p4j -t java -f path-of-task-file

Vous pouvez exécuter p4j --help pour afficher les paramètres détaillés.

Exécuter avec les informations de compte

./p4j -t java -f path-of-task-file -u email -p password

Voir les résultats

Une fois la tâche de chiffrement terminée, veuillez accéder au dossier de sortie pour vérifier les résultats.

Exécuter les applications chiffrées

Il existe trois façons d'exécuter l'application chiffrée

  1. Exécuter avec le fichier exe

Si la plateforme cible est Windows, vous pouvez exécuter l'application chiffrée avec le fichier exécutable généré par la tâche de chiffrement.

  1. Exécuter avec un script

Si la plateforme cible est Linux ou macOS, vous trouverez un fichier script avec le nom exe-name.sh, vous pouvez exécuter l'application avec ce script.

  1. Exécuter le programme avec la commande Java traditionnelle

Vous pouvez également exécuter manuellement le programme avec vlxjre/bin/java, le format de cette commande est le même que celui de la commande java normale.

On peut voir un dossier nommé vlxjre dans le répertoire de sortie, qui est notre JRE personnalisé, et les fichiers jar chiffrés sont stockés dans le dossier vlxlib.

vlxjre/bin/java -jar vlxlib/xxx.jar
vlxjre/bin/java -cp vlxlib/xxx.jar MainClass
vlxjre/bin/java -cp "vlxlib/*" MainClass
vlxjre/bin/java -Xms512M -Xmx1024m -cp "vlxlib/*" MainClass

Java 8 ne supporte actuellement pas l'exécution via vlxjre/bin/java -jar. Veuillez utiliser vlxjre/bin/java -cp xx MainClass

Remarques

Si la plateforme cible de ce programme est macOS ou Linux, mais qu'il est compilé sous Windows, veuillez exécuter add-executable-permission.sh sur la plateforme cible pour accorder les permissions d'exécution au programme avant le premier démarrage.