XML文档的基本操作

已知有一个XML文档(bookstore.xml)如下:

<?xml version="1.0" encoding="gb2312"?>
<bookstore>
<book genre="fantasy" ISBN="2-3631-4">
<title>Oberons Legacy</title>
<author>Corets, Eva</author>
<price>5.95</price>
</book>
</bookstore>

1、往<bookstore>节点中插入一个<book>节点:

XmlDocument xmlDoc=new XmlDocument();
xmlDoc.Load("bookstore.xml");
XmlNode root=xmlDoc.SelectSingleNode("bookstore");//查找<bookstore>
XmlElement xe1=xmlDoc.CreateElement("book");//创建一个<book>节点
xe1.SetAttribute("genre","李赞红");//配置该节点genre属性
xe1.SetAttribute("ISBN","2-3631-4");//配置该节点ISBN属性

XmlElement xesub1=xmlDoc.CreateElement("title");
xesub1.InnerText="CS从入门到精通";//配置文本节点
xe1.AppendChild(xesub1);//添加到<book>节点中
XmlElement xesub2=xmlDoc.CreateElement("author");
xesub2.InnerText="候捷";
xe1.AppendChild(xesub2);
XmlElement xesub3=xmlDoc.CreateElement("price");
xesub3.InnerText="58.3";
xe1.AppendChild(xesub3);

root.AppendChild(xe1);//添加到<bookstore>节点中
xmlDoc.Save("bookstore.xml");


//================
结果为:

<?xml version="1.0" encoding="gb2312"?>
<bookstore>
<book genre="fantasy" ISBN="2-3631-4">
<title>Oberons Legacy</title>
<author>Corets, Eva</author>
<price>5.95</price>
</book>
<book genre="李赞红" ISBN="2-3631-4">
<title>CS从入门到精通</title>
<author>候捷</author>
<price>58.3</price>
</book>
</bookstore>

2、修改节点:将genre属性值为“李赞红“的节点的genre值改为“update李赞红”,将该节点的子节点<author>

的文本修改为“亚胜”。

XmlNodeList nodeList=xmlDoc.SelectSingleNode("bookstore").ChildNodes;//获取bookstore节点的任何子节


foreach(XmlNode xn in nodeList)//遍历任何子节点
{
XmlElement xe=(XmlElement)xn;//将子节点类型转换为XmlElement类型
if(xe.GetAttribute("genre")=="李赞红")//假如genre属性值为“李赞红”
{
xe.SetAttribute("genre","update李赞红");//则修改该属性为“update李赞红”

XmlNodeList nls=xe.ChildNodes;//继续获取xe子节点的任何子节点
foreach(XmlNode xn1 in nls)//遍历
{
XmlElement xe2=(XmlElement)xn1;//转换类型
if(xe2.Name=="author")//假如找到
{
xe2.InnerText="亚胜";//则修改
break;//找到退出来就能够了
}
}
break;
}
}

xmlDoc.Save("bookstore.xml");//保存。

//=================

最后结果为:

<?xml version="1.0" encoding="gb2312"?>
<bookstore>
<book genre="fantasy" ISBN="2-3631-4">
<title>Oberons Legacy</title>
<author>Corets, Eva</author>
<price>5.95</price>
</book>
<book genre="update李赞红" ISBN="2-3631-4">
<title>CS从入门到精通</title>
<author>亚胜</author>
<price>58.3</price>
</book>
</bookstore>

3、删除 <book genre="fantasy" ISBN="2-3631-4">节点的genre属性,删除 <book genre="update李赞红"

ISBN="2-3631-4">节点。

XmlNodeList xnl=xmlDoc.SelectSingleNode("bookstore").ChildNodes;

foreach(XmlNode xn in xnl)
{
XmlElement xe=(XmlElement)xn;

if(xe.GetAttribute("genre")=="fantasy")
{
xe.RemoveAttribute("genre");//删除genre属性
}
else if(xe.GetAttribute("genre")=="update李赞红")
{
xe.RemoveAll();//删除该节点的全部内容
}
}
xmlDoc.Save("bookstore.xml");

//====================

最后结果为:

<?xml version="1.0" encoding="gb2312"?>
<bookstore>
<book ISBN="2-3631-4">
<title>Oberons Legacy</title>
<author>Corets, Eva</author>
<price>5.95</price>
</book>
<book>
</book>
</bookstore>

