解析http://219.142.81.86/igserver/ogc/kvp/TAS10R52000J49/WMTSServer服务的元数据

// 测试httpWebRequest读取 wmts元数据
string address = "http://219.142.81.86/igserver/ogc/kvp/TAS10R52000J49/WMTSServer";
var request = (HttpWebRequest)WebRequest.Create(address);
var response = (HttpWebResponse)request.GetResponse();
var stream = response.GetResponseStream();

if (stream == null) return;

var xmlReader = new XmlTextReader(stream);
var xmlDocument = new XmlDocument();
xmlDocument.Load(xmlReader);

string namespace_uri = xmlDocument.DocumentElement.NamespaceURI;
var nsmgr = new XmlNamespaceManager(xmlDocument.NameTable);
nsmgr.AddNamespace("wmts", namespace_uri);

XmlNode node = xmlDocument.SelectSingleNode("//wmts:Layer", nsmgr);
if (node == null)    return;        
string LowerCorner, UpperCorner;
// 得到layer节点的所有子节点
XmlNodeList xnl = node.ChildNodes;

double west = 0;
double east = 0;
double south = 0;
double north = 0;
foreach (XmlNode xn1 in xnl)
 {
  if (xn1.Name == "ows:BoundingBox" || xn1.Name == "ows:WGS84BoundingBox")
  {
            XmlElement xe = (XmlElement)xn1;
            //得到crs属性
            string crs = xe.GetAttribute("crs").ToString();

// 得到BoundBox节点的所有子节点                   
            XmlNodeList xn10 = xn1.ChildNodes;
            LowerCorner = xn10.Item(0).InnerText;
            UpperCorner = xn10.Item(1).InnerText;
            string[] cc = LowerCorner.Split(' ');
            west = Convert.ToDouble(cc[0]);
            south = Convert.ToDouble(cc[1]);
            string[] uu = UpperCorner.Split(' ');
            east = Convert.ToDouble(uu[0]);
            north = Convert.ToDouble(uu[1]);
  }                
       // 将节点转换为元素,便于得到节点的属性值
       //XmlElement xe = (XmlElement)xn1;
       // 得到Type和ISBN两个属性的属性值
       //string type = xe.GetAttribute("ows:Type").ToString();   //<book Type="必修课" ISBN="7-111-19149-2">
}

XmlNodeList nodes = xmlDocument.SelectNodes("//wmts:TileMatrixSet", nsmgr);
            if (nodes.Count <= 0) return;

Dictionary<int, _tileMatrix> tileMatrixSet = new Dictionary<int,_tileMatrix>();  
            int minLevel = 9999;
            int maxLevel = -9999;
            
            foreach (XmlNode xn1 in nodes)
            {
                if (xn1.ParentNode == null || xn1.ParentNode.Name != "Contents")
                    continue;
                
                XmlNodeList xn11 = xn1.ChildNodes;
                foreach (XmlNode xn110 in xn11)
                {
                    if (xn110.Name == "TileMatrix")
                    {
                        XmlNodeList xn10 = xn110.ChildNodes;
                        string strlevel = xn10.Item(0).InnerText;
                        string[] temp = strlevel.Split(':');
                        int cn = temp.Count();
                        int level = 0;
                        if (cn == 1)
                            level = Convert.ToInt32(temp[0]);
                        else
                            level = Convert.ToInt32(temp[cn-1]);
                        
                        double ScaleDenominator = Convert.ToDouble(xn10.Item(1).InnerText);
                        string[] TopLeftCorner = xn10.Item(2).InnerText.Split(' ');
                        double top = Convert.ToDouble(TopLeftCorner[0]);
                        double left = Convert.ToDouble(TopLeftCorner[1]);
                        int TileWidth = Convert.ToInt32(xn10.Item(3).InnerText);
                        int TileHeight = Convert.ToInt32(xn10.Item(4).InnerText);
                        int cols = Convert.ToInt32(xn10.Item(5).InnerText);
                        int rows = Convert.ToInt32(xn10.Item(6).InnerText);

_tileMatrix ts = new _tileMatrix();
                        ts.level = level;
                        ts.cornerTop = top;
                        ts.cornerLeft = level;
                        ts.tileWidth = TileWidth;
                        ts.tileHeight = TileHeight;
                        ts.tileCols = cols;
                        ts.tileRows = rows;
                        tileMatrixSet.Add(level, ts);

minLevel = Math.Min(minLevel, level);
                        maxLevel = Math.Max(maxLevel, level);
                    }
                }                 
            }
          
            xmlReader.Close();

