标签打印机抓包知识汇总

 

1. TCP抓包原理

1.1. TCP/IP协议

TCP/IP协议在一定程度上参考了OSI的体系结构。OSI模型共有七层,从下到上分别是物理层、数据链路层、网络层、运输层、会话层、表示层和应用层。但是这显然是有些复杂的,所以在TCP/IP协议中,它们被简化为了四个层次。

1、应用层、表示层、会话层三个层次提供的服务相差不是很大,所以在TCP/IP协议中,它们被合并为应用层一个层次。

2、由于运输层和网络层在网络协议中的地位十分重要,所以在TCP/IP协议中它们被作为独立的两个层次。

3、因为数据链路层和物理层的内容相差不多,所以在TCP/IP协议中它们被归并在网络接口层一个层次里。

clipboard

  • 建立连接:三次握手

7309e07fcbb5

  • 关闭连接:四次挥手

027ac1c9627c

1.2. WireShark使用

下载

https://www.wireshark.org/download.html

https://www.wireshark.org/download/win32/all-versions/

使用

为了更好的理解在整个TCP会话期间,TCP序列号和确认号是如何工作的,我们可以使用Wireshark内置的绘制流功能,选择菜单栏中的 Statistics ->Flow Graph...->TCP flow ->OK

725093504031

Wireshark会自动创建一个TCP流的图形摘要

725104320005

每行代表一个单独的TCP包,左边列显示时间,中间列显示包的方向、TCP端口、段长度和设置的标志位,右边列以10进制的方式显示相关序列号/确认号,在这里选中任意行会高亮主窗口中该行所关联的包

注:新版本中 统计 >> 流量图

clipboard

clipboard

1.3. 编程实现

WinPcap (windows packet captrue)

很多不同的工具软件使用Winpcap于网络分析,故障排除,网络安全监控等方面。Winpcap特别适用于下面这几个经典领域:

1、网络及协议分析

2、网络监控

3、通信日志记录

4、traffic generators

5、用户级别的桥路和路由

6、网络入侵检测系统(NIDS)

7、网络扫描

8、安全工具

Winpcap有些方面不能做。它不依靠主机的诸如TCP/IP协议去收发数据包。这意味着它不能阻塞,不能处理同一台主机中各程序之间的通信数据。它只能“嗅探”到物理线路上的数据包。因此它不适用于traffic shapers,QoS调度,以及个人防火墙。

https://baike.baidu.com/item/winpcap/11048966?fr=aladdin 介绍

https://www.winpcap.org/install/default.htm 下载

Npcap

Npcap是致力于采用Microsoft Light-Weight Filter (NDIS 6 LWF)技术和Windows Filtering Platform (NDIS 6 WFP)技术对当前最流行的WinPcap工具包进行改进的一个项目。Npcap项目是最初2013年由Nmap网络扫描器项目(创始人Gordon Lyon)和北京大学罗杨博士发起,由Google公司的Summer of Code计划赞助的一个开源项目,遵循MIT协议(与WinPcap一致)。Npcap基于WinPcap 4.1.3源码基础上开发,支持32位和64位架构,在Windows Vista以上版本的系统中,采用NDIS 6技术的Npcap能够比原有的WinPcap数据包(NDIS 5)获得更好的抓包性能,并且稳定性更好。

https://github.com/nmap/npcap/releases

1.4. 干扰

  • 漏包

WinPcap抓取的数据有漏数据的情况

  • 重包

重复传递某个数据包

  • 提前到达

2. 打印机数据解析

2.1. 原理

TSC、Printronix、SATO、Citizen,数据的格式无非是点阵或者pcx,但是打印机一旦做了压缩算法,目前都无法解析

点阵图(TSC)

clipboard

clipboard

PCX 数据

222559033417

2.2. 标签定位及解析

使用ZXing、DataMatrix.Net均会有解析失败的情况,为了捡漏(增加标签的识别率)使用二维码定位在解析的方式。

DataMatic格式的二维码,都有侧边有一个L型的边框,可以根据这个边框在一整张图片上来定位二维码。

clipboard

3. 分布式

采集的数据先汇总到分厂的数据库,然后再通过数据库同步脚本,同步到中心服务器。

20734

3.1. 集中日志

clipboard

3.2. 机台运行程序

自动启动

把快捷方式通过vbs脚本添加到startup文件夹下

  1 set WshShell=WScript.CreateObject("WScript.Shell")
  2 strDesktop=WshShell.SpecialFolders("startup")
  3 Msgbox strDesktop
  4 currentPath=WshShell.CurrentDirectory
  5 set oShellLink=WshShell.CreateShortcut(strDesktop & "\ApplicationName.lnk")
  6 oShellLink.TargetPath=currentPath & "\ApplicationName.exe"
  7 oShellLink.Arguments="/start"
  8 oShellLink.WindowStyle=1
  9 'oShellLink.Hotkey="CTRL+SHIFT+E"
 10 'oShellLink.IconLocation="c:\mydocumentfolder\icon.ico,0"
 11 oShellLink.Description="My Sniffer"
 12 oShellLink.WorkingDirectory=currentPath
 13 oShellLink.Save
View Code

自动最小化到托盘

 1 WindowState = FormWindowState.Minimized;
 2 
 3   /// <summary>初始化 右下角的通知栏(托盘)图标</summary>
 4         private void initialTray()
 5         {
 6             notifyIcon1.Text = "开料辅助程序";
 7             notifyIcon1.MouseDoubleClick += notifyIcon1_MouseDoubleClick;
 8             SizeChanged += F_Main_SizeChanged;
 9         }