4、显示任何数据。


XmlNode xn=xmlDoc.SelectSingleNode("bookstore");

XmlNodeList xnl=xn.ChildNodes;

foreach(XmlNode xnf in xnl)
{
XmlElement xe=(XmlElement)xnf;
Console.WriteLine(xe.GetAttribute("genre"));//显示属性值
Console.WriteLine(xe.GetAttribute("ISBN"));

XmlNodeList xnf1=xe.ChildNodes;
foreach(XmlNode xn2 in xnf1)
{
Console.WriteLine(xn2.InnerText);//显示子节点点文本
}
}

public static string DataToXml(string _ip,string _xmlType,bool _issavexml,string

_contenttype,string _message,string _sendtime,string _toip)
        {
            //return null;
            DataParser dp = new DataParser();
            dp.Message = _message;
            dp.IP = _ip;
            dp.XmlType = _xmlType;
            dp.isSaveXml = _issavexml;
            dp.ContentType = _contenttype;
            dp.Sendtime = _sendtime;
            dp.Toip = _toip;
            XmlDocument doc = new XmlDocument();
            XmlDeclaration newDec = doc.CreateXmlDeclaration("1.0",null,null);
            doc.AppendChild(newDec);
            XmlElement newRoot = doc.CreateElement("Requests");
            doc.AppendChild(newRoot);
            XmlElement newtitle = doc.CreateElement("Request");
            newtitle.SetAttribute("time", dp.Sendtime);
            newRoot.AppendChild(newtitle);
            XmlElement from = doc.CreateElement("from");
            from.SetAttribute("ip", dp.IP);
            from.SetAttribute("type", dp.XmlType);
            from.SetAttribute("ctntype", dp.ContentType);
            XmlNode xnfrom = doc.CreateNode(XmlNodeType.CDATA, "content", null);
            xnfrom.InnerText = _message;
            from.PrependChild(xnfrom);
          // from.InnerText = _message;
            newtitle.AppendChild(from);
            XmlElement to = doc.CreateElement("to");
            (to as XmlElement).SetAttribute("ip", dp.Toip);
            newtitle.AppendChild(to);
            return doc.OuterXml;
        }

        /// <summary>
        /// 数据解包
        /// 将xml解析成UserConnection对象
        /// </summary>
        /// <returns>UserConnection</returns>
        public static DataParser[] XmlToData(string outxml)
        {
            //return null;
            DataParser[] dp = null;
            try
            {
                XmlDocument doc = new XmlDocument();
                doc.LoadXml(outxml);
                XmlNode rootnode = doc.SelectSingleNode("Requests");
                XmlNodeList bodynodelist = rootnode.SelectNodes("Request");
                dp = new DataParser[bodynodelist.Count];
                foreach (XmlNode sn in bodynodelist)
                {
                    int i = 0;
                    XmlElement xe = (XmlElement)sn;
                    XmlNode xn = sn.SelectSingleNode("from");
                    dp[i] = new DataParser();
                    dp[i].IP = (xn as XmlElement).Attributes["ip"].Value;
                   
                  // dp[i].IP = (xn as XmlElement).GetAttribute("ip");
                    dp[i].Message = xn.InnerText;
                    dp[i].ContentType = (xn as XmlElement).Attributes["ctntype"].Value;
                    dp[i].XmlType = (xn as XmlElement).Attributes["type"].Value;
                    dp[i].Sendtime = (sn as XmlElement).Attributes["time"].Value;
                    XmlNode xn2 = sn.SelectSingleNode("to");
                    dp[i].Toip = (xn2 as XmlElement).Attributes["ip"].Value;
                    i++;

                }


            }
            catch (Exception err)
            {
                ChatCommon.Common.ExceptionHand.HandleErr(err.ToString());
            }
            return dp;
        }

 

