Zugriffs-Schutz für Unterverzeichnisse - policytool

Status
Nicht offen für weitere Antworten.

nols

Mitglied
Hi, ich habe da ein kleines Problem.

Ich möchte einen Container entwerfen in dem ein ControllerThread läuft der wiederum andere Klassen lädt und
ebenfalls als Threads startet und diese dann überwacht. Die Threads in dem Container dürfen miteinander kommunizieren, allerdings dürfen sie von außen nicht erreichbar sein. Die Klassen die sich in dem Container befinden, müssen also nach außen hin unsichtbar sein.

Von diesen Containern sollen mehrere in einer JVM laufen, die wiederum untereinander kommunizieren sollen.
Hat irgendwer eine Idee wie man das lösen könnte?
Kann man irgendwie den Classpath für jeden Container beschränken? So das er nur Klassen laden kann, die sich in dem Classpath befinden?

Ich habe mich schon ein wenig mit dem securityManager beschäftigt, sehe darin aber auch nicht wirklich eine Lösung.

Vielleicht ist es ja auch ganz einfach und ich sehe vor lauter Wald die Bäume nicht ;)

Für einen Vorschlag oder Kick in die richtige Richtung wäre ich sehr dankbar.

Gruß
Nols


[edit]
Hab den Titel geändert, weil sich das Problem geändert hat. Siehe unten!
 

nols

Mitglied
Keiner eine Idee?

Geht das irgendwie über java.security.CodeSource?
Das ich für bestimmte Objekte bestimmte Rechte definiere?
Kann ich da irgendwas über nen bestimmten Sicherheitskontext machen?
Irgendwie erschließt sich mir das noch nicht so ganz.

Danke für alle hoffentlich folgenden Antworten
 

AlArenal

Top Contributor
Beschreib doch mal besser das Grundproblem, weöches die Software lösen soll und nicht einen angedachten Lösungsweg. Nach dem Lesen deines ersten Post dürften die meisten hier genauso schlau sein wie vorher.
 

nols

Mitglied
Genau darin liegt ja auch noch ein Proplem,
das Grundkonzept der Software ist mir auch ncoh nicht ganz klar.
Es soll aber ein Framework werden um Anwendungen zu entwicklen

Es soll eine Abgrenzung bestimmter Klassen geben.
Einige dürfen direkt miteinander kommunizieren andere nur über den Umweg über funktionen des Containeres.
Klassen eines Containers haben einen gemeinsamen Sicherheitskontext, dürfen also z.B auf bestimmte Dateien zugreifen.
Auf Dateien anderer Container wiederum nicht.
Das ist alles ein wenig kompliziert, des wegen frage ich ja auch nach Hilfe!
Das mit der Sicherheit habe ich auch noch nicht ganz verstanden.
Kann ich zum Beispiel eine abstracte Klasse definieren, die irgendwelche Sicherheitsrichtlinien setzt?

Alle Klassen die dann diese Oberklasse ableiten, sollten doch dann den Sicherheitsrichtlinien folgen, oder?
Also wären sie ja dann in einem Sicherheitscontext, -> Container!
Nur dürfen sie aus diesem Container nicht ausbrechen können.


Gruß
Nols
 

Murray

Top Contributor
Einen Teil des Problems verstehe ich so: in einer VM sollen mehrere Container existieren, in denen jeweils ausschließlich Objekte enthalten sein können, deren Klassen über einen für jeden Container unterschiedlichen CLASSPATH geladen werden. Das könnte man evtl. dadurch lösen, dass man für jeden Container einen eigenen ClassLoader verwendet. Die Kommunikation zwischen Objekten in zwei verschiedenen Containern wird dadurch allerdings erschwert.
 

nols

Mitglied
Hallo alle miteinander.

Das Problem mit den Containern hat sich erledigt, hab die ganze Idee verworfen!

