如何由XSD自动生成XML和实体类

项目中有时候要用XML作为数据源,因此需要定义XML文件和相应的类,最佳方法是首先定义XSD,然后自动生成实体类,最后生成XML和填充数据;读取XML数据源的时候,首先用XSD验证XML数据格式,然后自动读入实体类使用。

定义XSD的过程就是类似设计表结构的过程,二者也可以相互转化。

本文讨论了如何定义XSD文件(XML Schema),然后自动生成实体类,最后生成XML的过程,以及如何根据XSD验证XML文件的合法性。以供大家做项目时参考。

1.
首先在VS2005中添加一个XSD文件。例子XSD可以参考:

http://www.15seconds.com/issue/031209.htm

http://www.cduce.org/manual_schema_samples.html

 

2. 使用VS2005工具XSD.exe(SDK/v2.0/Bin/xsd.exe)自动生成实体类:

xsd /c /namespace:myCompany /language:CS temp1.xsd

也可以生成DataSet类型的类:

xsd /dataset /language:CS temp1.xsd

 ( 类文件和XSD之间可以相互转换,也就是说,你也可以先生成类,然后自动生成XSD)

    自动读取XML数据到实体类:
    

XmlSerializer xs  =   new  XmlSerializer( typeof (myClassType));
using  (FileStream fs  =   new  FileStream(XmlFilePath, FileMode.Open))
{
    
return (myClassType)xs.Deserialize(fs);
}

     
3. 如何由XML生成XSD

   - 可以用工具,如XMLSpy,首先打开XML, 然后DTD/Schema -> Generate DTD/Schema, 选择W3c Sehcma即可。

   - 此方法不一定能生成确切满足需求的XSD,另需修改。


4. 如何由XSD生成XML?

   - 可以用其他工具,如XMLSpy,DTD/Schema -> Generate sample XML file...
  
   - 可以由XSD生成类,然后写代码实例化这个类,最后序列化为XML

   - 如何自动给类每个属性设置一个空值:(用反射的方法)

     代码示例:

/// <summary>
        
/// Get all properties and set default value
        
/// </summary>
        
/// <typeparam name="T">Type</typeparam>
        
/// <param name="item">Object</param>

         private   static   void  ReflctProperties < T > (T item)
        
{
            PropertyInfo[] pty 
= typeof(T).GetProperties();
            Type t 
= item.GetType();

            
if (pty != null)
            
{
                
foreach (PropertyInfo info in pty)
                
{
                    
if (!info.CanWrite) continue;

                    
if (info.PropertyType == typeof(String))
                    
{
                        t.GetProperty(info.Name).SetValue(item, String.Empty, 
null);
                    }

                    
if (info.PropertyType == typeof(Boolean))
                    
{
                        t.GetProperty(info.Name).SetValue(item, 
truenull);
                    }

                }

            }

        }

    - 反射读取类的属性:
 

public   static   object  GetProperty < T > (T item,  string  PropertyName)
{
     PropertyInfo propertyInfo 
= item.GetType().GetProperty(PropertyName);
     
if (propertyInfo != null)
     
{                
         
return propertyInfo.GetValue(item, null);
     }

     
return null;
}



   - 如何序列化为XML?

/// <summary>
        
/// Serialize class instance to XML file
        
/// </summary>
        
/// <typeparam name="T">type</typeparam>
        
/// <param name="XMLFileToCreate">XMLFileToCreate</param>
        
/// <param name="instance">class instance</param>

         public   void  Serialize < T > ( string  XMLFileToCreate, T instance)
        
{
            
if (instance == nullreturn;

            XmlSerializer xs 
= new XmlSerializer(typeof(T));
            
using (StreamWriter sw = new StreamWriter(XMLFileToCreate))
            
{
                xs.Serialize(sw, instance);
            }

        }


     (Link: 使用XMLSerializer类持久化数据 )


5. 如何使用XSD来验证 XML文件合法性:
  
   - 使用XMLSpy,首先Assign XSD,然后验证 (其实就是设置XML里面引用的schema,注意schema可能引用其他的schema)
 
   - 代码中验证:

     #region Validate XML against XSD

    
public class Validator
    
{
        
private string errMsg;

        
/// <summary>
        
/// validation Error Msg
        
/// </summary>

        public string validationErrMsg
        
{
            
get return errMsg; }
            
set { errMsg = value; }
        }

        
       
        
/// <summary>
        
/// Validate XML against schema
        
/// </summary>
        
/// <param name="XSD"></param>
        
/// <param name="XMLFile"></param>
        
/// <param name="LocationDefined"></param>
        
/// <returns></returns>

        public bool Validate(string XSD, string XMLFile, bool LocationDefined)
        
{
            
bool isValid = true;

            
try
            
{
                Stream schemaFile 
= null;

                XmlReaderSettings settings 
= new XmlReaderSettings();
                ValidationEventHandler SchemaValidationEventHandler 
= new ValidationEventHandler(ValidationCallBack);

                settings.ValidationType 
= ValidationType.Schema;
                settings.ValidationFlags 
|= XmlSchemaValidationFlags.AllowXmlAttributes;
                settings.ValidationFlags 
|= XmlSchemaValidationFlags.ReportValidationWarnings;
                settings.ValidationEventHandler 
+= SchemaValidationEventHandler;

                
if (LocationDefined == true)
                
{
                    settings.ValidationFlags 
|= XmlSchemaValidationFlags.ProcessInlineSchema;
                    settings.ValidationFlags 
|= XmlSchemaValidationFlags.ProcessSchemaLocation;
                }

                
else
                
{
                    schemaFile 
= new FileStream(XSD, FileMode.Open);
                    
                    XmlSchema tmsSchema 
= XmlSchema.Read(schemaFile, SchemaValidationEventHandler);

                    settings.Schemas.Add(tmsSchema);
                }


                
using (XmlReader reader = XmlReader.Create(XMLFile, settings))
                
{
                    
string test;

                    
while (reader.Read() && isValid == true)
                    
{
                        test 
= reader.Name;
                    }

                }
;

                
if (schemaFile != null)
                
{
                    schemaFile.Close();
                }

            }

            
catch (Exception e)
            
{
                validationErrMsg 
+= "Exception occured when validating. " + e.Message;

                isValid 
= false;
            }


            
return isValid;
        }


        
/// <summary>
        
/// Display any warnings or errors.
        
/// </summary>
        
/// <param name="sender"></param>
        
/// <param name="args"></param>

        public void ValidationCallBack(object sender, ValidationEventArgs args)
        
{
            
if (args.Severity == XmlSeverityType.Warning)
            
{
                validationErrMsg 
+= "Matching schema not found. No validation occurred." + args.Message;
                validationErrMsg 
= args.Message;
            }

            
else
            
{
                validationErrMsg 
+= "/nValidation error: " + args.Message;

                validationErrMsg 
= args.Message;
            }

        }

    }

    
