NetWorkService.cs 39 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939
  1. using CapturePackage;
  2. using Oreo.NetMonitor.Commons;
  3. using Oreo.NetMonitor.Helpers;
  4. using Oreo.NetMonitor.Models;
  5. using System;
  6. using System.Collections.Generic;
  7. using System.Diagnostics;
  8. using System.IO;
  9. using System.Linq;
  10. using System.Net;
  11. using System.Text;
  12. using System.Threading;
  13. using System.Threading.Tasks;
  14. using Y.Utils.DataUtils.Collections;
  15. using Y.Utils.DataUtils.JsonUtils;
  16. using Y.Utils.NetUtils.NetInfoUtils;
  17. using Y.Utils.WindowsUtils.InfoUtils;
  18. namespace Oreo.NetMonitor.Services
  19. {
  20. public class NetWorkService
  21. {
  22. #region 参数
  23. //CPU占用状态
  24. private static bool CpuLoadRun = false;
  25. public static bool CpuLoadLoop = false;
  26. //总流量监控状态
  27. private static bool NetFlowRun = false;
  28. public static bool NetFlowLoop = false;
  29. //抓包流量状态
  30. private static bool NetCaptureRun = false;
  31. public static bool NetCaptureLoop = false;
  32. //程序连接数任务状态
  33. private static bool ProConnRun = false;
  34. public static bool ProConnLoop = false;
  35. //开始时间
  36. public static DateTime BeginTime = DateTime.Now;
  37. //统计时间
  38. public static DateTime CalcTime = DateTime.Now;
  39. //当前流量、单位临时记录流量、单位时间流量、总流量
  40. public static double NowSent = 0, NowReceived = 0;
  41. public static double TempSent = 0, TempReceived = 0;
  42. public static double UnitSent = 0, UnitReceived = 0;
  43. public static double SentCount = 0, ReceivedCount = 0;
  44. //流量阈值(B)
  45. public static double FlowThreshold = 100 * 1024 * 1024;
  46. //达到阈值时间(分钟)
  47. public static int ThresholdTime = 5;
  48. //程序连接数阈值
  49. public static int MaxProConnect = 50;
  50. //记录程序IP访问记录周期
  51. public static int RecProConnect = 10;
  52. //包数
  53. public static long NowBag = 0, NowBadBag = 0, BagCount = 0;
  54. //进程列表
  55. public static List<NetProcess> netProcesses = new List<NetProcess>();
  56. //IP地址
  57. public static string IP = "192.168.3.56";
  58. //抓包对象
  59. public static NativeSocket2 NS;
  60. //CPU占用
  61. public static double CpuLoad = 0;
  62. //处理器信息
  63. public static PerformanceCounter Processor = new PerformanceCounter("Processor", "% Processor Time", "_Total");
  64. //网卡信息
  65. public static PerformanceCounterCategory performanceCounterCategory = new PerformanceCounterCategory("Network Interface");
  66. public static string[] instances = performanceCounterCategory.GetInstanceNames();
  67. public static PerformanceCounter[] pfSent = new PerformanceCounter[instances.Count()];
  68. public static PerformanceCounter[] pfReceived = new PerformanceCounter[instances.Count()];
  69. #endregion
  70. #region 私有构造(阻止new)
  71. private NetWorkService() { }
  72. #endregion
  73. #region 启动服务
  74. public static void Start()
  75. {
  76. //Task.Factory.StartNew(() =>
  77. //{
  78. // InitNetCard();
  79. // while (Enable)
  80. // {
  81. // GetCpuLoad();//读取CPU占用
  82. // GetNetFlow();//获取总网速
  83. // GetNetProcess();//获取联网进程
  84. // NetBagToPro();//数据包整理到进程
  85. // Thread.Sleep(1000);
  86. // CalcBagFlow();//计算进程流量
  87. // }
  88. //});
  89. ////获取实时数据包
  90. //GetIP();
  91. //GetNetBag();
  92. }
  93. public static void StartCpuLoad()
  94. {
  95. if (!CpuLoadRun)
  96. {
  97. CpuLoadRun = true;
  98. Task.Factory.StartNew(() =>
  99. {
  100. try
  101. {
  102. while (CpuLoadLoop)
  103. {
  104. GetCpuLoad();//读取CPU占用
  105. Thread.Sleep(1000);
  106. }
  107. CpuLoadRun = false;
  108. }
  109. catch (Exception ex)
  110. {
  111. R.Log.e("StartCpuLoad异常" + ex.Message);
  112. }
  113. });
  114. }
  115. }
  116. public static void StartNetFlow()
  117. {
  118. if (!NetFlowRun)
  119. {
  120. NetFlowRun = true;
  121. Task.Factory.StartNew(() =>
  122. {
  123. try
  124. {
  125. InitSettings();
  126. InitNetCard();
  127. while (NetFlowLoop)
  128. {
  129. GetNetFlow();//获取总网速
  130. Thread.Sleep(1000);
  131. }
  132. NetFlowRun = false;
  133. }
  134. catch (Exception ex)
  135. {
  136. R.Log.e("StartNetFlow异常" + ex.Message);
  137. }
  138. });
  139. }
  140. }
  141. public static void StartNetCapture()
  142. {
  143. int span = 0;
  144. if (!NetCaptureRun)
  145. {
  146. NetCaptureRun = true;
  147. Task.Factory.StartNew(() =>
  148. {
  149. //获取实时数据包
  150. #region 设置IP
  151. var networkInfo = NetCardInfoTool.GetNetworkCardInfo();
  152. if (!ListTool.IsNullOrEmpty(networkInfo))
  153. {
  154. IP = networkInfo[0].Item3;
  155. }
  156. #endregion
  157. GetNetBag();
  158. GetNetProcess();//获取联网进程
  159. while (NetCaptureLoop)
  160. {
  161. //if (span >= 1)
  162. //{
  163. // GetNetProcess();//获取联网进程
  164. // span = 0;
  165. //}
  166. Thread.Sleep(1000);
  167. CalcBagFlow();//计算进程流量
  168. span++;
  169. }
  170. NS.IsStart = false;
  171. NetCaptureRun = false;
  172. });
  173. }
  174. }
  175. public static void StartConnectCheck()
  176. {
  177. if (!ProConnRun)
  178. {
  179. ProConnRun = true;
  180. Task.Factory.StartNew(() =>
  181. {
  182. try
  183. {
  184. List<string> connInfo = GetProConnInfo2();
  185. //LogHelper.writeLog(string.Format("y-connInfo web 访问记录信息条数:{0}", connInfo == null ? "null" : connInfo.Count().ToString()));
  186. DateTime maxConnRunTime = DateTime.Now.AddMinutes(ThresholdTime);
  187. DateTime recConnRunTime = DateTime.Now.AddSeconds(RecProConnect);
  188. List<string> rcd = new List<string>();
  189. while (ProConnLoop)
  190. {
  191. #region 发送连接数超限数据
  192. if (DateTime.Now > maxConnRunTime)
  193. {
  194. try
  195. {
  196. List<ProConnRecordBag> rec = GetNetConn();
  197. foreach (var r in rec)
  198. {
  199. if (r.Count > MaxProConnect)
  200. {
  201. SendProConnRecord(r);
  202. //LogHelper.writeLog("y-监控软件连接数超过上限");
  203. }
  204. }
  205. }
  206. catch (Exception ex)
  207. {
  208. R.Log.v(string.Format("y-监控软件连接数运行异常:{0}", ex.Message));
  209. }
  210. maxConnRunTime = DateTime.Now.AddMinutes(ThresholdTime);
  211. }
  212. #endregion
  213. #region 发送访问记录
  214. try
  215. {
  216. List<ProConnRecordBag> rec = GetNetConn();
  217. if (connInfo != null && connInfo.Count() > 0)
  218. {
  219. #region 统计本次访问记录
  220. //循环服务器IP列表
  221. foreach (var _info in connInfo)
  222. {
  223. //循环软件列表
  224. foreach (var r in rec)
  225. {
  226. //如果软件连接>0
  227. if (r.Count > 0)
  228. {
  229. //循环记录
  230. foreach (var _r in r.Record)
  231. {
  232. //过滤 0. 和 127. 开头 ip
  233. string tempr = "filter" + _r.RI;
  234. if (!tempr.Contains("filter0.") && !tempr.Contains("filter127."))
  235. {
  236. //循环端口
  237. foreach (var _p in _r.Conn)
  238. {
  239. //仅通过Established:连接成功
  240. if (_p.Status == "Established")
  241. {
  242. #region 新访问记录处理方法
  243. //把IP和端口号转换为组
  244. List<string> ipnum = string.Format("{0}.{1}", _r.RI, _p.RP).Trim().Split('.').ToList();
  245. List<string> infonum = _info.Trim().Replace(":", ".").Split('.').ToList();
  246. if (ipnum != null && ipnum.Count() == 5 && infonum != null && infonum.Count() == 5)
  247. {
  248. bool match = true;
  249. for (int i = 0; i < 5; i++)
  250. {
  251. if (infonum[i] == "*") continue;
  252. if (ipnum[i] == infonum[i]) continue;
  253. string[] numarr = infonum[i].Split('-');
  254. if (numarr != null && numarr.Count() == 2)
  255. {
  256. try
  257. {
  258. if (int.Parse(ipnum[i]) >= int.Parse(numarr[0]) &&
  259. int.Parse(ipnum[i]) <= int.Parse(numarr[1]))
  260. continue;
  261. }
  262. catch { }
  263. }
  264. match = false;
  265. }
  266. if (match && !rcd.Contains(string.Format("{0}:{1}", _r.RI, _p.RP).Trim()))
  267. rcd.Add(string.Format("{0}:{1}", _r.RI, _p.RP).Trim());
  268. }
  269. #endregion
  270. }
  271. #region 2016年10月17日(原有访问记录处理方法备份)
  272. //string con = string.Format("{0}:{1}", _r.RI, _p.RP);
  273. //if (_info == con)
  274. //{
  275. // if (!rcd.Contains(_info))
  276. // rcd.Add(_info);
  277. //}
  278. #endregion
  279. }
  280. }
  281. }
  282. }
  283. }
  284. }
  285. #endregion
  286. #region 周期发送记录
  287. if (DateTime.Now > recConnRunTime)
  288. {
  289. //组装结果字符串并发送回服务器
  290. if (rcd != null && rcd.Count() > 0)
  291. {
  292. string result = "";
  293. foreach (var _info in rcd)
  294. {
  295. result += _info + ",";
  296. }
  297. result = result.Substring(0, result.Length - 1);
  298. bool send_res = SendHelper.Send("46", result + "&");
  299. //LogHelper.writeLog(result + "&");
  300. }
  301. rcd = new List<string>();
  302. recConnRunTime = DateTime.Now.AddSeconds(RecProConnect);
  303. }
  304. #endregion
  305. }
  306. else
  307. {
  308. if (DateTime.Now > recConnRunTime)
  309. {
  310. connInfo = GetProConnInfo2();
  311. //LogHelper.writeLog(string.Format("y-connInfo web 访问记录信息条数:{0}", connInfo == null ? "null" : connInfo.Count().ToString()));
  312. recConnRunTime = DateTime.Now.AddSeconds(RecProConnect);
  313. }
  314. }
  315. }
  316. catch (Exception ex)
  317. {
  318. R.Log.e(string.Format("y-监控访问记录异常:{0}", ex.Message));
  319. }
  320. #endregion
  321. Thread.Sleep(1000);
  322. }
  323. ProConnRun = false;
  324. }
  325. catch (Exception ex)
  326. {
  327. R.Log.e("StartConnectCheck发送连接数异常" + ex.Message);
  328. }
  329. });
  330. }
  331. }
  332. #endregion
  333. #region 初始化流量记录配置
  334. public static void InitSettings()
  335. {
  336. BeginTime = DateTime.Now;//开始时间
  337. int _time = 0, _maxConn = 0, _recConn = 0;
  338. double _flow = 0;
  339. try
  340. {
  341. _time = R.Settings.ThresholdTime;
  342. _flow = R.Settings.FlowThreshold;
  343. _maxConn = R.Settings.MaxProConnect;
  344. _recConn = R.Settings.RecProConnect;
  345. }
  346. catch { }
  347. if (_flow > 0) FlowThreshold = _flow;
  348. if (_time > 0) ThresholdTime = _time;
  349. if (_maxConn > 0) MaxProConnect = _maxConn;
  350. if (_recConn > 0) RecProConnect = _recConn;
  351. CalcTime = DateTime.Now.AddMinutes(ThresholdTime);//统计时间
  352. //LogHelper.writeLog(string.Format("y-读取流量参数设置:FlowThreshold{0}-ThresholdTime{1}-MaxProConnect{2}-RecProConnect{3}", FlowThreshold, ThresholdTime, MaxProConnect, RecProConnect));
  353. }
  354. #endregion
  355. #region 初始化网卡适配器
  356. public static void InitNetCard()
  357. {
  358. for (int i = 0; i < instances.Count(); i++)
  359. {
  360. pfSent[i] = new PerformanceCounter("Network Interface", "Bytes Sent/sec", instances[i]);
  361. pfReceived[i] = new PerformanceCounter("Network Interface", "Bytes Received/sec", instances[i]);
  362. }
  363. }
  364. #endregion
  365. #region 获取网卡网络流量
  366. private static void GetNetFlow()
  367. {
  368. NowSent = 0;
  369. NowReceived = 0;
  370. try
  371. {
  372. for (int i = 0; i < instances.Count(); i++)
  373. {
  374. NowSent += pfSent[i].NextValue();
  375. NowReceived += pfReceived[i].NextValue();
  376. }
  377. }
  378. catch { }
  379. SentCount += NowSent;
  380. ReceivedCount += NowReceived;
  381. TempSent += NowSent;
  382. TempReceived += NowReceived;
  383. if (DateTime.Now >= CalcTime)
  384. {
  385. CalcTime = DateTime.Now.AddMinutes(ThresholdTime);
  386. UnitSent = TempSent;
  387. UnitReceived = TempReceived;
  388. TempSent = 0;
  389. TempReceived = 0;
  390. }
  391. }
  392. #endregion
  393. #region 获取联网进程列表
  394. private static void GetNetProcess()
  395. {
  396. lock (netProcesses)
  397. {
  398. foreach (var item in NetProcessAPI.GetAllTcpConnections())
  399. {
  400. AddTCPNetProcess(item);
  401. }
  402. foreach (var item in NetProcessAPI.GetAllUdpConnections())
  403. {
  404. AddUDPNetProcess(item);
  405. }
  406. }
  407. }
  408. private static void AddTCPNetProcess(TcpRow item)
  409. {
  410. try
  411. {
  412. var _netProcess = netProcesses.FirstOrDefault(x => x.ProcessID == item.owningPid);
  413. if (_netProcess == null)
  414. {
  415. _netProcess = new NetProcess() { ProcessID = item.owningPid };
  416. netProcesses.Add(_netProcess);
  417. }
  418. if (_netProcess.Ports.FirstOrDefault(x => x.Port == item.LocalPort) == null)
  419. {
  420. _netProcess.ProcessICon = ProcessAPI.GetIcon(item.owningPid, true);
  421. }
  422. _netProcess.Ports.Add(GetTcpProcessPort(item));
  423. }
  424. catch (Exception e)
  425. {
  426. }
  427. }
  428. private static void AddUDPNetProcess(UdpRow item)
  429. {
  430. try
  431. {
  432. var _netProcess = netProcesses.FirstOrDefault(x => x.ProcessID == item.owningPid);
  433. if (_netProcess == null)
  434. {
  435. _netProcess = new NetProcess() { ProcessID = item.owningPid };
  436. netProcesses.Add(_netProcess);
  437. }
  438. if (_netProcess.Ports.FirstOrDefault(x => x.Port == item.LocalPort) == null)
  439. {
  440. _netProcess.ProcessICon = ProcessAPI.GetIcon(item.owningPid, true);
  441. _netProcess.Ports.Add(GetUDPProcessPort(item));
  442. }
  443. }
  444. catch (Exception e)
  445. {
  446. }
  447. }
  448. private static ProcessPort GetTcpProcessPort(TcpRow tr)
  449. {
  450. ProcessPort _pp = new ProcessPort()
  451. {
  452. LocalAddress = tr.LocalAddress.ToString(),
  453. Port = tr.LocalPort,
  454. RemoteAddress = tr.RemoteAddress.ToString(),
  455. Type = ProtocolType.TCPType,
  456. RemotePort = tr.RemotePort,
  457. };
  458. return _pp;
  459. }
  460. private static ProcessPort GetUDPProcessPort(UdpRow tr)
  461. {
  462. ProcessPort _pp = new ProcessPort()
  463. {
  464. LocalAddress = tr.LocalAddress.ToString(),
  465. Port = tr.LocalPort,
  466. RemoteAddress = "",
  467. Type = ProtocolType.UDPType,
  468. RemotePort = 0,
  469. };
  470. return _pp;
  471. }
  472. #endregion
  473. #region 获取所有网络连接
  474. private static List<ProConnRecordBag> GetNetConn()
  475. {
  476. List<ProConnRecordBag> rec = new List<ProConnRecordBag>();
  477. TcpRow[] tlist = NetProcessAPI.GetAllTcpConnections();
  478. foreach (var item in tlist)
  479. {
  480. var pro = rec.FirstOrDefault(x => x.Name == item.owningPid.ToString());
  481. if (pro == null)
  482. {
  483. pro = new ProConnRecordBag() { Name = item.owningPid.ToString(), Count = 0, Record = new List<ProConnRecord>() };
  484. rec.Add(pro);
  485. }
  486. var ipConn = pro.Record.FirstOrDefault(x => x.LI == item.LocalAddress.ToString() && x.RI == item.RemoteAddress.ToString());
  487. if (ipConn == null)
  488. {
  489. ipConn = new ProConnRecord() { LI = item.LocalAddress.ToString(), RI = item.RemoteAddress.ToString(), Conn = new List<ProConnPort>() };
  490. pro.Record.Add(ipConn);
  491. }
  492. ipConn.Conn.Add(new ProConnPort() { LP = item.LocalPort, RP = item.RemotePort, TP = ProtocolType.TCPType.ToString().Replace("Type", ""), Status = item.state.ToString() });
  493. pro.Count++;
  494. }
  495. UdpRow[] ulist = NetProcessAPI.GetAllUdpConnections();
  496. foreach (var item in ulist)
  497. {
  498. var pro = rec.FirstOrDefault(x => x.Name == item.owningPid.ToString());
  499. if (pro == null)
  500. {
  501. pro = new ProConnRecordBag() { Name = item.owningPid.ToString(), Count = 0, Record = new List<ProConnRecord>() };
  502. rec.Add(pro);
  503. }
  504. var ipConn = pro.Record.FirstOrDefault(x => x.LI == item.LocalAddress.ToString());
  505. if (ipConn == null)
  506. {
  507. ipConn = new ProConnRecord() { LI = item.LocalAddress.ToString(), Conn = new List<ProConnPort>() };
  508. pro.Record.Add(ipConn);
  509. }
  510. ipConn.Conn.Add(new ProConnPort() { LP = item.LocalPort, TP = ProtocolType.TCPType.ToString().Replace("Type", "") });
  511. pro.Count++;
  512. }
  513. return rec;
  514. }
  515. #endregion
  516. #region 获取联网进程列表:新列表
  517. private static void GetNetPro(List<NetProcess> proList)
  518. {
  519. foreach (var item in NetProcessAPI.GetAllTcpConnections())
  520. {
  521. AddTCPNetPro(item, proList);
  522. }
  523. foreach (var item in NetProcessAPI.GetAllUdpConnections())
  524. {
  525. AddUDPNetPro(item, proList);
  526. }
  527. }
  528. private static void AddTCPNetPro(TcpRow item, List<NetProcess> proList)
  529. {
  530. try
  531. {
  532. var _netProcess = proList.FirstOrDefault(x => x.ProcessID == item.owningPid);
  533. if (_netProcess == null)
  534. {
  535. _netProcess = new NetProcess() { ProcessID = item.owningPid, ProcessName = ProcessAPI.GetProcessNameByPID(item.owningPid) };
  536. proList.Add(_netProcess);
  537. }
  538. if (_netProcess.Ports.FirstOrDefault(x => x.Port == item.LocalPort) == null)
  539. {
  540. _netProcess.ProcessICon = ProcessAPI.GetIcon(item.owningPid, true);
  541. }
  542. _netProcess.Ports.Add(GetTcpProPort(item));
  543. }
  544. catch (Exception e)
  545. {
  546. }
  547. }
  548. private static void AddUDPNetPro(UdpRow item, List<NetProcess> proList)
  549. {
  550. try
  551. {
  552. var _netProcess = proList.FirstOrDefault(x => x.ProcessID == item.owningPid);
  553. if (_netProcess == null)
  554. {
  555. _netProcess = new NetProcess() { ProcessID = item.owningPid, ProcessName = ProcessAPI.GetProcessNameByPID(item.owningPid) };
  556. proList.Add(_netProcess);
  557. }
  558. if (_netProcess.Ports.FirstOrDefault(x => x.Port == item.LocalPort) == null)
  559. {
  560. _netProcess.ProcessICon = ProcessAPI.GetIcon(item.owningPid, true);
  561. _netProcess.Ports.Add(GetUDPProPort(item));
  562. }
  563. }
  564. catch (Exception e)
  565. {
  566. }
  567. }
  568. private static ProcessPort GetTcpProPort(TcpRow tr)
  569. {
  570. ProcessPort _pp = new ProcessPort()
  571. {
  572. LocalAddress = tr.LocalAddress.ToString(),
  573. Port = tr.LocalPort,
  574. RemoteAddress = tr.RemoteAddress.ToString(),
  575. Type = ProtocolType.TCPType,
  576. RemotePort = tr.RemotePort,
  577. };
  578. return _pp;
  579. }
  580. private static ProcessPort GetUDPProPort(UdpRow tr)
  581. {
  582. ProcessPort _pp = new ProcessPort()
  583. {
  584. LocalAddress = tr.LocalAddress.ToString(),
  585. Port = tr.LocalPort,
  586. RemoteAddress = "",
  587. Type = ProtocolType.UDPType,
  588. RemotePort = 0,
  589. };
  590. return _pp;
  591. }
  592. #endregion
  593. #region 获取网络数据包(间隔:实时)
  594. private static void GetNetBag()
  595. {
  596. NS = new NativeSocket2(IPAddress.Parse(IP));
  597. NS.IsStart = true;
  598. NS.OnIPPacketCapure = (IPPacket tp) =>
  599. {
  600. BagCount++;
  601. if (tp.SrcAddr.ToString() == IP)
  602. {
  603. //源地址是本机-从本机发出
  604. lock (netProcesses)
  605. {
  606. bool _in = false;
  607. foreach (var item in netProcesses)
  608. {
  609. int inPort = item.Ports.Where(x => x.Port == tp.SrcPort).Count(); ;
  610. if (inPort > 0)
  611. {
  612. item.UpBag++;
  613. NowBag++;
  614. _in = true;
  615. //item.Upload += tp.DataLen;
  616. //item.FlowCount += tp.DataLen;
  617. }
  618. }
  619. if (!_in) NowBadBag++;
  620. }
  621. }
  622. if (tp.DestAddr.ToString() == IP)
  623. {
  624. //目标地址是本机-本机接收
  625. lock (netProcesses)
  626. {
  627. bool _in = false;
  628. foreach (var item in netProcesses)
  629. {
  630. int inPort = item.Ports.Where(x => x.Port == tp.DestPort).Count(); ;
  631. if (inPort > 0)
  632. {
  633. item.DownBag++;
  634. NowBag++;
  635. _in = true;
  636. //item.DownLoad += tp.DataLen;
  637. //item.FlowCount += tp.DataLen;
  638. }
  639. }
  640. if (!_in) NowBadBag++;
  641. }
  642. }
  643. };
  644. Task.Factory.StartNew(() => { NS.Capture(); });
  645. }
  646. #endregion
  647. #region 矫正数据流量
  648. private static void CalcBagFlow()
  649. {
  650. lock (netProcesses)
  651. {
  652. foreach (var pro in netProcesses)
  653. {
  654. long temp = pro.UpBag + pro.DownBag;
  655. double rate = 0;
  656. if (NowBag > 0 && temp > 0)
  657. rate = (double)temp / (double)NowBag;
  658. if (temp > 0 && temp != NowBag)
  659. {
  660. int i = 0;
  661. }
  662. pro.UpLoad = (long)(NowSent * rate);
  663. pro.DownLoad = (long)(NowReceived * rate);
  664. pro.UpLoadCount += pro.UpLoad;
  665. pro.DownLoadCount += pro.DownLoad;
  666. pro.UpBag = 0;
  667. pro.DownBag = 0;
  668. }
  669. }
  670. NowBag = 0;
  671. NowBadBag = 0;
  672. }
  673. #endregion
  674. #region 读取CPU占用率
  675. private static void GetCpuLoad()
  676. {
  677. try { CpuLoad = Processor.NextValue(); } catch { }
  678. }
  679. #endregion
  680. #region 存储发送联网流量记录
  681. public static void WriteRecord(DateTime beginTime, DateTime endTime, List<NetProcess> netProcesses, string ip)
  682. {
  683. NetRecordBag rs = new NetRecordBag();
  684. rs.IP = ip;
  685. rs.Begin = beginTime.ToString("yyyy-MM-dd HH:mm:ss");
  686. rs.End = endTime.ToString("yyyy-MM-dd HH:mm:ss");
  687. if (netProcesses.Count() > 0)
  688. {
  689. rs.Record = new List<NetRecord>();
  690. NetRecord rcd;
  691. foreach (var pro in netProcesses)
  692. {
  693. if (pro.UpLoadCount > 0 || pro.DownLoadCount > 0)
  694. {
  695. rcd = new NetRecord()
  696. {
  697. Name = pro.ProcessName,
  698. Up = pro.UpLoadCount,
  699. Down = pro.DownLoadCount,
  700. };
  701. rs.Record.Add(rcd);
  702. }
  703. }
  704. }
  705. //判断只有有流量纪录数据时 向服务器发送数据
  706. if (rs != null && rs.Record != null && rs.Record.Count() > 0)
  707. {
  708. try
  709. {
  710. string rsJson = JsonTool.ToStr(rs);
  711. string path = R.Paths.BasePath + @"FlowRec";
  712. if (!Directory.Exists(path))
  713. {
  714. Directory.CreateDirectory(path);
  715. }
  716. //Write(string.Format(path + @"\{0}.txt", DateTime.Now.ToString("yyyyMMddHHmmss")), rsJson);
  717. SendHelper.Send("38", rsJson);
  718. }
  719. catch { }
  720. }
  721. }
  722. #endregion
  723. #region 存储发送程序连接数记录
  724. public static void SendProConnRecord(NetProcess pro)
  725. {
  726. ProConnRecordBag rs = new ProConnRecordBag();
  727. rs.Name = pro.ProcessName;
  728. rs.Count = pro.Ports.Count();
  729. rs.Record = new List<ProConnRecord>();
  730. foreach (var p in pro.Ports)
  731. {
  732. var r = rs.Record.FirstOrDefault(x => x.LI == p.LocalAddress && x.RI == p.RemoteAddress);
  733. if (r != null)
  734. {
  735. r.Conn.Add(new ProConnPort()
  736. {
  737. LP = p.Port,
  738. RP = p.RemotePort,
  739. TP = p.Type.ToString().Replace("Type", ""),
  740. });
  741. }
  742. else
  743. {
  744. var rcd = new ProConnRecord()
  745. {
  746. LI = p.LocalAddress,
  747. RI = p.RemoteAddress,
  748. Conn = new List<ProConnPort>(),
  749. };
  750. rcd.Conn.Add(new ProConnPort()
  751. {
  752. LP = p.Port,
  753. RP = p.RemotePort,
  754. TP = p.Type.ToString().Replace("Type", ""),
  755. });
  756. rs.Record.Add(rcd);
  757. }
  758. }
  759. try
  760. {
  761. string rsJson = JsonTool.ToStr(rs);
  762. string path = R.Paths.BasePath + @"ProConnRec";
  763. if (!Directory.Exists(path))
  764. {
  765. Directory.CreateDirectory(path);
  766. }
  767. //Write(string.Format(path + @"\{0}-{1}.txt", DateTime.Now.ToString("yyyyMMddHHmmss"), pro.ProcessName), rsJson);
  768. SendHelper.Send("43", rsJson);
  769. }
  770. catch { }
  771. }
  772. public static void SendProConnRecord(ProConnRecordBag rec)
  773. {
  774. try
  775. {
  776. rec.Name = ProcessAPI.GetProcessNameByPID(int.Parse(rec.Name));
  777. if (!string.IsNullOrWhiteSpace(rec.Name) && rec.Name.ToLower() != "idle")
  778. {
  779. string rsJson = JsonTool.ToStr(rec);
  780. string path = R.Paths.BasePath + @"ProConnRec";
  781. if (!Directory.Exists(path))
  782. {
  783. Directory.CreateDirectory(path);
  784. }
  785. //Write(string.Format(path + @"\{0}-{1}.txt", DateTime.Now.ToString("yyyyMMddHHmmss"), rec.Name), rsJson);
  786. SendHelper.Send("43", rsJson);
  787. }
  788. }
  789. catch { }
  790. }
  791. #endregion
  792. #region 存储文件
  793. private static bool Write(string file, string content)
  794. {
  795. bool rs = false;
  796. try
  797. {
  798. StreamWriter sw = new StreamWriter(file, false);
  799. sw.WriteLine(content);
  800. sw.Close();//写入
  801. rs = true;
  802. }
  803. catch (Exception e) { }
  804. return rs;
  805. }
  806. #endregion
  807. #region 获取联网记录的数据
  808. public List<string> GetProConnInfo()
  809. {
  810. //参数
  811. string WebIp = R.Servers.ConfigIP;
  812. int webPort = R.Servers.ConfigPort;
  813. string url = string.Format("http://{0}:{1}/noah/webservice/getApplication", WebIp, webPort);
  814. string pageHtml = "";
  815. //请求并转换模型
  816. try
  817. {
  818. WebClient MyWebClient = new WebClient();
  819. MyWebClient.Credentials = CredentialCache.DefaultCredentials;//获取或设置用于向Internet资源的请求进行身份验证的网络凭据
  820. Byte[] pageData = MyWebClient.DownloadData(url); //从指定网站下载数据
  821. //pageHtml = Encoding.Default.GetString(pageData); //如果获取网站页面采用的是GB2312,则使用这句
  822. pageHtml = Encoding.UTF8.GetString(pageData); //如果获取网站页面采用的是UTF-8,则使用这句
  823. if (!string.IsNullOrWhiteSpace(pageHtml))
  824. {
  825. List<string> result = new List<string>();
  826. string[] list = pageHtml.Split(';');
  827. foreach (var item in list)
  828. {
  829. if (!string.IsNullOrWhiteSpace(item))
  830. {
  831. string ip = item.Replace("\r", "");
  832. ip = ip.Replace("\n", "");
  833. result.Add(ip.Trim());
  834. }
  835. }
  836. return result;
  837. }
  838. }
  839. catch (Exception e)
  840. { }
  841. return null;
  842. }
  843. #endregion
  844. #region 获取联网记录的数据2
  845. public static List<string> GetProConnInfo2()
  846. {
  847. //参数
  848. string WebIp = R.Servers.ConfigIP;
  849. int webPort = R.Servers.ConfigPort;
  850. string url = string.Format("http://{0}:{1}/noah/webservice/getApplicationTwo", WebIp, webPort);
  851. string pageHtml = "";
  852. //请求并转换模型
  853. try
  854. {
  855. WebClient MyWebClient = new WebClient();
  856. MyWebClient.Credentials = CredentialCache.DefaultCredentials;//获取或设置用于向Internet资源的请求进行身份验证的网络凭据
  857. Byte[] pageData = MyWebClient.DownloadData(url); //从指定网站下载数据
  858. //pageHtml = Encoding.Default.GetString(pageData); //如果获取网站页面采用的是GB2312,则使用这句
  859. pageHtml = Encoding.UTF8.GetString(pageData); //如果获取网站页面采用的是UTF-8,则使用这句
  860. if (!string.IsNullOrWhiteSpace(pageHtml))
  861. {
  862. List<string> result = new List<string>();
  863. string[] list = pageHtml.Split(';');
  864. foreach (var item in list)
  865. {
  866. string ip = item.Replace("\r", "").Replace("\n", "").Trim();
  867. if (!string.IsNullOrWhiteSpace(ip))
  868. {
  869. result.Add(ip);
  870. }
  871. }
  872. return result;
  873. }
  874. }
  875. catch (Exception e)
  876. { }
  877. return null;
  878. }
  879. #endregion
  880. }
  881. #region 程序联网记录
  882. public class NetRecord
  883. {
  884. public string Name { get; set; }
  885. public long Up { get; set; }
  886. public long Down { get; set; }
  887. }
  888. public class NetRecordBag
  889. {
  890. public string IP { get; set; }
  891. public string Begin { get; set; }
  892. public string End { get; set; }
  893. public List<NetRecord> Record { get; set; }
  894. }
  895. #endregion
  896. #region 联网进程连接数记录
  897. public class ProConnPort
  898. {
  899. public int LP { get; set; }
  900. public int RP { get; set; }
  901. //Type
  902. public string TP { get; set; }
  903. public string Status { get; set; }
  904. }
  905. public class ProConnRecord
  906. {
  907. //本地IP
  908. public string LI { get; set; }
  909. //远端IP
  910. public string RI { get; set; }
  911. public List<ProConnPort> Conn { get; set; }
  912. }
  913. public class ProConnRecordBag
  914. {
  915. public string Name { get; set; }
  916. public int Count { get; set; }
  917. public List<ProConnRecord> Record { get; set; }
  918. }
  919. #endregion
  920. }