Jetzt habe ich ein neues Problem.
Ich möchte einen Zugriffschutz für Klassen in verschiedenen Verzeichnissen realisieren.
Dafür habe ich mir eine policy-Datei erstellt in der die Klasse mit der main volle Rechte hat.
Diese schreibt nun in eine Datei.
Es wird auch ein Objekt der Klasse others.appl1 erstellt. Dieses Objekt versucht jetzt die Datei zu lesen.
Und genau das soll nicht möglich sein. Da die Klasse appl1 ja in einem Unterverzeichniss und die Rechte eigentlich nicht erben sollte. Das Policy-File sieht folgendermaßen aus:
Code:
grant codeBase "file:/C:/Test/" {
  permission java.io.FilePermission "<<ALL FILES>>", "read, write";
  permission java.security.AllPermission;
};
Ich weiß, die FilePermission ist doppelt gemoppelt, wollte das aber nur mal testen.
Die Klasse appl1 liegt logischerweise in C:\test\others\.
Da ich ja als letztes Zeichen ein / in Codebase habe, sollte er die Unterverzeichnisse ja nicht mitberücksichtigen.
So habe ich das laut Api-Dokumentation verstanden.
Wäre dort ein - würde er die Verzeichnisse rekursiv durchgehen.

Wo liegt jetzt mein Problem? Habe ich irgendwo einen Denkfehler oder nimmt java als codebase immer das verzeichnis aus dem die Virtuelle Maschine gestartet wird.

starte ich die maschine mit
Code:
c:\test>java -Djava.security.manager -Djava.security.policy=myPol.policy StartupManager

dann kann das appl1 Objekt die Datei überschreiben, bzw lesen. !!!! Aber das soll ja nicht sein.

Ich hoffe ich habe mich diesmal besser ausgedrückt und ihr versteht mich.

Ach ja, verschiebe ich die Hauptklasse StartupManager ins Paket startup und starte die VM mit
Code:
c:\test>java -Djava.security.manager -Djava.security.policy=myPol.policy startup.StartupManager

ist das Verhalten gleich dem obigen.
Änder ich jedoch die Grant Anweisung in der Policy auf C:/test/startup bekomme ich eine Exception.

Ich blick da nicht ganz durch. Gibt es irgendwo eine Funktion die es mir erlaubt die CodeBase auszulesen?

Danke für eure Antworten und Hilfe

Gruß Nols
 

nols

Mitglied
Niemand eine Idee?

Kann ich irgendwie policies für verschiedene Packages definieren?
So wie ich das sehe kann ich nur auf ne Codebase policies definieren.
Ist die "codebase" immer das oberste Verzeichnis der packages?

Ich stehe vor einem echten Problem. Irgendwie muss ich sicherstellen das die packages die hinzugenommen werden können, nur bestimmte rechte haben. bzgl Dateien schreiben. etc...

Danke für eure hoffentlich folgenden Antworten.

Gruß
Nols
 

nols

Mitglied
Habs jetzt alleine geschafft. Der Zugriffsschutz auf package ebene funktioniert wohl nicht so.
Deswegen habe ich die Packages jetzt alle in Verschiedene Classpathes gelegt und gebe diesen nun beim starten an.
Dadurch ändert sich bei den Packages jeweils die codebase und man kann policys definieren.