10 
11         /// <summary>
12         ///     添加双击托盘图标事件(双击显示窗口)
13         /// </summary>
14         /// <param name="sender"></param>
15         /// <param name="e"></param>
16         private void notifyIcon1_MouseDoubleClick(object sender, MouseEventArgs e)
17         {
18             if (WindowState == FormWindowState.Minimized)
19             {
20                 //还原窗体显示    
21                 WindowState = FormWindowState.Normal;
22                 //激活窗体并给予它焦点
23                 Activate();
24                 //任务栏区显示图标
25                 ShowInTaskbar = true;
26                 //托盘区图标隐藏
27                 notifyIcon1.Visible = false;
28             }
29         }
30 
31         /// <summary>
32         ///     判断是否最小化,然后显示托盘
33         /// </summary>
34         /// <param name="sender"></param>
35         /// <param name="e"></param>
36         private void F_Main_SizeChanged(object sender, EventArgs e)
37         {
38             //判断是否选择的是最小化按钮
39             if (WindowState == FormWindowState.Minimized)
40             {
41                 //隐藏任务栏区图标
42                 ShowInTaskbar = false;
43                 //图标显示在托盘区
44                 notifyIcon1.Visible = true;
45             }
46         }
View Code

本地时钟

从中心服务器获取当前时间,使用定时器进行累加

 1 public class LocalClockHelper
 2     {
 3         public delegate void OnLocalTimeChangeHandler(DateTime now);
 4 
 5         private static DateTime _now;
 6         private static readonly object _lock = new object();
 7 
 8         private static readonly SqlHelper _sqlHelper;
 9         //  private static System.Timers.Timer _timer;
10 
11         static LocalClockHelper()
12         {
13             // 连接字符串
14             _sqlHelper = new SqlHelper(Global.ConnectionStrWithSettingIni);
15 
16             // 定时从服务器上获取时间,初始化
17             _now = getTimeFromServer();
18             StartTime = _now;
19 
20             // 定时器
21             int index = 0;
22             ThreadManager.Instance.Loop("LocalClockHelper", () =>
23             {
24                 lock (_lock)
25                 {
26                     index++;
27                     if (index > 60 * 60)
28                     {
29                         _now = getTimeFromServer();
30                         index = 0;
31                     }
32                     else
33                         _now = _now.AddMilliseconds(1000);
34 
35                     OnLocalTimeChangeEvent?.Invoke(_now);
36                 }
37             }, 1000);
38 
39         }
40 
41         /// <summary>
42         /// </summary>
43         public static DateTime Now
44         {
45             get
46             {
47                 lock (_lock)
48                 {
49                     return _now;
50                 }
51             }
52         }
53 
54         /// <summary>
55         ///     系统启动时间
56         ///     <remarks>不准确,但是好用</remarks>
57         /// </summary>
58         public static DateTime StartTime { get; }
59 
60         public static event OnLocalTimeChangeHandler OnLocalTimeChangeEvent;
61 
62         /// <summary>
63         ///     从服务器上获取时间
64         /// </summary>
65         private static DateTime getTimeFromServer()
66         {
67             try
68             {
69                 //  var now = DateTime.Now;
70                 DateTime sqlDateTime = Convert.ToDateTime(_sqlHelper.ExecuteScalar("select getdate()"));
71                 if (Math.Abs((sqlDateTime - DateTime.Now).TotalMilliseconds) < 1000)
72                     return DateTime.Now;
73                 return sqlDateTime;
74             }
75             catch (Exception exception)
76             {
77                 NjEventLog.Instance.WriteFatal(exception);
78             }
79 
80             return DateTime.Now;
81         }
82 
83         /// <summary>
84         /// 重置
85         /// </summary>
86         public static void Reset()
87         {
88             lock (_lock)
89             {
90                 _now = getTimeFromServer();
91             }
92         }
93     }
View Code

禁止关闭

不足:无法阻止任务管理器上的强制关闭

 1         public MainForm(string[] args)
 2         {
 3             InitializeComponent();
 4 
 5             FormClosing += onFormClosing;
 6         }
 7  
 8  private void onFormClosing(object sender, FormClosingEventArgs e)
 9         {
10             switch (e.CloseReason)
11             {
12                 case CloseReason.ApplicationExitCall: //应用程序要求关闭窗口
13                 case CloseReason.FormOwnerClosing: //自身窗口上的关闭按钮
14                 case CloseReason.UserClosing: //用户通过UI关闭窗口或者通过Alt+F4关闭窗口
15                 case CloseReason.MdiFormClosing: //MDI窗体关闭事件 
16                 case CloseReason.TaskManagerClosing: //任务管理器关闭进程
17                     e.Cancel = true; //拦截,不响应操作
18                     break;
19 
20                 case CloseReason.WindowsShutDown: //操作系统准备关机
21                     e.Cancel = false; //不拦截,响应操作
22                     break;
23 
24                 default:
25                 case CloseReason.None: //不明原因的关闭
26                     e.Cancel = true; //拦截,不响应操作
27                     break;
28             }
29             //base.OnFormClosing(e);
30         }
View Code

自动更新

clipboard

本地数据缓存

所有的数据先存到sqlite,然后再逐条进行上传

clipboard

posted @ 2020-01-09 10:21  远方V3  阅读(948)  评论(0编辑  收藏  举报