使用jdom进行xml解析,网络抓包
最近再做一个项目,使用到了jdom进行xml解析,为了方便记忆,现在保存在这里
package bboss; import java.io.FileInputStream;
import java.io.InputStream;
import java.io.StringReader;
import java.util.HashMap;
import java.util.Iterator;
import java.util.List;
import java.util.Map;
import java.util.Map.Entry; import org.apache.log4j.Logger;
import org.jdom.Document;
import org.jdom.Element;
import org.jdom.input.SAXBuilder;
import org.junit.Test;
import org.xml.sax.InputSource; /**
* @author 吕龙虎
*/
public class ParseSoapXml {
public static Logger logger1 = Logger.getLogger(ParseXMLToListUtil.class); /**
* 报文解析
*
* @param xmlStr
* @param xmlPath
* @return
*/
// 外部调用此方法必须保证xmlPath为空
public static Map<String, String> parseXMlStr(String xmlStr, String xmlPath) {
Map<String, String> dataMap = new HashMap<String, String>();
// 创建一个新的SAXBuilder
System.out.println("-----------------------准备开始解析数据包-------------------------");
if ((xmlStr != null && xmlStr != "") || (xmlPath != null && xmlPath != "")) {
SAXBuilder sb = new SAXBuilder();
logger1.info("------开始解析数据包中报文数据------");
try {
Document doc = null;
if (xmlStr != null && (xmlPath == null || xmlPath == "")) {
// 创建一个新的字符串
StringReader read = new StringReader(xmlStr);
// 创建新的输入源SAX 解析器将使用 InputSource 对象来确定如何读取 XML 输入
InputSource source = new InputSource(read);
// 如果报文格式出错,抛出异常,doc为空
doc = sb.build(source);
} else if ((xmlStr == null || xmlStr == "") && xmlPath != null) {
InputStream source = new FileInputStream(xmlPath);
doc = sb.build(source);
}
// 报文格式出错,doc为空
if (doc != null) {
Element root = doc.getRootElement();// 获取根节点
List<?> list = root.getChildren();// 获取第一个子节点
if (list.size() != 0) {
for (int i = 0; i < list.size(); i++) {
Element el = (Element) list.get(i);
List<?> elist = el.getChildren();// 获取子节点下的节点
if (elist.size() != 0) {
for (int j = 0; j < elist.size(); j++) {
Element elm = (Element) elist.get(j);
List<?> ellist = elm.getChildren();
if (ellist.size() != 0) {
for (int k = 0; k < ellist.size(); k++) {
Element elmt = (Element) ellist.get(k);
logger1.info("节点名:" + elmt.getName() + "节点值:" + elmt.getText());
dataMap.put(elmt.getName(), elmt.getText());// 添加数据至集合里以便比对
}
} else {
logger1.info("节点名:" + elm.getName() + "节点值:" + elm.getText());
dataMap.put(elm.getName(), elm.getText());// 添加数据至集合里以便比对
}
}
} else {
logger1.info("节点名:" + el.getName() + "节点值:" + el.getText());
dataMap.put(el.getName(), el.getText());// 添加数据至集合里以便比对
}
} } else {
dataMap.put(root.getName(), "");
}
// 将解析后的dataMap拿出来准备比对确保xmlPath为空,即保证第一次进入
if (dataMap.size() != 0 && (xmlPath == null || xmlPath == "")) {
compareXml(dataMap);
}
System.out.println("------结束解析数据包中报文数据------");
} else {
if (xmlStr != null && xmlPath == null) {
logger1.info("-----捕获到的报文-----\n" + xmlStr);
System.out.println("------捕获报文有异常------");
} else if (xmlStr == null && xmlPath != null) {
logger1.info("-----原比对报文所在路径-----" + xmlPath);
System.out.println("------比对报文有异常------");
} }
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
} else {
System.out.println("------未捕获到任何数据------");
}
return dataMap;
} /**
* 开始比较
*/
public static void compareXml(Map<String, String> dataMap) {
Map<String, String> caseMap = new HashMap<String, String>();
Iterator<?> it = dataMap.entrySet().iterator();
System.out.println("-----比对数据包开始解析-----");
String xmlPath = null;
while (it.hasNext()) {
Entry<?, ?> entry = (Entry<?, ?>) it.next();
if (entry.getKey().equals("保密")) {
if (entry.getValue().equals("保密")) {
System.out.println("------找到匹配报文“个”------");
xmlPath = "src/xml/个.txt";
caseMap = parseXMlStr(null, xmlPath);
break;
}
else if (entry.getValue().equals("保密")) {
System.out.println("------找到匹配报文“个”------");
xmlPath = "src/xml/个.txt";
caseMap = parseXMlStr(null, xmlPath);
break;
}
else if (entry.getValue().equals("保密")) {
System.out.println("------找到匹配报文“Jqk”------");
xmlPath = "src/xml/Jqk.txt";
caseMap = parseXMlStr(null, xmlPath);
break;
}
else if (entry.getValue().equals("保密")) {
System.out.println("------找到匹配报文“反馈”------");
xmlPath = "src/xml/反馈.txt";
caseMap = parseXMlStr(null, xmlPath);
break;
}
}
/*
* else { xmlPath="src/xml/报文.txt"; caseMap = parseXMlStr(null,xmlPath);
* break; }
*/
/*
* else if(true){ xmlPath="src/xml/报文.txt"; caseMap =
* parseXMlStr(null,xmlPath); } else if(true){ xmlPath="src/xml/Pt";
* caseMap = parseXMlStr(null,xmlPath); }
*/
}
if (caseMap.size() != 0) {
CompareXMLUtil.compareXml(caseMap, dataMap);
} else {
System.out.println("-----找不到与之匹配的数据包类型-----");
}
} @Test
public void testMain() {
String soap = "保密";
parseXMlStr(soap, null);
}
}
由于有保密协议,所以中间涉及到的都为保密状态。
使用jdom进行xml解析,网络抓包的更多相关文章
- CatchPacket网络抓包软件
CatchPacket网络抓包软件 qq 22945088431.技术特点:基于WinPcap库,c# winform2.实现获取机器所有网卡,可任意选择监听3.可以捕获常见网络协议arp dns ...
- python编写网络抓包分析脚本
python编写网络抓包分析脚本 写网络抓包分析脚本,一个称手的sniffer工具是必不可少的,我习惯用Ethereal,简单,易用,基于winpcap的一个开源的软件 Ethereal自带许多协议的 ...
- [转载]Fiddler 解析!抓包抓得好真的可以为所欲为 [一]
说起抓包,很多人以为就是用个工具,简简单单地抓一下就可以了.昨天在面试一个安卓逆向,直接告诉我[抓包没有技术含量].在这里,我必须发一个教程,解析一下抓包神器——Fiddler.Fiddler仅仅是一 ...
- 开源网络抓包与分析框架学习-Packetbeat篇
开源简介packbeat是一个开源的实时网络抓包与分析框架,内置了很多常见的协议捕获及解析,如HTTP.MySQL.Redis等.在实际使用中,通常和Elasticsearch以及kibana联合使用 ...
- 超详细的网络抓包神器 tcpdump 使用指南
原文链接:Tcpdump 示例教程 本文主要内容翻译自<Tcpdump Examples>. tcpdump 是一款强大的网络抓包工具,它使用 libpcap 库来抓取网络数据包,这个库在 ...
- 网络抓包wireshark(转)
转自 网络抓包wireshark 抓包应该是每个技术人员掌握的基础知识,无论是技术支持运维人员或者是研发,多少都会遇到要抓包的情况,用过的抓包工具有fiddle.wireshark,作为一个不是经 ...
- 跨平台网络抓包工具-Microsoft Message Analyzer
Microsoft Message Analyzer (MMA 2013)是微软最受欢迎的Netmon的最新版本. 在Netmon网络跟踪和排除故障功能的基础上提供了更强大的跨平台网络分析追踪能力.园 ...
- Microsoft Message Analyzer (微软消息分析器,“网络抓包工具 - Network Monitor”的替代品)官方正式版现已发布
来自官方日志的喜悦 被誉为全新开始的消息分析器时代,由MMA为您开启,博客原文写的很激动,大家可以点击这里浏览:http://blogs.technet.com/b/messageanalyzer/a ...
- 网络抓包工具-Wireshark学习资料
wireshark一个非常牛逼的网络抓包工具.转载一系列博文 一站式学习Wireshark(一):Wireshark基本用法 一站式学习Wireshark(二):应用Wireshark观察基本网络协议 ...
随机推荐
- 【读书笔记】iOS-微定位技术
在大型商场,医院或是大楼里,你是否曾经有过找不到想去的地方的经历呢?这种情况下采用传统的定位方法就有些力不从心了.首先这些地方不能采用GPS定们,而Wifi和蜂窝式移动电话基站定位误差比较大.这种情况 ...
- Java并发编程(四)synchronized
一.synchronized同步方法或者同步块 在了解synchronized关键字的使用方法之前,我们先来看一个概念:互斥锁,顾名思义:能到达到互斥访问目的的锁. 举个简单的例子:如果对临界资源加上 ...
- Android事件总线(四)源码解析otto
前言 上一篇文章中讲到了otto的用法,这一篇我们来讲一下otto的源码.可能有人觉得otto过时了,但是通过源码我们学习的是高手设计otto时的设计理念,这种设计理念是不过时的. otto各个类的作 ...
- Android基础之内容提供者的实现
内容提供者可以实现应用间查询数据库的需求 一.在提供数据库访问的应用设置内容提供者 public class AccountProvider extends ContentProvider { sta ...
- 【PHP调试篇】PHP高性能日志组件SeasLog
简述 什么是SeasLog SeasLog是一个C语言编写的PHP扩展,提供一组规范标准的功能函数,在PHP项目中方便.规范.高效地写日志,以及快速地读取和查询日志. 为什么使用SeasLog 无论在 ...
- [20171225]查看并行执行计划注意的问题.txt
[20171225]查看并行执行计划注意的问题.txt --//如果使用dbms_xplan.display_cursor查看并行执行计划注意一些问题,通过例子说明: 1.环境: SCOTT@book ...
- 洗礼灵魂,修炼python(25)--自定义函数(6)—从匿名函数进阶话题讲解中解析“函数式编程”
匿名函数进阶 前一章已经说了匿名函数,匿名函数还可以和其他内置函数结合使用 1.map map():映射器,映射 list(map(lambda x:x*2,range(10))) #把range产生 ...
- 洗礼灵魂,修炼python(23)--自定义函数(4)—闭包进阶问题—>报错UnboundLocalError: local variable 'x' referenced before assignment
闭包(lexical closure) 什么是闭包前面已经说过了,但是由于遗留问题,所以单独作为一个章节详解讲解下 不多说,看例子: def funx(x): def funy(y): return ...
- sql server 2008R2无人值守批处理脚本自动化安装
▲版权声明:本文为博主原创文章,未经博主允许不得转载. Microsoft SQL Server 2008 R2是一款软件,提供完整的企业级技术与工具,帮助您以最低的总拥有成本获得最有价值的信息.您可 ...
- ES5数组的遍历方式
/* 遍历数组 */ var arr=[1,2,3,43,55,66,77,99]; /* 遍历数组 function(item,index) */ arr.forEach(function(item ...