Also Problem gelöst!
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
M Schutz vor Log4J Allgemeine Java-Themen 2
J Schutz Programm Jar Exe Allgemeine Java-Themen 7
3 Schutz von Softwarepaketen Allgemeine Java-Themen 6
hdi Schutz vor Dekompilierung? Allgemeine Java-Themen 18
B Algorithmus für Arbeit mit fehlenden Listenelementen? Allgemeine Java-Themen 1
kodela Eingabe für TextArray bedingt sperren Allgemeine Java-Themen 3
Karl_Der_Nette_Anfänger Hat wer ne Lösung für verknüpfte Postleitzahlen? (Baum/Wurzel Struktur) Allgemeine Java-Themen 11
R 11 GB File lesen ohne zu extrahieren Filedaten Bereich für Bereich adressieren dann mit Multi-Thread id die DB importieren Allgemeine Java-Themen 3
G KeyListener für JTextField Allgemeine Java-Themen 5
webracer999 Library für Textsuche (z. B. include/exclude, and/or)? Allgemeine Java-Themen 5
I Module-Info für Jar erzeugen Allgemeine Java-Themen 7
krgewb Java-Bibliothek für ONVIF Allgemeine Java-Themen 1
B Simpler Eventlistener für Tastaturtaste bauen? Allgemeine Java-Themen 13
_user_q Eingegebenen Text Zeile für Zeile ausgeben lassen Allgemeine Java-Themen 11
E Key für TOTP Algorythmus(Google Authentificator) Allgemeine Java-Themen 0
S Formel für Sonnenwinkel in ein Programm überführen Allgemeine Java-Themen 11
M pfx-Zertifikat in Tomcat für SSL-Verschlüsselung nutzen Allgemeine Java-Themen 14
R Best Practice Erfahrungswerte für eine Migration von JSF nach Angular (oder anderes JS-Framework) Allgemeine Java-Themen 1
B HeapSort für Array of Strings funktioniert nur teilweise Allgemeine Java-Themen 3
jhCDtGVjcZGcfzug Klassen Was genau passiert hier? Kann mir das jemand bitte Zeile für Zeile erklären? Allgemeine Java-Themen 1
rosima26 Bester Sortieralgorithmus für kurze Arrays Allgemeine Java-Themen 40
S Mit Methoden kann man definieren für was <T> steht. Geht das auch irgendwie für Variablen? Allgemeine Java-Themen 12
MangoTango Operatoren while-Schleife für Potenz Allgemeine Java-Themen 3
B Lottospiel, genug Reihen tippen für 3 Richtige (Spaß mit Arrays)? Allgemeine Java-Themen 46
B Mit welchen Datentypen und Strukturierung am Besten dutzende Baccaratspiele Shcritt für Schritt durchsimulieren? Allgemeine Java-Themen 26
D Klassendesign für einen Pascal Interpreter Allgemeine Java-Themen 6
I OCR Library für Belegerkennung Allgemeine Java-Themen 7
farah GetterMathod für Farbkanäle Allgemeine Java-Themen 6
B Welcher Datentyp für sehr große Zahlenbereiche? Allgemeine Java-Themen 1
S Webservices für binäre Daten? Allgemeine Java-Themen 5
G Licence-Header für InHouse entwickelten Source Allgemeine Java-Themen 8
M Schleife für einen TicTacToe Computer Allgemeine Java-Themen 5
O git ignore für Intellji braucht es die .idea Dateien? Allgemeine Java-Themen 8
F Java Script für das Vorhaben das richtige? Allgemeine Java-Themen 9
M wiviel Java muss ich für die Berufswelt können ? Allgemeine Java-Themen 5
Robertop Datumsformat für GB ab Java 16 Allgemeine Java-Themen 1
Thallius Verschiedene entities für gleichen Code…. Allgemeine Java-Themen 8
OnDemand Zentrale "Drehscheibe" für verschiedene APIs Allgemeine Java-Themen 14
S Übergabe eines Sortierkriteriums für ein Artikel Array mittels BiPredicate<Artikel, Artikel> Allgemeine Java-Themen 13
F Streams als Alternative für dieses Problem ? Allgemeine Java-Themen 15
D SHA-3 für Java-version 1.8 Allgemeine Java-Themen 1
N Validator für einen SQL-Befehl Allgemeine Java-Themen 22
Muatasem Hammud Erstellung von Testdaten für Arrays Allgemeine Java-Themen 6
B Logikfehlersuche, das perfekte Lottosystem für 3 Richtige mit Arraylists? Allgemeine Java-Themen 61
G Methoden für die Zukunft sinnvoll? Allgemeine Java-Themen 4
M API für PLZ Umkreissuche Allgemeine Java-Themen 3
1Spinne JDK 8 für Eclipse installieren Allgemeine Java-Themen 5
Tobero Meine Funktion für das beinhalten eines Punktes in einem Kreis funktioniert nicht Allgemeine Java-Themen 5
L Methoden Parser für gängige Datumsformate? Allgemeine Java-Themen 1
H Interface PluginSystem ClassNotFound exception für library Klassen Allgemeine Java-Themen 10
N relativier Pfad für sqlite-Datenbank in Gradle/IntelliJ Allgemeine Java-Themen 2
buchfrau Anagram für beliebiges Wort Allgemeine Java-Themen 2
TonioTec Api für Datenaustausch zwischen Client und Server Allgemeine Java-Themen 0
W Suche Ursache für NPE - woher kommt sie? (Hilfe beim Debugging) Allgemeine Java-Themen 19
Kirby.exe Distanz Map für die Distanztransformation erstellen Allgemeine Java-Themen 1
F PI Regler für Heizung Allgemeine Java-Themen 7
8u3631984 Generelle Log4j.xml für alle Module Allgemeine Java-Themen 5
M Wie übergebe ich den Zähler für die Anzahl Rekursionsschritte korrekt? Allgemeine Java-Themen 2
B Login für User, der im Hintergrund Schedules ausführt Allgemeine Java-Themen 16
L RegEx für Teile einer Berechnung Allgemeine Java-Themen 14
S Java-Task-Management-Tool für Windows und Mac selber programmieren Allgemeine Java-Themen 4
M Java 2D Array für ein Grid erstellen ? Allgemeine Java-Themen 2
Z Welches GUI Framework für Java ist aktuell? Allgemeine Java-Themen 16
N Convert.FromBase64 von C# für Java Allgemeine Java-Themen 11
N fixed-keyword von C# für Java Allgemeine Java-Themen 6
O Suche Scripter für alt:V Project! Allgemeine Java-Themen 0
S Interface Design von HookUp oder Callback Methoden für eigenes Framework Allgemeine Java-Themen 9
O Suche Unterstützung für ein OpenSource-Projekt (grafischer Editor) Allgemeine Java-Themen 13
Kirby.exe Software für Graphische Visualisierung Allgemeine Java-Themen 20
B OOP Auslöser für NullPointerException Allgemeine Java-Themen 3
L Generator für einen Parser implementieren Allgemeine Java-Themen 13
DonMalte Ambitioniertes Projekt für Einsteiger & Motivierte Allgemeine Java-Themen 0
Kirby.exe Movement System für Spiel Allgemeine Java-Themen 13
Kirby.exe Framework für Game Design Allgemeine Java-Themen 8
W Alternative für Threads Allgemeine Java-Themen 6
S Rückgabe einer HttpURLConnection für eine Seite einlesen bei der man eingeloggt ist..? Allgemeine Java-Themen 5
Elyt Compiler-Fehler Datei kann nicht erstellt werden. Die Syntax für den Dateinamen etc. ist falsch. Allgemeine Java-Themen 2
Thallius Rätsel für Windows Profis Allgemeine Java-Themen 8
D OOP Gemeinsamen ID-Raum für zwei Klassen implementieren Allgemeine Java-Themen 7
D Input/Output Implementierung eines CommandHandlers/Parsers für viele Eingaben Allgemeine Java-Themen 26
Thallius Alternative für SwingWorker Allgemeine Java-Themen 5
I Lohnt sich heutzutage der Aufwand einer Portierung für MacOS Allgemeine Java-Themen 8
L Klassen Algorithmus für das folgende Problem entwickeln? Allgemeine Java-Themen 30
J Datenstruktur für eine Map erstellen Allgemeine Java-Themen 2
H OOP Setting(config) für Applikation sicheren? Allgemeine Java-Themen 9
OnDemand PDF Libary für Formulare Allgemeine Java-Themen 7
S Warmup für Lineare-Suche mit Zeitmessung Allgemeine Java-Themen 2
T Allgemeine Frage: GUI für 3D-Visualisierung Allgemeine Java-Themen 5
M Brainstorming für mein Projekt Allgemeine Java-Themen 30
K OOP Suche Hilfe + Erklärung für eine Hausaufgabe Allgemeine Java-Themen 1
F Was ist der Dateityp meines Parameters für die Main Methode. Allgemeine Java-Themen 6
C Bibliotheken für Algorithmische Geometrie Allgemeine Java-Themen 2
C Daten für Klassifikationsverfahren gewinnen Allgemeine Java-Themen 6
C code oder Bibliotheken für 2-Center Problem Allgemeine Java-Themen 4
I Overlay für Spiele Allgemeine Java-Themen 5
B Suche nach einem Testprogramm für meine BA Allgemeine Java-Themen 0
I GUI für kleine Pop-Ups unter Windows Allgemeine Java-Themen 1
A NetBeans Suche Programmierer für eine Belegarbeit Allgemeine Java-Themen 11
HarleyDavidson Best Practice Wohin mit der Konfigurationsdatei für Desktopapplikationen? Allgemeine Java-Themen 3
R MAC-Adresse eindeutig für einen PC ? Bezug zu Netzwerk, wieso ? Allgemeine Java-Themen 7

Ähnliche Java Themen

Neue Themen


Oben