将XML序列化成对象

1

 

namespace MvcAppTest.Controllers
{
    public class HomeController : Controller
    {
        //
        // GET: /Home/

        public ActionResult Index()
        {

            string sql = "select a.* ,(select UserName,Password, Error from T_UserLogin  where LoginId=a.LoginId  for xml auto, type, elements) as UserInfoXML from T_UserInfo a ";

            List<T_UserInfo> list = SqlHelper.ExecuteClass<T_UserInfo>(sql, null);

            //经过sql语句查询后UserInfoXML字段的值为:
            //  <T_UserLogin><UserName>无盐海</UserName><Password>123456</Password><Error>1</Error></T_UserLogin>

            //将XML格式的字符串转换成对象(特别要注意<T_UserLogin>要与目标类名称一致)
            var objList = HomeController.XMLToObject<T_UserLogin>(list.First().UserInfoXML, Encoding.UTF8);
            var name = objList.UserName;
            return View();
        }


        /// <summary>
        /// 将object对象序列化成XML
        /// </summary>
        /// <typeparam name="T">需要序列化的对象</typeparam>
        /// <param name="encoding">如果序列化出错,可以尝试修改下encoding的值试试</param>
        /// <returns></returns>
        public static string ObjectToXML<T>(T t, Encoding encoding)
        {
            XmlSerializer ser = new XmlSerializer(t.GetType());
            using (MemoryStream mem = new MemoryStream())
            {
                using (XmlTextWriter writer = new XmlTextWriter(mem, encoding))
                {
                    XmlSerializerNamespaces ns = new XmlSerializerNamespaces();
                    ns.Add("", "");
                    ser.Serialize(writer, t, ns);
                    return encoding.GetString(mem.ToArray()).Trim();
                }
            }
        }

        /// <summary>
        /// 将XML反序列化成对象
        /// </summary>
        /// <typeparam name="T"></typeparam>
        /// <param name="source">需要序列化的XML字符串</param>
        /// <param name="encoding">如果序列化出错,可以尝试修改下encoding的值试试</param>
        /// <returns></returns>
        public static T XMLToObject<T>(string source, Encoding encoding)
        {
            XmlSerializer mySerializer = new XmlSerializer(typeof(T));
            using (MemoryStream stream = new MemoryStream(encoding.GetBytes(source)))
            {
                return (T)mySerializer.Deserialize(stream);
            }
        }
    }
}

 

 

namespace MvcAppTest.DAL
{
    [Serializable]
    public class T_UserInfo
    {
        public int Id { get; set; }

        public string UserName { get; set; }

        public int Age { get; set; }

        public string UserInfoXML { get; set; }
    }
    [Serializable]
    public class T_UserLogin
    {
        public string UserName { get; set; }

        public string Password { get; set; }

        public int Error { get; set; }
    }
}

 

 

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值