通过XmlNodeType.ProcessingInstruction属性获取到InfoPath XML文件头信息

简介:

通过InfoPath Form生成的XML文件在文件开头的地方都会附加上一段特定的信息,用于标识该XML文件是由什么版本的InfoPath Form生成的,所对应的XSN模板的存放位置等信息,如下图所示:

20111004_1 那么我们在使用XDocument.Load()方法加载该XML文件之后,如何获取到文件头中相关的节点信息呢?如mso-infoPathSolution。

在XmlNodeType类型中,ProcessingInstruction申明了类似于“<?pi test?>” 的节点,我们可以通过该属性来筛选XML的节点,下面的函数用于找出InfoPath Form XML文件中的文件头信息,并将mso-infoPathSolution节点中的href属性值做修改,将XSN模板的位置修改成别的服务器中对应的位置。

复制代码
 1  ///   <summary>
 2  ///  Replace the reference url with the target server name for each InfoPath xml file.
 3  ///   </summary>
 4  ///   <param name="path"></param>
 5  ///   <param name="targetServer"></param>
 6  public  static  void ReplaceReferenceUrl( string path,  string targetServer)
 7 {
 8      const  string pattern =  " href=\"http://.*?/ "//  Regular expression used for replacing the reference url in the XML files.
 9     DirectoryInfo info =  new DirectoryInfo(path);
10     FileInfo[] files = info.GetFiles( " *.xml ");
11 
12      foreach (FileInfo file  in files)
13     {
14         XDocument document = XDocument.Load(file.FullName);
15         List<XNode> list = document.Nodes().Where(t => t.NodeType == System.Xml.XmlNodeType.ProcessingInstruction).ToList<XNode>();
16          if (list !=  null)
17         {
18              foreach (XNode item  in list)
19             {
20                 XProcessingInstruction tmp = item  as XProcessingInstruction;
21                  if (tmp.Target.Equals( " mso-infoPathSolution "))
22                 {
23                     Regex reg =  new Regex(pattern);
24                     tmp.Data = reg.Replace(tmp.Data,  " href=\"http:// " + targetServer +  " / ");
25                     document.Save(file.FullName);
26                      break;
27                 }
28             }
29         }
30     }
31 
32     DirectoryInfo[] direcotries = info.GetDirectories();
33      foreach (DirectoryInfo directory  in direcotries)
34     {
35         ReplaceReferenceUrl(directory.FullName, targetServer);
36     }
复制代码

首先通过拉姆达表达式 找出所有ProcessingInstruction类型的节点,然后使用正则表达式替换href属性的值(注意只替换了其中ServerName的部分)。后面的递归调用表示该方法允许修改指定目录中所有的XML文件。

在SharePoint中,很多地方使用InfoPath Form来收集XML数据文件,当需要批量上传InfoPath XML文件时,修改文件头信息是必要的步骤,通过上面的函数,我们可以很简单地实现这一点!记录一下,以方便日后查阅。 


本文转自Jaxu博客园博客,原文链接:http://www.cnblogs.com/jaxu/archive/2011/10/04/2198752.html,如需转载请自行联系原作者


相关文章
|
1月前
|
XML 前端开发 Java
讲解SSM的xml文件
本文详细介绍了SSM框架中的xml配置文件,包括springMVC.xml和applicationContext.xml,涉及组件扫描、数据源配置、事务管理、MyBatis集成以及Spring MVC的视图解析器配置。
54 1
|
3月前
|
XML Java 数据格式
Spring5入门到实战------7、IOC容器-Bean管理XML方式(外部属性文件)
这篇文章是Spring5框架的实战教程,主要介绍了如何在Spring的IOC容器中通过XML配置方式使用外部属性文件来管理Bean,特别是数据库连接池的配置。文章详细讲解了创建属性文件、引入属性文件到Spring配置、以及如何使用属性占位符来引用属性文件中的值。
Spring5入门到实战------7、IOC容器-Bean管理XML方式(外部属性文件)
|
1天前
|
Java Maven
maven项目的pom.xml文件常用标签使用介绍
第四届人文,智慧教育与服务管理国际学术会议(HWESM 2025) 2025 4th International Conference on Humanities, Wisdom Education and Service Management
30 8
|
1月前
|
XML JavaScript Java
java与XML文件的读写
java与XML文件的读写
23 3
|
1月前
|
XML 存储 数据格式
|
1月前
|
XML 存储 缓存
C#使用XML文件的详解及示例
C#使用XML文件的详解及示例
77 0
|
1月前
|
XML 存储 Web App开发
查看 XML 文件
查看 XML 文件
|
2月前
|
SQL XML Java
mybatis :sqlmapconfig.xml配置 ++++Mapper XML 文件(sql/insert/delete/update/select)(增删改查)用法
当然,这些仅是MyBatis功能的初步介绍。MyBatis还提供了高级特性,如动态SQL、类型处理器、插件等,可以进一步提供对数据库交互的强大支持和灵活性。希望上述内容对您理解MyBatis的基本操作有所帮助。在实际使用中,您可能还需要根据具体的业务要求调整和优化SQL语句和配置。
44 1
|
3月前
|
XML 存储 数据库
XML 中的元素和属性
【8月更文挑战第22天】
51 0
|
5月前
|
XML Java 数据格式
java创建xml文件内容
java创建xml文件内容