使用C# + httpWebRequest 解析WMTS服务元数据的更多相关文章

  1. WMTS服务解析

    WMTS服务解析 1.基本思路 拼接地址,请求xml文件 ↓ 处理获取的xml文件,返回参数 ↓ 获取xml解析得到的参数,组织结构 2.对应函数 requestWMTS (olUrl) ↓ hand ...

  2. 使用C++/libCurl/Jsoncpp读取arcgis wmts 服务(restful模式)

    前言: 最近工作需要将arcgis的wmts服务接入我们的3DGis系统平台,要求用户只输入一个rest模式的wmts服务地址,系统即可自动获取并解析其元数据信息,生成wmts图层,并渲染显示.经过多 ...

  3. WCF分布式开发步步为赢(3)WCF服务元数据交换、配置及编程开发

    今天我们继续WCF分布式开发步步为赢(3)WCF服务元数据交换.配置及编程开发的学习.经过前面两节的学习,我们了解WCF分布式开发的相关的基本的概念和自定义宿主托管服务的完整的开发和配置过程.今天我们 ...

  4. WCF之服务元数据

    服务元数据是用来获得服务的EndPoint的信息,也就是它的ABC. 服务有两种方案可以发布自己的元数据. 一种是基于HTTP-GET协议提供元数据: 一种是元数据交换方式,它往往使用一个专门的终结点 ...

  5. ajax调用handler,使用HttpWebRequest访问WCF服务

    引言 随着手机及移动设备的普及,移动端的应用也进入了热潮.以前PC端的门户网站,大多也均推出了适配移动设备的网站或者APP,再差的也注册了个公众号.在移动应用开发中,目前据我所了解到的解决方案有:1. ...

  6. Netty 4源码解析:服务端启动

    Netty 4源码解析:服务端启动 1.基础知识 1.1 Netty 4示例 因为Netty 5还处于测试版,所以选择了目前比较稳定的Netty 4作为学习对象.而且5.0的变化也不像4.0这么大,好 ...

  7. 超图不支持JPEG格式的WMTS服务

    就目前面而言,超图不支持JPEG格式的WMTS服务,只支持PNG格式的. <本篇完>

  8. 如何在Skyline中加载ArcGISServer发布的WMS和WMTS服务

    如何在Skyline中加载ArcGISServer发布的WMS和WMTS服务? 我这里的测试环境是ArcGISServer10.1和TerraExplorer Pro7.0,主要过程截图如下,

  9. (二十)ArcGIS JS 加载WMTS服务(超图示例)

    前言 在前一篇中说到我们可以通过加载WMS服务解决用ArcGIS API加载超图发布的服务,但是WMS服务在加载效率上是低于切片服务的,加上超图的IServer,无力吐槽,所以,在加载速度的要求下,切 ...

随机推荐

  1. 一次压力测试Loadrunner经验分享

    一次压力测试Loadrunner经验分享 http://blog.csdn.net/lxlmj/article/category/553431 loadrunner测试socketstcpserver ...

  2. sql获取的时间不能直接在c#中tostring成我们要的格式,要转化一下

    DateTime.Parse(Model.Rows[0]["datevalidbegin"].ToString()).ToString("yyyy-MM-dd" ...

  3. 修改MySQL事件

    MySQL允许您更改现有事件的各种属性. 要更改现有事件,请使用ALTER EVENT语句,如下所示: ALTER EVENT event_name ON SCHEDULE schedule ON C ...

  4. 【转】关于Vue打包的一个要注意的地方

    https://www.jianshu.com/p/4118e76d684a 我们用vue-cli(脚手架)自动生成项目,然后用webpack来打包,往往会遇到这种问题: 1.直接根据README.m ...

  5. STL容器 -- Bitset

    核心内容:Bitset 是 STL 中的二进制容器, 存放的时 bit 位元素, 每一位只占一个 bit 位, 取值 0 或者 1, 可以像整形元素一样按位与或非, 并且大大优化了时间和空间复杂度. ...

  6. struts2和1的区别

    先大致介绍下struts1和struts2 struts:过去最流行的web MVC组件,apache项目组的一个开源项目. struts2:现在非常流行的web MVC组件,是apache用stru ...

  7. Process Explorer常用操作介绍

    (未获得作者本人同意,严禁转载) Process Explorer出现的背景 Process Explorer可以看成是一个加强版的任务管理器.在较早的Windows版本中,任务管理器提供的功能是非常 ...

  8. [BZOJ3203][SDOI2013]保护出题人(凸包+三分)

    https://www.cnblogs.com/Skyminer/p/6435544.html 先不要急于转化成几何模型,先把式子化到底再对应到几何图形中去. #include<cstdio&g ...

  9. 求矩阵中各列数字的和 Exercise08_01

    import java.util.Scanner; /** * @author 冰樱梦 * 时间:2018年12月 * 题目:求矩阵中各列数字的和 * */ public class Exercise ...

  10. WEB安全扫描器Netsparker推荐给大家

    Netsparker是一款综合型的web应用安全漏洞扫描工具,它分为专业版和免费版,免费版的功能也比较强大. Netsparker与其他综合 性的web应用安全扫描工具相比的一个特点是它能够更好的检测 ...