Untuk Aplikasi Java:
Sebenarnya untuk kasus JDownloader, Ini desain modular. Ikon baki datang sebagai plugin yang dapat dinonaktifkan dari:
JDownloader → Addons → Addon Manager → Extensions → Hapus centang Aktifkan kotak untuk JD Light Tray
Untuk kasus umum aplikasi Java, Dimungkinkan untuk menggunakan manajer keamanan Java dengan menulis aturan kebijakan khusus.
Buat java.policy
file dalam ~/.jdownloader
berisi:
grant codeBase "file:/home/user/.jdownloader/-" {
// full access
// permission java.security.AllPermission;
// AWTPermission full or only selected elements from it
// permission java.awt.AWTPermission "*";
permission java.awt.AWTPermission "accessClipboard";
permission java.awt.AWTPermission "accessEventQueue";
// permission java.awt.AWTPermission "accessSystemTray";
permission java.awt.AWTPermission "createRobot";
permission java.awt.AWTPermission "fullScreenExclusive";
permission java.awt.AWTPermission "listenToAllAWTEvents";
permission java.awt.AWTPermission "readDisplayPixels";
permission java.awt.AWTPermission "replaceKeyboardFocusManager";
permission java.awt.AWTPermission "setAppletStub";
permission java.awt.AWTPermission "setWindowAlwaysOnTop";
permission java.awt.AWTPermission "showWindowWithoutWarningBanner";
permission java.awt.AWTPermission "toolkitModality";
permission java.awt.AWTPermission "watchMousePointer";
// Added by try and learn
permission java.io.FilePermission "/-", "read,write,delete";
permission java.util.PropertyPermission "*", "read,write";
permission java.util.logging.LoggingPermission "control";
permission java.lang.RuntimePermission "*";
permission java.net.NetPermission "*";
permission java.security.SecurityPermission "*";
permission javax.net.ssl.SSLPermission "*";
permission java.net.SocketPermission "*", "connect,resolve";
permission java.lang.reflect.ReflectPermission "*";
};
Ubah jdownloader
skrip peluncuran untuk menggunakan kebijakan khusus
sudo nano /usr/bin/jdownloader
Tambahkan: -Djava.security.manager -Djava.security.policy=java.policy
ke panggilan perintah java:
exec java ${JAVA_OPTIONS} -Djava.security.manager -Djava.security.policy=java.policy -jar JDownloader.jar $*
Ini adalah aturan minimum yang memungkinkan saya untuk meluncurkan jdownloader. Anda mungkin perlu menambahkan lebih banyak izin. Karena tidak ada deny
pilihan Anda harus menulis semua grant
aturan yang diperlukan .
Referensi:
BTW, cobalah mengomentari salah satu aturan dengan menambahkan //
ke awal baris; Jadi, Anda dapat melihat bagaimana kesalahan dari izin yang ditolak terlihat. Ini memberi tahu Anda izin mana yang harus Anda tambahkan. Juga perhatikan bahwa saya telah menggunakan banyak -
& *
mencoba untuk memperluas aturan karena saya mencari solusi cepat (standarnya AllPermission
sih) dan saya tidak mencari untuk memenjarakan aplikasi.
Ini adalah templat untuk memulai, mencoba memberikan semua izin yang mungkin:
grant codeBase "file:/home/user/.jdownloader/-" {
// permission java.security.AllPermission;
// permission java.awt.AWTPermission "*";
permission java.awt.AWTPermission "accessClipboard";
permission java.awt.AWTPermission "accessEventQueue";
// permission java.awt.AWTPermission "accessSystemTray";
permission java.awt.AWTPermission "createRobot";
permission java.awt.AWTPermission "fullScreenExclusive";
permission java.awt.AWTPermission "listenToAllAWTEvents";
permission java.awt.AWTPermission "readDisplayPixels";
permission java.awt.AWTPermission "replaceKeyboardFocusManager";
permission java.awt.AWTPermission "setAppletStub";
permission java.awt.AWTPermission "setWindowAlwaysOnTop";
permission java.awt.AWTPermission "showWindowWithoutWarningBanner";
permission java.awt.AWTPermission "toolkitModality";
permission java.awt.AWTPermission "watchMousePointer";
permission javax.sound.sampled.AudioPermission "*";
permission javax.security.auth.AuthPermission "*";
// permission javax.security.auth.kerberos.DelegationPermission "";
permission javax.xml.bind.JAXBPermission "*";
permission java.nio.file.LinkPermission "hard";
permission java.nio.file.LinkPermission "symbolic";
permission java.util.logging.LoggingPermission "control";
// permission java.lang.management.ManagementPermission "*";
permission javax.management.MBeanServerPermission "*";
permission javax.management.MBeanTrustPermission "*";
permission java.net.NetPermission "*";
permission java.util.PropertyPermission "*", "read,write";
permission java.lang.reflect.ReflectPermission "*";
permission java.lang.RuntimePermission "*";
permission java.security.SecurityPermission "*";
permission java.io.SerializablePermission "*";
permission java.sql.SQLPermission "*";
permission javax.net.ssl.SSLPermission "*";
permission javax.management.remote.SubjectDelegationPermission "*";
permission javax.xml.ws.WebServicePermission "*";
// permission "*";
permission java.io.FilePermission "/-", "read,write,execute,delete,readlink";
permission javax.management.MBeanPermission "*", "*";
// permission javax.security.auth.PrivateCredentialPermission "", "read";
permission javax.security.auth.kerberos.ServicePermission "*", "initiate,accept";
permission java.net.SocketPermission "*", "accept,connect,listen,resolve";
permission java.net.URLPermission "*";
};
Catatan :
Java Policy Tools adalah alat GUI untuk mengedit file kebijakan. Itu membuatnya lebih mudah untuk mengetahui semua opsi yang tersedia dari drop box. Seharusnya sudah menginstal dengan paket Java.