加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

将XML序列化成对象

发布时间:2020-12-16 02:19:44 所属栏目:百科 来源:网络整理
导读: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,t

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; }
    }
}

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读