Wie ein Subject mit Execution Thread verbinden?

Status
Nicht offen für weitere Antworten.

Tobias

Top Contributor
Hi,

ich habe von JAAS ein Subject bezogen, welches ich nun für die nachfolgenden Checks per AccessController mit dem Execution Thread verbinden muss. Wie mache ich das?
 

FArt

Top Contributor
Tobias hat gesagt.:
ich habe von JAAS ein Subject bezogen, welches ich nun für die nachfolgenden Checks per AccessController mit dem Execution Thread verbinden muss. Wie mache ich das?

Wo hast du das denn her? Steht da nicht auch wie das geht?
 

Tobias

Top Contributor
Naja, stellen wir die Frage anders ...

Ich möchte Principal-basierte Securityabfragen mit dem AccessController durchführen. Nur weil mein Code irgendwann mal ein Subject vom JAAS-LoginContext holt und es in irgendeiner Instanzvariable ablegt, hat der AccessController für die nachfolgenden Abfragen ja keinen Zugriff darauf (es sei denn hier gibt es irgendwelche mir unbekannte Magie). Wie mache ich dem AccessController das Subject bekannt?

Ich habe da was gefunden, den DomainCombiner. Aber so richtig habe ich noch nicht verstanden, wie ich den standardmäßig benutzten DomainCombiner gegen den JAAS-SubjectDomainCombiner austausche.
 

Tobias

Top Contributor
Ok,

ich habe mein Beispiel tatsächlich noch ans Laufen gekriegt. Szenario ist das Folgende: Ich habe eine Client-Server-Anwendung, bei der die Client-Swing-Applikation durch einen SecurityManager betreut wird. Dieser SecurityManager vergibt den größten Teil der Berechtigungen auf Basis der Principals des am Server (JBoss AS 4.2.1) eingeloggten Subjects, die Anwendung an sich kriegt nur die nötigen Rechte, um sich am Server anzumelden. Problem ist nun die Übernahme des von JAAS an den Client gelieferten Subjects in den Execution Thread des Swing-Clients.

Beispiel:

Die Klasse SubjectBinding meldet sich am JBoss-Server an und gibt die Klasse des erhaltenen Subjects aus (zum Beweis des erfolgten Logins). Anschließend wird eine Aktion ausgeführt, für die das eingeloggte Subject die nötigen Rechte besitzt (Lesezugriff auf eine Datei):
Code:
public class SubjectBinding {

	/**
	 * @param args
	 */
	public static void main(String[] args) throws Exception {
		LoginContext lCtx = new LoginContext("jaas-test", new MyCallbackHandler());
		lCtx.login();
		Subject s = lCtx.getSubject();
		
		System.out.println(s.getPrincipals().toArray()[0].getClass());
		
		File f = new File("C:\\test.txt");
		f.exists(); // Das eingeloggte Subject hat die nötigen Rechte!
	}

}

// MyCallbackHandler setzt nur den Benutzernamen und das Passwort;
// weggelassen, um das Beispiel kurz zu halten.

Die dazugehörige Policy-Datei sieht wie folgt aus; der Anwendung selbst werden alle Rechte gegeben, die zum Login erforderlich sind. Das Subject, das eingeloggt wird, erhält die Rechte zur Ausführung der eigentlichen Nutzlast, dem Lesezugriff auf die Datei "test.txt":
Code:
grant codebase "file:/<<Projekt-Pfad>>/JAAS-Examples/-" {
	permission javax.security.auth.AuthPermission "createLoginContext.jaas-test";
	permission javax.security.auth.AuthPermission "modifyPrincipals";
	permission javax.security.auth.AuthPermission "getSubject";
	
	permission java.util.PropertyPermission 
              "org.jboss.security.SecurityAssociation.ThreadLocal", "read";
	permission java.lang.RuntimePermission 
              "org.jboss.security.SecurityAssociation.setPrincipalInfo";
};

grant principal org.jboss.security.SimplePrincipal "tobias" {
	permission java.io.FilePermission "<<ALL-FILES>>", "read";
};

Beim Ausführen des Beispiels kommt folgende Ausgabe:
Code:
class org.jboss.security.SimplePrincipal
Exception in thread "main" java.security.AccessControlException: access denied 
    (java.io.FilePermission C:\test.txt read)

