• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            天下

            記錄修行的印記

            WCF 數據契約(DataContract)

            數據契約(DataContract)
            服務契約定義了遠程訪問對象和可供調用的方法,數據契約則是服務端和客戶端之間要傳送的自定義數據類型。
            一旦聲明一個類型為DataContract,那么該類型就可以被序列化在服務端和客戶端之間傳送,如下所示。
                 [DataContract]
                 
            public class UserInfo
                 {
                      
            //….
                 }
            只有聲明為DataContract的類型的對象可以被傳送,且只有成員屬性會被傳遞,成員方法不會被傳遞。WCF對聲明為DataContract的類型提供更加細節的控制,可以把一個成員排除在序列化范圍以外,也就是說,客戶端程序不會獲得被排除在外的成員的任何信息,包括定義和數據。默認情況下,所有的成員屬性都被排除在外,因此需要把每一個要傳送的成員聲明為DataMember,如下所示。
                [DataContract]
                
            public class UserInfo
                {
                    [DataMember]
                    
            public string UserName
                    {
                        
            get;
                        
            set;
                    }
                    [DataMember]
                    
            public int Age
                    {
                        
            get;
                        
            set;
                    }
                    [DataMember]
                    
            public string Location
                    {
                        
            get;
                        
            set;
                    }
                    
            public string Zodiac
                    {
                        
            get;
                        
            set;
                    }
            }
            上面這段代碼把UserInfo類聲明為DataContract,將UserName、Age、Location這3個屬性聲明為DataMember(數據成員)。Zodiac成員沒有被聲明為DataMember,因此在交換數據時,不會傳輸Zodiac的任何信息。
            DataContract也支持Name
            /Namespace屬性,如同ServiceContract,Name和Namespace可以自定義名稱和命名空間,客戶端將使用自定義的名稱和命名空間對DataContract類型進行訪問。
            聲明為DataMember的成員也可以自定義客戶端可見的名稱,例如:
            [DataMember(Name
            ="Name")]
            public string UserName
            {
                 
            get;
                 
            set;
            }
            [DataMember(Name
            ="Age")]
            public int UserAge
            {
                      
            get;
                      
            set;
            }
            除了Name和Namespace以外,DataMember還有以下參數,它們的含義分別如下。
            1)IsRequired:值為true時,要求序列化引擎檢查對象是否存在該值;若無,則會有異常拋出。
            2)Order:bool類型值,值為true時,序列化和反序列化過程將會按成員定義的順序進行,這對依賴于成員位置的反序列化過程無比重要。
            3)EmitDefaultvalue:為成員屬性設置一個默認值。

            posted on 2016-06-13 17:52 天下 閱讀(263) 評論(0)  編輯 收藏 引用 所屬分類: C#

            <2012年3月>
            26272829123
            45678910
            11121314151617
            18192021222324
            25262728293031
            1234567

            導航

            統計

            常用鏈接

            留言簿(4)

            隨筆分類(378)

            隨筆檔案(329)

            鏈接

            最新隨筆

            搜索

            最新評論

            久久影院久久香蕉国产线看观看| 亚洲精品国产成人99久久| 精品久久久久久无码人妻蜜桃| 狠狠久久综合| 久久久久国产精品嫩草影院| 久久婷婷五月综合色奶水99啪| 国产美女久久精品香蕉69| 久久这里只有精品首页| 久久天天躁狠狠躁夜夜2020| 久久亚洲AV无码精品色午夜麻豆| 午夜精品久久久久久久久| 久久综合久久综合久久| 香蕉久久久久久狠狠色| 一本一道久久精品综合| 久久久久久曰本AV免费免费| 国产福利电影一区二区三区,免费久久久久久久精 | 亚洲国产成人久久笫一页| 久久综合亚洲欧美成人| 亚洲欧美国产精品专区久久| AV狠狠色丁香婷婷综合久久| 99久久免费国产精品特黄| 91精品观看91久久久久久| 精品久久久无码21p发布| 久久男人AV资源网站| 国产精品久久自在自线观看| 伊人久久大香线焦AV综合影院 | 九九99精品久久久久久| 久久人人爽人人爽人人片av高请| 久久se精品一区二区影院| 久久婷婷久久一区二区三区| 久久综合给合久久国产免费| 久久精品国产亚洲av麻豆蜜芽| 欧美大战日韩91综合一区婷婷久久青草| 久久精品一区二区| 99精品久久精品| 国产精品青草久久久久婷婷 | 久久香蕉综合色一综合色88| 国产亚洲婷婷香蕉久久精品| 久久99精品久久只有精品| 国产亚洲精久久久久久无码| 亚洲AV无码久久精品色欲|