nu-fg Geschrieben 18. März 2004 Geschrieben 18. März 2004 Hallo! Ich habe da folgendes Problem: Ich möchte den Usernamen, mit dem der Benutzer an seinem Client angemeldet ist, mit einem Servlet auslesen. Auf den Clients läuft Win NT 4. Die Servlets werden unter Linux entwickelt, Container ist Tomcat. Bisher habe ich request.getRemoteUser() und das request.getUserPrincipal() - Objekt ausprobiert. Bei beiden kommt "null" zurück :-( Hat jemand eine Idee wie man sowas hinbekommt??? Danke für Eure Hilfe!! Zitieren
BMAS Geschrieben 18. März 2004 Geschrieben 18. März 2004 http://jcifs.samba.org/ Du musst jcifs als Filter in deine web.xml einbinden. Ein Tutorial findest du auf der Startseite, Beispiele findest du hier: http://jcifs.samba.org/src/examples/ Noch ein Tipp: Kopier die .jar Datei NICHT in das lib-Verzeichnis deiner Applikation, sondern in das common\lib Verzeichnis. Steht zwar im Tutorial, funktioniert aber nicht. Achja, sobald du jcifs richtig eingebunden hast, kannst du einfach mit request.getRemoteUser() den Benutzernamen auslesen. Zitieren
nu-fg Geschrieben 18. März 2004 Autor Geschrieben 18. März 2004 Danke schonmal! Habe nur noch eine Frage zum Einbinden in die web.xml. Sieht bei mir jetzt foilgendermaßen aus: <filter> <filter-name>NTLM HTTP Authentication Filter</filter-name> <filter-class>jcifs.http.NtlmHttpFilter</filter-class> </filter> <filter-mapping> <filter-name>NTLM HTTP Authentication Filter</filter-name> <url-pattern>/*</url-pattern> </filter-mapping> Er scheint den Filter zu benutzen, jedoch bekomme ich beim Aufrufen des Servlets folgenden Fehler: java.lang.ArrayIndexOutOfBoundsException at java.lang.System.arraycopy(Native Method) at jcifs.ntlmssp.Type2Message.toByteArray(Type2Message.java:261) at jcifs.http.NtlmSsp.authenticate(NtlmSsp.java:90) at jcifs.http.NtlmHttpFilter.doFilter(NtlmHttpFilter.java:112) ... Falsch eingebunden??? Die Datei jcifs-0.8.2.jar habe ich ins common/lib von tomcat kopiert. Zitieren
BMAS Geschrieben 18. März 2004 Geschrieben 18. März 2004 Da fehlen noch einige params, schau dir mal das Tutorial dazu an. Da steht drinnen welche das sind. Unter anderem musst du nämlich den DC angeben. So muss das aussehen: <filter> <filter-name>NTLM HTTP Authentication Filter</filter-name> <filter-class>jcifs.http.NtlmHttpFilter</filter-class> <!-- For development, any SMB server (also jeder Client mit WinNT oder höher!!!) is suitable for validating password hashes. --> <init-param> <param-name>jcifs.http.domainController</param-name> <param-value>192.168.1.16</param-value> </init-param> <!-- For production use a real domain controller and eliminate a middle-man server <init-param> <param-name>jcifs.smb.client.domain</param-name> <param-value>NYC-USERS</param-value> </init-param> <init-param> <param-name>jcifs.netbios.wins</param-name> <param-value>10.169.10.77</param-value> </init-param> --> </filter> <!-- NTLM HTTP Authentication only works with MSIE <filter-mapping> <filter-name>NTLM HTTP Authentication Filter</filter-name> <url-pattern>/*</url-pattern> </filter-mapping> --> Aber wie gesagt, für genauere Infos musst du dir das Tutorial anschauen. Zitieren
Empfohlene Beiträge
Dein Kommentar
Du kannst jetzt schreiben und Dich später registrieren. Wenn Du ein Konto hast, melde Dich jetzt an, um unter Deinem Benutzernamen zu schreiben.