Sprich, das Programm scheitert, sobald es darum geht Rechte aufgrund des eingeloggten Subjects zu erhalten. Dies liegt nach meiner Interpretation daran, dass das Subject nicht an den Execution Thread gebunden wird (warum auch?). Wie kann ich also den aktuellen AccessControlContext und das Subject bzw dessen Principals miteinander bekannt machen?
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
K Javamail:Probleme mit der Darstellung von Umlaute in Subject Allgemeine Java-Themen 15
N No context is current or a function that is not available in the current context was called. The JVM will abort execution. (lwjgl) Allgemeine Java-Themen 6
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
urmelausdemeis Exception in thread "main" java.lang.Error: Unresolved compilation problem: Allgemeine Java-Themen 7
smarterToby Wie stoppe ich diesen Thread Allgemeine Java-Themen 4
A Thread.sleep Problem Allgemeine Java-Themen 2
J Thread started nur einmal Allgemeine Java-Themen 19
W Server-Thread schreibt nicht alle Dateien Allgemeine Java-Themen 6
OnDemand Logfile pro User / Thread Allgemeine Java-Themen 7
OnDemand Thread / Service abbrechen Allgemeine Java-Themen 3
Thallius Ist meine static Helper Class Thread save? Allgemeine Java-Themen 9
P Swing Exception in thread "AWT-EventQueue-0" java.lang.IndexOutOfBoundsException: npoints > xpoints.length || npoints > ypoints.length Allgemeine Java-Themen 5
B Thread.sleep() in EJB Container wie lösen? Allgemeine Java-Themen 11
S Ist das Neuzuweisen von Feldern atomic und damit Thread-Safe? Allgemeine Java-Themen 2
S Exception in thread "main" java.lang.NullPointerException at FamilienApp.main(FamilienApp.java:15) Allgemeine Java-Themen 1
J Einen Thread in einer Schleife Allgemeine Java-Themen 2
E HILFE !! Exception in thread "main" java.lang.NoClassDefFoundError: org/apache/commons/io/FileUtils Allgemeine Java-Themen 4
Flynn Thread-Problem... Allgemeine Java-Themen 2
G Thread-Programmierung Allgemeine Java-Themen 5
S Datei wird nicht gefunden Thread.currentThread().getContextClassLoader().getResourceAsStream() Allgemeine Java-Themen 1
G Beendet sich der Thread selbst?! Allgemeine Java-Themen 3
mrbig2017 Sleep wird ignoriert und der Thread wartet nicht Allgemeine Java-Themen 1
S Thread beenden Allgemeine Java-Themen 9
M Array aus Thread Objekten erstellen Allgemeine Java-Themen 2
Aruetiise Swing JOptionPane ohne denn Thread zu pausieren Allgemeine Java-Themen 1
M Nanosekunden-Pause innerhalb einen Thread-Loops Allgemeine Java-Themen 3
E Thread Exception Allgemeine Java-Themen 6
javaerd Binomialkoeffizient ausrechnen, Exception in thread "main" java.lang.StackOverflowError Allgemeine Java-Themen 6
T Merkwürdiges Thread-Verhalten Allgemeine Java-Themen 6
K Thread Problem Allgemeine Java-Themen 6
W Thread sleep 30 sekunden - wenn keine Antwort bis dahin neu senden Allgemeine Java-Themen 2
H Thread bleibt stehen bei jar in jar Allgemeine Java-Themen 1
J Threads HTTP Request (Thread) dauert lange - in Android Allgemeine Java-Themen 3
F CPU Last eines Thread ausfindig machen Allgemeine Java-Themen 0
V Compiler-Fehler Exception in thread "AWT-EventQueue-0" java.lang.IndexOutOfBoundsException: Index: 125, Size: 125 Allgemeine Java-Themen 11
Tausendsassa Threads Einen Thread sich selbst schließen lassen Allgemeine Java-Themen 17
P Threads BufferedImage, Thread Concurrency Allgemeine Java-Themen 1
M Klasse in separaten Thread ausführen.Wie genau? Allgemeine Java-Themen 2
llabusch Thread blockiert Dialog Allgemeine Java-Themen 1
J Thread wait() Allgemeine Java-Themen 2
V Thread.sleep und InterruptedException? Allgemeine Java-Themen 1
G Thread nicht von GC zerstört Allgemeine Java-Themen 6
J Wie erschaffe ich einen sicheren Datenaustausch zwischen Thread und Nicht-Threads Allgemeine Java-Themen 8
Sogomn Thread blocken bis Taste gedrückt Allgemeine Java-Themen 5
T Starten vom Thread Allgemeine Java-Themen 3
T Wait/Notify() bei Thread Allgemeine Java-Themen 6
J Exception in thread "main" java.lang.NoClassDefFoundError Allgemeine Java-Themen 4
M Exception in thread "AWT-EventQueue-0" Allgemeine Java-Themen 6
Q Thread wacht nicht auf Allgemeine Java-Themen 7
T Fragen zum Thread-Thema Allgemeine Java-Themen 4
T Threads Input/Output im Thread - Datei ohne Inhalt Allgemeine Java-Themen 1
T Fragen zum Thread-Thema Allgemeine Java-Themen 9
C Threads Variablen in einem Thread Aktualisieren Allgemeine Java-Themen 17
U Thread beenden Allgemeine Java-Themen 3
W Threads Mit Thread und Runtime externe Programme öffnen Allgemeine Java-Themen 0
N Thread interrupt Status debuggen Allgemeine Java-Themen 6
A Thread: Code paralell ausführen in mehreren Instanzen Allgemeine Java-Themen 1
E Threads linkedlist/multi-thread problem Allgemeine Java-Themen 3
B Erkennen, wann Prozess beendet ist, dann Thread beenden. Allgemeine Java-Themen 6
A Thread Fehler absichtlich provozieren Allgemeine Java-Themen 3
B Threads Java Thread kommunizieren Allgemeine Java-Themen 12
N Thread Sicherheit im komplexen Datenmodell Allgemeine Java-Themen 7
K Thread richtig benutzen Allgemeine Java-Themen 3
K Exception in thread "AWT-EventQueue-1" Allgemeine Java-Themen 2
vandread Problem bei kleiner Thread-Übung Allgemeine Java-Themen 2
G Thread erzeugt nicht plausible NullPointerException Allgemeine Java-Themen 7
H Netbeans Warning bei Thread.sleep in Schleife Allgemeine Java-Themen 4
P [Thread] Scheint nicht Sequenziell zu Arbeiten Allgemeine Java-Themen 9
A eine test thread.join() frage Allgemeine Java-Themen 2
tuttle64 Verständnisprobleme mit Thread Locks Allgemeine Java-Themen 4
G Threads Thread bei Datenabfrage Allgemeine Java-Themen 3
S Thread anhalten per Button ? Allgemeine Java-Themen 3
E Thread Programmierung Allgemeine Java-Themen 2
S Threads ServerSocket-Thread soll schlafen, bis er gebraucht wird Allgemeine Java-Themen 2
V Thread schneller stoppen Allgemeine Java-Themen 2
V anstatt thread.join() einfach while schleife? Allgemeine Java-Themen 8
B Mausbewegung im Thread erkennen (hoch/runter) Allgemeine Java-Themen 6
G Linux/C++/Pthreads auf JVM zugreifen, thread safe? Allgemeine Java-Themen 10
K Threads Probleme mit Thread Allgemeine Java-Themen 13
K Threads Thread überprüfen Allgemeine Java-Themen 3
Z Threads Thread für einen Client Allgemeine Java-Themen 9
M Thread JavaFish Allgemeine Java-Themen 10
G Thread.sleep Allgemeine Java-Themen 12
M Threads Viele Aufrufe aus Thread, komisches Verhalten Allgemeine Java-Themen 8
B Threads Main Thread warten auf abgebrochen Task warten lassen Allgemeine Java-Themen 25
K Timer Thread Allgemeine Java-Themen 8
M Methoden Static Methoden und Thread??? Allgemeine Java-Themen 4
N java.lang.IllegalMonitorStateException: object not locked by thread before notify() Allgemeine Java-Themen 2
C Mehothode in anderenm Thread aufrufen Allgemeine Java-Themen 10
R Thread läuft nicht?! Allgemeine Java-Themen 7
R ThreadPool - vorhandene thread liste überprüfen bzw. aufräumen Allgemeine Java-Themen 3
J Anderem Thread Variable mitgeben Allgemeine Java-Themen 2
C Argument an einen Thread übergeben Allgemeine Java-Themen 4
S java.util.ConcurrentModificationException - aber nur ein Thread Allgemeine Java-Themen 3
G JUnit Test Methoden in anderen Thread verlagern Allgemeine Java-Themen 4
P Java Probleme - java.lang.Thread.run(Unkown Source) Allgemeine Java-Themen 10
L Im Thread auf Eingaben warten Allgemeine Java-Themen 3
P aus Thread auf Form zugreifen Allgemeine Java-Themen 9
C Threads Thread blockieren Allgemeine Java-Themen 4
K Threads Thread für Sleep Allgemeine Java-Themen 6

Ähnliche Java Themen

Neue Themen


Oben