silverlight security with WCF service, Forms Authentication and Custom Form Ticket

Posted by user74825 on Stack Overflow See other posts from Stack Overflow or by user74825
Published on 2010-05-14T01:59:55Z Indexed on 2010/05/14 2:04 UTC
Read the original article Hit count: 358

I have a silverlight application with login on the silverlight page. It uses Forms Authentication with WCF authentication service and customer Membership Provider. Something like : http://blogs.msdn.com/phaniraj/archive/2009/09/10/using-the-ado-net-data-services-silverlight-client-library-in-x-domain-and-out-of-browser-scenarios-ii-forms-authentication.aspx

So, SL page login page calls the WCF service authentication service, it validates using DB - brings back username and password. Now, in each subsequent calls (in Global.asax in Authenticate_Request, I get HttpContext.User.IsAuthenticated and HttpContext.User.UserName). I have all this working properly. But, I just don't want the username, but more information surrounding the user, like UserId, UserAddress, UserAssociateCustomer etc.

I tried couple of different approaches. 1) Use HttpContext.Cache as a dictionary to save the item and get it off based on httpcontext.user.name, problem is cache can be erased if there memory is being used heavily.

2) Tried CustomFormsAuth Ticket, when forms authentication writes a ticket, I intercept CreatingCookie method and write additional info in formauthentication ticket, so that I can read it in subsequent requests, I am having problems with this approach, I don't find the ticket in subsequent requests. I read about how we should use REsponse.Redirect, but where do I redirect user from WCF call.

How do you guys implement the above scenario? Any best practices.? Any issues you see with going on HTTPS?

All examples (or most of them) just explains simple forms authentication with "I am logged in message"..

Any suggestions ?

© Stack Overflow or respective owner

Related posts about silverlight-3.0

Related posts about security