using System;
using System.Collections.Generic;
using System.Text;
using System.Xml;
namespace XmlDOM
{
    class Program
    {
        static void Main(string[] args)
        {
            XmlDocument doc = new XmlDocument();
            XmlDeclaration xd = doc.CreateXmlDeclaration("1.0", null, null);
            doc.AppendChild(xd);
            XmlElement xe = doc.CreateElement("bookstore");
            doc.AppendChild(xe);
            XmlElement xr = doc.CreateElement("book");
            xr.SetAttribute("publish", "thinkbank+1");
            xr.InnerText = "c#基础";
            xe.AppendChild(xr);
            XmlElement xr2 = doc.CreateElement("book");
            xr2.SetAttribute("publish", "thinkbank+1");
            xr2.InnerText = "j#基础";
            xe.AppendChild(xr2);
            string xml = doc.OuterXml;
            XmlDocument doc2 = new XmlDocument();
            doc2.LoadXml(xml);
            //doc.Save(@"d:/33.xml");
            //XmlDocument doc = new XmlDocument();
            //doc.Load(@"d:/33.xml");
            XmlNode xn = doc.SelectSingleNode("bookstore");
            XmlNodeList xnlist = doc2.SelectNodes("//book");
            foreach (XmlNode mynode in xnlist)
            {
                Console.WriteLine(mynode.InnerText);
            }
          
        }
    }
}

 

XPath 应用:


XML 文档对象模型 (DOM)
能够以编程方式读取、处理和修改 XML 文档。

XPath 表达式
XPath 表达式使用路径表示法(与 URL 中使用的路径表示法类似)寻址 XML 文档的各个部分。表达式计算为生

成子元素集、布尔值、数字或字符串类型的对象。

URL与XPath 表达式比较
URL: 由文件系统中的文件夹和文件组成的层次结构。
每个级别具有唯一名称的文件。URL 总是标识单个文件。
相对特定文件夹(称为“当前文件夹”)进行计算。
XPath: 由 XML 文档中的元素和其他元素组成的层次结构。
每个级别的元素名可能不是唯一的。XPath 表达式标识所有匹配的元素集。
相对特定元素(称为表达式的“上下文”)进行计算。

基本 XPath 表达式 (判断是谁的集合!!)
1.当前上下文
   以句点和正斜杠 (./) 作为前缀的表达式明确使用当前上下文作为上下文。例如,以下表达式引用当前上下文

中的所有 <author> 元素:
    ./author
   注意,此表达式等效于以下表达式:
    author

2.文档根
   以正斜杠 (/) 为前缀的表达式使用文档树的根作为上下文。例如,以下表达式引用此文档根的 <bookstore>

元素:
    /bookstore
