• <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 天下 閱讀(287) 評論(0)  編輯 收藏 引用 所屬分類: C#

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

            導航

            統計

            常用鏈接

            留言簿(4)

            隨筆分類(378)

            隨筆檔案(329)

            鏈接

            最新隨筆

            搜索

            最新評論

            欧美激情精品久久久久久久| 精品伊人久久久| 国产精品欧美亚洲韩国日本久久| 国产精品免费久久久久影院| 久久青青草视频| 久久国产色AV免费观看| 久久精品国产99久久久香蕉| 色欲久久久天天天综合网 | 一本久道久久综合狠狠躁AV| 久久亚洲国产成人精品性色| 久久综合视频网站| 日本免费一区二区久久人人澡| 久久亚洲sm情趣捆绑调教| 亚洲国产精品一区二区久久| 亚洲精品乱码久久久久久蜜桃不卡 | 中文字幕无码精品亚洲资源网久久 | 久久久久无码精品国产app| 日韩人妻无码一区二区三区久久| Xx性欧美肥妇精品久久久久久| 色欲久久久天天天综合网 | 国产精品久久久久久久久软件| 久久中文娱乐网| 97久久精品午夜一区二区| 久久天天躁狠狠躁夜夜2020一 | 亚洲国产精品一区二区久久hs| 久久精品国产99久久香蕉| 88久久精品无码一区二区毛片| 久久精品国产亚洲AV无码娇色| 77777亚洲午夜久久多喷| 国内精品伊人久久久久妇| 人妻无码久久精品| 亚洲国产综合久久天堂 | 久久亚洲精品成人无码网站| 午夜精品久久久久久影视777| 久久精品无码免费不卡| 国产福利电影一区二区三区久久久久成人精品综合 | 久久精品人人做人人爽97| 色综合久久久久综合体桃花网| 亚洲AV日韩精品久久久久久久| 亚洲国产美女精品久久久久∴| 五月丁香综合激情六月久久|