FileNet P8 Arbeitsplatz Token Ausgabe
-
04-10-2019 - |
Frage
Ich versuche, Benutzer-Token und die URL zu bauen, so dass Benutzer nicht jedes Mal anmelden sie auf die Datei. unten ist mein Code. Meine Frage ist, ich von dem Token-Wert zu übergeben ganzen tun müssen, siehe unten oder ?? Der Token-Wert Ich erhalte ist
symmetric:algorithm:QUVT:keyid:NTZkYTNkNmI=:data:7P9aJHzkfGTOlwtotuWGaMqfU9COECscA9yxMdK64ZLa298A3tsGlHKHDFp0cH+gn/SiMrwKfbWNZybPXaltgo5e4H4Ak8KUiCRKWfS68qhmjfw69qPv9ib96vL3TzNORYFpp/hrwvp8aX4CQIZlBA==
Das Problem ist, wenn ich die URL und daran vorbei in dem Browser kopieren, mich auf die Login-Seite nimmt. Obwohl ich alle Fehler bin nicht immer, es sollte Benutzer nehmen direkt mit dem Bildbetrachter, sondern nimmt es mich auf Login-Seite, wenn ich es richtig anmelden um die Datei geöffnet wird.
Was mache ich falsch?
string text = "";
string userName = "userName";
string pwd = "*****";
fileNetID = "{5FCE7E04-3D74-4A93-AA53-26C12A2FD4FC}";
Uri uri = null;
string workplaceURL = "http://filenet:9081/WorkPlaceXT";
uri = new Uri(workplaceURL + "/setCredentials?op=getUserToken&userId=" + this.encodeLabel(userName) + "&password=" + this.encodeLabel(pwd) + "&verify=true");
System.Net.WebRequest webRequest = System.Net.WebRequest.Create(uri);
System.Net.WebResponse webResponse = webRequest.GetResponse();
StreamReader streamReader = new StreamReader(webResponse.GetResponseStream());
String token = streamReader.ReadToEnd();
string contentURL = string.Empty;
contentURL = workplaceURL + "/getContent?objectType=document&impersonate=true&objectStoreName=OBJECTSTORE&id=" + HttpUtility.UrlEncode(fileNetID);
contentURL += "&ut=" + HttpUtility.UrlEncode(encodeLabel(token));
return contentURL;
Keine korrekte Lösung
Andere Tipps
Hier ist meine Funktion ist, können Sie die letzten paar Zeilen sehen, wie ich das Token am Ende entrollen:
public static string getCEUserToken(string baseURL, string uid, string pwd)
{
string UserToken = "";
System.Net.WebRequest request = System.Net.WebRequest.Create(baseURL + "/setCredentials?op=getUserToken&userId=" + uid + "&password=" + pwd +
"&verify=true");
request.Method = "POST";
System.Net.WebResponse response = request.GetResponse();
Stream stream = response.GetResponseStream();
byte[] token = new byte[response.ContentLength];
stream.Read(token, 0, (int)response.ContentLength);
response.Close();
foreach (byte chr in token)
UserToken += System.Convert.ToChar(chr);
return System.Web.HttpUtility.UrlEncode(UserToken);
}
Lizenziert unter: CC-BY-SA mit Zuschreibung
Nicht verbunden mit StackOverflow