Related to this question, I'm instantiating a connection to our internal API inside my custom UserNamePasswordValidator. Can I stash this somewhere so that I can use it in future calls in that user's session?
This is similar to this question, but I'm not using IIS, so I can't use HttpContext.Current (or can I?).
Update: Some context: our inter开发者_如何学Pythonnal API is exposed via a COM object, which exposes a Login
method. Rather than have a Login
method in my service interface, I've got a custom UserNamePasswordValidator
, which calls the Login method on the COM object.
Because instantiating the COM object and logging in is expensive, I'd like to re-use the now-logged-in COM object in my service methods.
Yes, it can. You'll need:
- a custom
ServiceCredentials
implementation that returns a customSecurityTokenManager
. - a custom
SecurityTokenManager
implementation that returns a customCustomUserNameSecurityTokenAuthenticator
. - your custom
CustomUserNameSecurityTokenAuthenticator
needs to overrideValidateUserNamePasswordCore
, and should add a custom implementation ofIAuthorizationPolicy
. - your implementation of
IAuthorizationPolicy
should implementEvaluate
, at which point it can start putting things in the WCF context. - replace the
evaluationContext["PrimaryIdentity"]
value with aPasswordIdentity
or a customIIdentity
. - replace the
evaluationContext["Principal"]
value with aPasswordPrincipal
or a customIPrincipal
. - update the
evaluationContext["Identities"]
collection to replace theGenericIdentity
instance with your custom instance.
By doing this, you can have a custom IPrincipal
implementation with some extra information in it.
For more details, see this.
UserNamePasswordValidator is absolutely out of all WCF contexts. It is only used to validate user name and password. Can you futher explain your problem?
Edit: I guess COM object is instantiated for each session, isn't it? Otherwise wrapping COM into singleton should solve your problem. If you need to have per session COM object shared between validator and service instance you will need some cache or registry - something which is outside both validator and service and can be called from both of them.
精彩评论