3.根元素
   使用正斜杠后接星号 (/*) 的表达式将使用根元素作为上下文。例如,以下表达式查找文档的根元素:
    /*
4.递归下降
   用双正斜杠 (//) 的表达式指示可以包括零个或多个层次结构级别的搜索。如果此运算符出现在模式的开头,

上下文相对于文档的根。例如,以下表达式引用当前文档中任意位置的所有 <author> 元素:
    //author
   .// 前缀指示上下文从层次结构中当前上下文所指示的级别开始。
5.特定元素
   以元素名开头的表达式引用特定元素的查询,从当前上下文节点开始。例如,以下表达式引用当前上下文节点

中 <images> 元素内的 <background.jpg> 元素:
    images/background.jpg
   以下表达式引用当前上下文节点中 <bookstore> 元素内的 <book> 元素的集合:
    bookstore/book
   以下表达式引用当前上下文节点中的所有 <first.name> 元素:
    first.name
XPath 表达式是使用下表中所示的运算符和特殊字符构造的。
运算符和特殊字符:
/ 子运算符;选择左侧集合的直接子级。此路径运算符出现在模式开头时,表示应从根节点选择该子级。
// 递归下降;在任意深度搜索指定元素。此路径运算符出现在模式开头时,表示应从根节点递归下降。
. 指示当前上下文。
.. 当前上下文节点的父级。
* 通配符;选择所有元素,与元素名无关。
@ 属性;属性名的前缀。
@* 属性通配符;选择所有属性,与名称无关。
: 命名空间分隔符;将命名空间前缀与元素名或属性名分隔。
( ) 为运算分组,明确设置优先级。
[ ] 应用筛选模式。
[ ] 下标运算符;用于在集合中编制索引。
+ 执行加法。
- 执行减法。
div 根据 IEEE 754 执行浮点除法。
* 执行乘法。
mod 从截断除法返回余数。

优先级   字符   用途
1   ( )   分组
2   [ ]   筛选器
3   / //   路径运算

分组运算符()仅适用于顶级路径表达式。
例如:
   (//author/degree | //author/name) 是有效的分组运算
   //author/(degree | name) 不是有效的分组运算
筛选模式运算符 [] 的优先级高于路径运算符(/ 和 //)。
例如:
   //comment()[3]
   选择相对于文档中任意位置comment的父级索引等于3的所有comment,可以返回多个备注

   (//comment())[3]
   选择相对于父级的所有comment集中的第三个comment,只能返回一个备注。

   author/first-name
   当前上下文节点的 <author> 元素中的所有 <first-name> 元素。

   bookstore//title
   <bookstore> 元素中更深的一级或多级(任意子代)的所有 <title> 元素。注意,此表达式与以下模式

bookstore/*/title 不同。

   bookstore/*/title
   属于 <bookstore> 元素的孙级的所有 <title> 元素。

   bookstore//book/excerpt//emph
   <book> 元素的 <excerpt> 子级中的任意位置和 <bookstore> 元素中的任意位置的所有 <emph> 元素:

   .//title
   当前上下文中更深的一级或多级的所有 <title> 元素。注意,本质上只有这种情况需要句点表示法。
通配符
通过使用通配符 * 集合,不使用元素名即可引用元素。* 集合引用作为当前上下文的子级的所有元素,与名称无

关。
例如:
   author/*
   <author> 元素的所有元素子级。

   book/*/last-name
   所有作为 <book> 元素的孙级的 <last–name> 元素。

   */*
   当前上下文的所有孙级元素。

   my:book
   my 命名空间中的 <book> 元素。

   my:*
   my 命名空间中的所有元素。
属性
XPath 使用 @ 符号表示属性名。属性和子元素应公平对待,两种类型之间的功能应尽可能相当。
例如:
   @style
   当前元素上下文的 style 属性。

price/@exchange
   当前上下文中 <price> 元素的 exchange 属性。
  
   book/@style
    所有 <book> 元素的 style 属性。
  
    @*
    当前上下文节点的所有属性。
  
    @my:*
    my 命名空间中的所有属性。不包括 my 命名空间中的元素的未限定属性。
  
   注意:
    属性不能包含子元素,所以,如果对属性应用路径运算符,将出现语法错误。此外,不能对属性应用索引,

因为根据定义,不为属性定义任何顺序。
   price/@exchange/total
比较
运算符:

   and   逻辑与
   or   逻辑或
   not()   非
   =   相等
   !=   不相等
   &lt;   小于
   &lt;=   小于或等于
   &gt;   大于
   &lt;=   大于或等于
   |   集运算;返回两个节点集的联合


例如:
   author[last-name = "Bob"]
   至少包含一个值为 Bob 的 <last-name> 元素的所有 <author> 元素。

   author[last-name[1] = "Bob"]
   第一个 <last-name> 子元素的值为 Bob 的所有 <author> 元素。

   author/degree[@from != "Harvard"]
   包含 from 属性不等于 "Harvard" 的 <degree> 元素的所有 <author> 元素。

   author[last-name = /editor/last-name]
   包含与根元素下 <editor> 元素中的 <last-name> 元素相同的 <last-name> 元素的所有 <author> 元素。

   author[. = "Matthew Bob"]
   所有字符串值为 Matthew Bob 的 <author> 元素。
集运算
Union (|) 运算符
|(即 union)运算符返回两个操作数的联合,操作数必须是节点集。例如,//author | //publisher 返回的节

点集结合了所有 //author 节点和所有 //publisher 节点。


例如:
   first-name | last-name
   包含当前上下文中的 <first-name> 和 <last-name> 元素的节点集。

   (bookstore/book | bookstore/magazine)
   包含 <bookstore> 元素中的 <book> 或 <magazine> 元素的节点集。

   book | book/author
    包含 <book> 元素中的所有 <book> 元素和所有 <author> 元素的节点集。

   (book | magazine)/price
    包含 <book> 或 <magazine> 元素的所有 <price> 元素的节点集。


筛选器和筛选模式

通过将筛选子句 [pattern] 添加到集合中,可以对任何集合应用约束和分支。筛选器类似于 SQL WHERE 子句。

筛选器中包含的模式称为“筛选模式”。

例如:
   book[excerpt]
   至少包含一个 <excerpt> 元素的所有 <book> 元素。

   book[excerpt]/title
   至少包含一个 <excerpt> 元素的 <book> 元素内的所有 <title> 元素。

   book[excerpt]/author[degree]
   至少包含一个 <degree> 元素并且在至少包含一个 <excerpt> 元素的 <book> 元素内的所有 <author> 元素

   book[author/degree]
   至少包含一个 <author> 元素并且该元素至少包含一个 <degree> 子元素的 <book> 所有元素。

   book[excerpt][title]
   至少包含一个 <excerpt> 元素以及至少包含一个 <title> 元素的 <book> 所有元素。

转载于:https://www.cnblogs.com/wzglweb/articles/1389923.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/435948.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

delphi 发送html邮件,delphi发送html带附件邮件

varhtml: TIdText;beginif not SMTP.Connected thenSMTP.Disconnect();trySMTP.Connect;tryif SMTP.Authenticate then //验证beginEMessage.Recipients.EMailAddresses : FUser;EMessage.ClearBody;//清空正文html: TIdText.Create(EMessage.MessageParts);EMessage.Subject:N…

【转】DICOM:DICOM三大开源库对比分析之“数据加载”

背景&#xff1a; 上一篇博文DICOM&#xff1a;DICOM万能编辑工具之Sante DICOM Editor介绍了DICOM万能编辑工具&#xff0c;在日常使用过程中发现&#xff0c;“只要Sante DICOM Editor打不开的数据&#xff0c;基本可以判定此DICOM文件格式错误&#xff08;准确率达99.9999%…

wince Hive注册表实现机制

WinCE下的注册表可以分为两种&#xff0c;一种是RAM based&#xff0c;另外一种是HIVE based了.这要根据你在PB里添加的是哪种配置. 用PB向导新建的WinCE工程文件默认会用RAM based. Hive 注册表可以实现掉电不丢失数据.那它是如何实现这种机制的呢. RAM based 注册表因为是把信…

html中点击照片时放大缩小,基于jquery实现一张图片点击鼠标放大再点缩小

. 代码如下:var isopen false;var newImg;var w 200; //将图片宽度200var h 200; // 将图片高度 200$(document).ready(function(){$("img").bind("click", function(){newImg this;if (!isopen){isopen true;$(this).width($(this).width() w);$(th…

css入门之head区设置

收藏夹小图标 如果你将本站加入收藏夹&#xff0c;可以看到在收藏夹网址之前的IE图标变成了本站特别的图标。要实现这样效果很简单&#xff0c;首先制作一个16x16的icon图标&#xff0c;命名为favicon.ico&#xff0c;放在根目录下。然后将下面的代码嵌入head区&#xff1a; &l…

初识WINCE的HIVE注册表

要点&#xff1a;1、WINCE5.0的注册表共分为两类&#xff0d;&#xff0d;RAM based及HIVE based&#xff1b;2、RAM based注册表特点是在内核启动时&#xff0c;被释放到内存&#xff0c;用户可以修改&#xff0c;但由于是基于内存的方式&#xff0c;所以在系统掉电后&#xf…

【转】Dicom基础知识

DICOM 文件可以大致分为两部分&#xff1a; 一部分&#xff1a;与 图像 相关 的 元 信息 &#xff0c;包括患者信息&#xff0c;检查信息&#xff0c;序列信息&#xff0c;图像信息等等。 另一部分&#xff1a;图像的像素数据。 在解析DICOM文件中的像素数据的时候&#xff0c;…

04751计算机网络安全讲解,【19份】04751计算机网络安全自考试卷_历年真题自考答案及解析_湖南080901计算机科学与技术(原B080702计算机及应用)专业-自考生资料网...

1、资料如何使用本商城提供资料为WORD版&#xff0c;可打印成纸质版&#xff0c;结合备考习惯&#xff0c;营造考试氛围。支持手机查看&#xff0c;随时随地&#xff0c;高效学习。WORD文档也可直接用于电脑端学习&#xff0c;快速浏览&#xff0c;永久使用。2、文档无法编辑&a…

湖北省汉十高速公路项目接近尾声,所想所感真的值得写写

湖北省汉十高速公路的项目是我接的第一个B/S结构的软件项目&#xff0c;总体感觉吧&#xff1a;有点粗糙。虽然基本功能已经实现。想来不经意的来了一个公司竟然还能做一个这样的项目。前前后后2个月的开发周期&#xff0c;也让我感到做此类项目&#xff0c;需要你的技术点很多…

WINCE恢复默认HIVE注册表的方法

当Wince使用了HIVE注册表后&#xff0c;每次用户的注册表改动将得到保存&#xff0c;但是在某些应用场合需要将注册表还原成为出厂的默认设置&#xff0c;通常要求能够在AP中通过点击一个按钮来实现这种clean boot。使用我前面的文章的方法配置的HIVE系统注册表和HIVE用户注册表…

【转】DICOM协议新手入门资料-DICOM协议详细解释!!

转自&#xff1a;https://blog.csdn.net/zhuwei0710/article/details/82620036 数字影像传输标准协议的初衷&#xff0c;是为了在不同厂商生产的数字影像设备之间实现影像及其附属信息的调用。这个标准的最初版本是所谓ACR&#xff08;美国放射学会&#xff09;-NEMA&#xff…

博士期间要注意的几个问题

博士期间要注意的几个问题 读博士是一件非常艰苦和漫长的过程&#xff0c;相信在经历了博士期间的洗礼&#xff0c;一个人的思想会得到升华&#xff0c;视野会得到拓宽&#xff0c;人生会更加充实和丰富&#xff0c;为以后的人生打好了坚实的基础&#xff01; 在博士期间&#…

html设置页面编码gbk,GBK及UTF-8网页编码定义与应用

网页编码英文译为web page encoding&#xff0c;是在网页中指定其特定的字符编码格式的库。GBK是国家标准GB2312基础上扩容后兼容GB2312的标准。GBK的文字编码是用双字节来表示的&#xff0c;即不论中、英文字符均使用双字节来表示&#xff0c;为了区分中文&#xff0c;将其最高…

VxWorks常用的命令

1&#xff0e;与任务相关的命令 sp function,[arg1],...,[arg9] &#xff0d;启动任务&#xff0c;最多接受9个参数&#xff0c;默认的优先级100、堆栈20000字节 period n,function,[arg1],...,[arg8] &#xff0d;创建一个周期调用function的任务&#xff0c;周期为n秒&#x…

【转】Wireshark网络抓包(三)——网络协议

转自&#xff1a;https://www.cnblogs.com/strick/p/6262284.html 一、ARP协议 ARP&#xff08;Address Resolution Protocol&#xff09;地址解析协议&#xff0c;将IP地址解析成MAC地址。 IP地址在OSI模型第三层&#xff0c;MAC地址在OSI第二层&#xff0c;彼此不直接通信…

jquery技巧总结-转载

jquery技巧总结一、简介1.1、概述随着WEB2.0及ajax思想在互联网上的快速发展传播&#xff0c;陆续出现了一些优 秀的Js框架&#xff0c;其中比较著名的有Prototype、YUI、jQuery、mootools、Bindows以及国内的JSVM框架等&#xff0c;通过将这些JS 框架应用到我们的项目中能够使…

川农计算机网络题库,川农网院20秋《计算机网络》期末机考

《计算机网络》期末机考, j9 g5 q- D# p w1.[单选题] 般在10M或100M局域网中&#xff0c;至少要用双绞线多少蕊( ) p2 N: n5 g d A.6) p. a5 B& d2 Z7 l B.104 ^5 l$ 0 C" j& L f# \& " \1 Y C.8, |6 j: y) F2 }; }$ kD.43 o I U$ S0 ) c/ |;…

Vxworks系统学习之一----任务

1.任务队列 vxworks维护4个队列&#xff1a; tick队列 ready队列 active队列 pend队列 一&#xff0c;tick队列 当执行taskDelay时&#xff0c;任务会被延长一段时间执行&#xff0c;此时&#xff0c;任务就会被加入到tick队列中&#xff0c;任务处于Delay状态&#xff…

【转】Wireshark网络抓包(四)——工具

转自&#xff1a;https://www.cnblogs.com/strick/p/6344486.html 一、基本信息统计工具 1&#xff09;捕获文件属性&#xff08;Summary&#xff09; 1. File&#xff1a;了解抓包文件的各种属性&#xff0c;例如抓包文件的名称、路径、文件所含数据包的规模等信息 2. Tim…

silverlight + wcf(json格式) + sqlserver存储过程分页

silverlight并没有提供现成的分页控件&#xff0c;百度了一圈&#xff0c;也没有发现aspx中好用的类似AspNetPager成熟控件&#xff0c;网上现有的一些分页代码&#xff0c;很多也是基于1.0版本的&#xff0c;silverlight2.0的并不多&#xff0c;自个儿琢磨了一下&#xff0c;发…