• 一个配置文件的Mapping


    1. 需要Mapping的Xml结构

    <?xml version="1.0" encoding="utf-8"?>
    <Requestes>
    <Request name="RequestA" formname="LanguageUI" serviceurl="http://MyComputer/LanguageService" httpmethod="POST" targetui="Settings->LanuageSetting">
    <Reference name="ClassA">
    <Property name="DateFrom" type="DateTime?" />
    <Property name="DateTo" type="DateTime?" />
    </Reference>
    </Request>
    <Request name="RequestB" formname="ImageShowUI" serviceurl="http://MyComputer/ImageService" httpmethod="POST" targetui="Settings->Images">
    <Reference name="ClassB">
    <Property name="Top" type="int" />
    </Reference>
    </Request>
    </Requestes>

    2. Mapping到的类结构

     

    public class PropertyInfo
    {
    public string PropertyName
    {
    get;
    set;
    }
    public string PropertyType
    {
    get;
    set;
    }
    }
    public class DynamicEntity
    {
    public string Name
    {
    get;
    set;
    }
    public string ServiceURL
    {
    get;
    set;
    }
    public string TargetUI
    {
    get;
    set;
    }
    public List<PropertyInfo> SimplePropertyList { get; set; }
    public Dictionary<string, List<PropertyInfo>> CollectivePropertyList { get; set; }
    public List<RefenceInfo> RefenceList
    {
    get;
    set;
    }
    public string HttpMehtod
    {
    get;
    set;
    }
    public string FormName
    {
    get;
    set;
    }
    }
    public class RefenceInfo
    {
    public string Key
    {
    get;
    set;
    }
    public List<PropertyInfo> SimplePropertyList { get; set; }
    public Dictionary<string, List<PropertyInfo>> CollectivePropertyList { get; set; }
    public List<RefenceInfo> RefenceList { get; set; }
    }

     3. Mapping的方法

    public static List<DynamicEntity> Generate(string xmlPath, string formName)
    {
    XElement main
    = XElement.Load(xmlPath);

    return
    (from c
    in main.Elements("Request")
    where c.Attribute("formname").Value == formName
    select
    new DynamicEntity
    {
    Name
    = c.Attribute("name").Value,
    ServiceURL
    = c.Attribute("serviceurl").Value,
    TargetUI
    = c.Attribute("targetui").Value,
    HttpMehtod
    = c.Attribute("httpmethod").Value,
    FormName
    = c.Attribute("formname").Value,
    SimplePropertyList
    = c.Elements("Property").Where(p => p.Attribute("type").Value.Trim().ToLower() != "list").Select(p => new PropertyInfo { PropertyName = p.Attribute("name").Value, PropertyType = p.Attribute("type").Value }).ToList(),
    CollectivePropertyList
    = CollectivePropertyList(c.Elements("Property").Where(p => p.Attribute("type").Value.Trim().ToLower() == "list")),
    RefenceList
    = TopRefenceList(c.Elements("Reference"))
    }).ToList
    <DynamicEntity>();
    }
  • 相关阅读:
    oracle_jdbc_insert_into
    MySQL 性能比较测试:MySQL 5.6 GA -vs- MySQL 5.5
    centos去下载mysql应该怎么选择linux版本
    centos_radhat升级系统
    phpmyadmin 配置方法
    js 判断js函数,变量是否存在
    mysqlbinlog- 处理二进制日志文件的实用工具 学习笔记
    linux基本命令
    4 MySQL程序概述(包含mysql配置文件配置原理)-学习笔记
    Python学习笔记4 高级特性_20170618
  • 原文地址:https://www.cnblogs.com/mxy1028/p/2039136.html
Copyright © 2020-2023  润新知