Home | Contact Us | FAQ | Search & Site Map | Link to Us
Sign In | Join | Other 45 Sites in Network
HomeAnnouncementsFree MagazinesWhite PapersSubmit Content
Discussion GroupsASP.NETWindows FormsLanguages.NET FrameworkVisual Studio.NET
Articles.NET FrameworkASP.NETToolsWindows Forms
.NET DirectoryOpen Source ProjectsUser GroupsWeb Resources
Related Topics
Visual Basic 6SQL ServerMS AccessOther DB ProductsMS Server ProductsMore Topics ...

.NET Forum / ASP.NET / Web Services / April 2008

Tip: Looking for answers? Try searching our database.

WCF 3.5 and Problem with KnownTypeAttribute

Thread view: 
Enable EMail Alerts  Start New Thread
Thread rating: 
coconet - 29 Feb 2008 16:34 GMT
I have an Interface and an implementing class (receiver) and calling
class (sender) in a single DLL. The DLL is referenced in a web site
that received WCF calls and also in a seperate web site that makes
calls to the WCF site .svc. Why would I get an Exception about
KnownTypeAttribute?

InnerException thrown is:

System.Runtime.Serialization.SerializationException: Type
'nstestSecurity.TestPrincipal' with data contract name
'TestPrincipal:http://schemas.datacontract.org/2004/07/nstest.Security'
is not expected. Add any types not known statically to the list of
known types - for example, by using the KnownTypeAttribute attribute
or by adding them to the list of known types passed to
DataContractSerializer..

But my stuff looks like this:

[KnownType(typeof(IPrincipal))]
[DataContract(Name="DashboardPrincipal")]
public class TestPrincipal : IPrincipal
{
  ....
}

An instance of TestPrincipal is one of two parameters for a class that
uses this interface:

[ServiceContract(Name="IWcfReceiver",Namespace="http://nstest/200804/IWcfReceiver")]
public interface IWcfReceiver
{
[OperationContract]
List<ITestStuff> Do( IPrincipal inputPrincipal , List<ITestStuff>
testList );
}
Steven Cheng - 03 Mar 2008 03:42 GMT
Hi coconet,

Regarding on the "Type not serializable" exception you encountered, it is a
typical error in WCF service when you use base class/interface with derived
classes actually send in WCF service method.

For your case, the problem here is that you only declare the Interface type
in your WCF method( the IPrincipal type which is not a DataContract).
However, WCF service will only expose metadata for types that is decorated
with "DataContract" attribute or any type that is declared as "KnowType".  
I saw the you've add "KnowTypeAttribute" in the "TestPrincipal" class, this
is not the correct means of using "KnownTypeAttribute".
"KnownTypeAttribute" should be apply on the base type(base class or
interface) or on a DataContract type which has member of the base
type/interface. See the following reference:

#Data Contract Known Types
http://msdn2.microsoft.com/en-us/library/ms730167.aspx

To address the problem in your case, since you haven't use a base class,
you can add the known type declaration at service contract level. e.g.

=========
[ServiceContract]
[ServiceKnownType(typeof(TestPrincipal ))]
public interface IYourServiceInterface
....
==============

the following article include all the three means that can be used for
apply "KnownType" info for WCF service's  custom data contract:

#Handling Data Contract Object Hierarchies in WCF
http://footheory.com/blogs/bennie/archive/2007/07/28/handling-data-contract-
object-hierarchies-in-wcf.aspx

Sincerely,

Steven Cheng

Microsoft MSDN Online Support Lead



==================================================

Get notification to my posts through email? Please refer to
http://msdn.microsoft.com/subscriptions/managednewsgroups/default.aspx#notif
ications.



Note: The MSDN Managed Newsgroup support offering is for non-urgent issues
where an initial response from the community or a Microsoft Support
Engineer within 1 business day is acceptable. Please note that each follow
up response may take approximately 2 business days as the support
professional working with you may need further investigation to reach the
most efficient resolution. The offering is not appropriate for situations
that require urgent, real-time or phone-based interactions or complex
project analysis and dump analysis issues. Issues of this nature are best
handled working with a dedicated Microsoft Support Engineer by contacting
Microsoft Customer Support Services (CSS) at
http://msdn.microsoft.com/subscriptions/support/default.aspx.

==================================================
   

This posting is provided "AS IS" with no warranties, and confers no rights.

--------------------
>NNTP-Posting-Date: Fri, 29 Feb 2008 10:34:26 -0600
>From: coconet <coconet@community.nospam>
>Newsgroups: microsoft.public.dotnet.framework.aspnet.webservices
>Subject: WCF 3.5 and Problem with KnownTypeAttribute
>Date: Fri, 29 Feb 2008 11:34:26 -0500

>I have an Interface and an implementing class (receiver) and calling
>class (sender) in a single DLL. The DLL is referenced in a web site
[quoted text clipped - 31 lines]
>testList );
>}
Marc - 06 Mar 2008 08:21 GMT
> I have an Interface and an implementing class (receiver) and calling
> class (sender) in a single DLL. The DLL is referenced in a web site
[quoted text clipped - 31 lines]
> testList );
> }

Hi,

Found a solution to your problem? I'm having a simular issue where I get the knowType exception

/Marc

BizTalk Utilities - Frustration free BizTalk Adapters
http://www.topxml.com/biztalkutilities
coconet - 09 Apr 2008 04:14 GMT
I got into something else and don't remember what the fix should be,
after some more research I think I got it but did not actually
implement a solution.

I think the problem has to do with my using a List<T> of an Interface
for a return type and for a parameter. Whent he List<T> is serialized,
the receiver expects an array of a concrete type that it can convert
to the list of a type. When passing a list of Interface, the class
that implements it could be "anything" so it doesn't rehydrate
properly.

I think I was being too lazy in hoping I could just pass things around
this way, I am pretty sure that changing the method signature to
take/receive an array of each concrete type (instead of a single
method that gives/expects a List of Interface) would work.

>Hi,
>
[quoted text clipped - 4 lines]
>BizTalk Utilities - Frustration free BizTalk Adapters
>http://www.topxml.com/biztalkutilities

Rate this thread:







Free Magazines

Get these publications absolutely FREE for up to 12 months. There are no hidden fees and no obligation. Simply choose a title, complete the application form and submit it. Read more ...

Oracle MagazineNetwork ComputingComputer WorldBio-IT WorldeWeekInformation WeekInfosecurity
 
Sign In
Join
My Latest Posts
My Monitored Threads
My Blog
My Photo Gallery
My Profile
My Homepage

Start New Thread
Enable EMail Alerts
Rate this Thread



©2008 Advenet LLC   Privacy Policy - Terms of Use
This website includes both content owned or controlled by Advenet as well as content owned or controlled by third parties.