#endregion
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: 使用 JAXB 生成 Java 实体类需要按照以下步骤进行: 1. 在 pom.xml 中添加 JAXB 的依赖。 ``` <dependencies> <dependency> <groupId>javax.xml.bind</groupId> <artifactId>jaxb-api</artifactId> <version>2.3.1</version> </dependency> </dependencies> ``` 2. 创建一个包含 JAXB 注解的 Java 类。 ``` import javax.xml.bind.annotation.XmlRootElement; @XmlRootElement public class Person { private String name; private int age; // 省略 getter 和 setter 方法 } ``` 3. 使用 JAXB 将 XML 数据映射到 Java 实体类。 ``` import javax.xml.bind.JAXBContext; import javax.xml.bind.Unmarshaller; // 读取 XML 文件 File file = new File("person.xml"); // 创建 JAXBContext 对象 JAXBContext jaxbContext = JAXBContext.newInstance(Person.class); // 创建 Unmarshaller 对象 Unmarshaller unmarshaller = jaxbContext.createUnmarshaller(); // 将 XML 数据转换为 Java 对象 Person person = (Person) unmarshaller.unmarshal(file); // 输出结果 System.out.println(person.getName()); System.out.println(person.getAge()); ``` 4. 使用 JAXB 将 Java 实体类转换为 XML 数据。 ``` import javax.xml.bind.JAXBContext; import javax.xml.bind.Marshaller; // 创建 Person 对象 Person person = new Person(); person.setName("张三"); person.setAge(20); // 创建 JAXBContext 对象 JAXBContext jaxbContext = JAXBContext.newInstance(Person.class); // 创建 Marshaller 对象 Marshaller marshaller = jaxbContext.createMarshaller(); // 将 Java 对象转换为 XML 数据 marshaller.marshal(person, new File("person.xml ### 回答2: Java中,JAXB(Java Architecture for XML Binding)是一种用于将XML数据与Java对象进行绑定的技术。JAXB可以根据给定的XML数据自动生成Java实体类的内容。 在使用JAXB时,我们需要先编写一个XSDXML Schema Definition)文件,XSD文件定义了XML数据的结构和规则。然后,我们可以使用JAXB提供的工具XSD文件转换为Java类。 首先,我们需要导入JAXB相关的包,例如javax.xml.bind.annotation和javax.xml.bind.annotation.adapters等。 然后,我们可以使用JAXB提供的注解来进行定义。比如,使用@XmlRootElement注解来指定根元素,使用@XmlElement注解来指定元素,使用@XmlAttribute注解来指定属性等。 接下来,我们可以使用JAXB提供的工具生成Java类。可以通过命令行的方式执行xjc命令,将XSD文件转换为Java类,也可以通过IDE工具中的插件或者菜单来完成这个过程。 生成的Java类将包含与XML数据对应的字段和方法。我们可以通过调用相关的getter和setter方法来访问和修改这些字段的值。 此外,JAXB还提供了一些其他的功能,例如将Java对象序列化成XML数据、将XML数据反序列化为Java对象等。 总之,使用JAXB可以根据给定的XML数据自动生成相应的Java实体类内容,使得XML数据与Java对象之间的转换更加方便和简洁。 ### 回答3: Java使用JAXB可以根据XML数据自动生成实体类内容。JAXB是Java架构用于处理Java与XML之间的数据绑定和序列化的技术。使用JAXB可以根据XML的结构自动生成相应的Java类,从而方便地在程序中使用XML数据。 在使用JAXB时,首先需要定义一个XML模式文档(XML Schema),该文档描述了XML数据的结构和约束。然后,使用JAXB提供的工具生成Java类。通过运行JAXB命令行工具或者使用maven插件,可以将XML模式文档转换为Java类。 生成的Java类会根据XML的结构生成对应的属性(与XML元素对应),并提供相应的访问方法。同时,JAXB还可以根据XML中的属性生成对应的Java注解,进一步增强生成的Java类的功能。 使用JAXB生成实体类可以方便地进行XML与Java对象之间的互相转换,通过调用JAXB提供的方法,可以将XML数据转换为Java对象,或将Java对象转换为XML数据。在转换过程中,JAXB会自动完成对象属性与XML元素或属性之间的映射,无需开发人员手动解析XML数据。 总之,JAXB是一个强大的工具,可以根据XML数据自动生成实体类内容,简化了Java与XML之间的数据绑定和序列化任务。使用JAXB可以减少在处理XML数据时的开发工作量,提高代码的可读性和可维护性。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值