AnalyseFileController.cs 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326
  1. using Azure.Storage.Blobs;
  2. using Azure.Storage.Blobs.Models;
  3. using Microsoft.AspNetCore.Hosting;
  4. using Microsoft.AspNetCore.Http;
  5. using Microsoft.AspNetCore.Mvc;
  6. using System;
  7. using System.Collections.Generic;
  8. using System.IO;
  9. using System.Linq;
  10. using System.Text;
  11. using System.Text.Json;
  12. using System.Text.RegularExpressions;
  13. using System.Threading.Tasks;
  14. using TEAMModelBI.Tool;
  15. using TEAMModelBI.Tool.CosmosBank;
  16. using TEAMModelOS.SDK.Context.BI;
  17. using TEAMModelOS.SDK.Context.Constant;
  18. using TEAMModelOS.SDK.DI;
  19. using TEAMModelOS.SDK.Extension;
  20. using TEAMModelOS.SDK.Models.Cosmos.BI;
  21. namespace TEAMModelBI.Controllers.BIBlob
  22. {
  23. [Route("analyse")]
  24. [ApiController]
  25. public class AnalyseFileController : ControllerBase
  26. {
  27. private readonly IWebHostEnvironment _environment; //读取文件流
  28. private readonly AzureStorageFactory _azureStorage;
  29. public AnalyseFileController(IWebHostEnvironment environment, AzureStorageFactory azureStorage)
  30. {
  31. _environment = environment;
  32. _azureStorage = azureStorage;
  33. }
  34. /// <summary>
  35. /// 查询一天的分析防火墙分析 已对接
  36. /// </summary>
  37. /// <param name="jsonElement"></param>
  38. /// <returns></returns>
  39. [ProducesDefaultResponseType]
  40. [HttpPost("get-dayapi")]
  41. public async Task<IActionResult> GetDayApi(JsonElement jsonElement)
  42. {
  43. jsonElement.TryGetProperty("dateTime", out JsonElement dateTime);
  44. jsonElement.TryGetProperty("site", out JsonElement site);
  45. DateTimeOffset dtOff = DateTimeOffset.UtcNow;
  46. var blobCilent = _azureStorage.GetBlobContainerClient(containerName: "0-public");
  47. if ($"{site}".Equals(BIConst.Global))
  48. blobCilent = _azureStorage.GetBlobContainerClient(containerName: "0-public", BIConst.Global);
  49. if (!string.IsNullOrEmpty($"{dateTime}"))
  50. dtOff = TimeHelper.GetDateTime(dateTime.GetInt64());
  51. string day = dtOff.ToString("yyyyMMdd");
  52. Dictionary<string, RecCnt> days = new();
  53. await foreach (BlobItem blobItem in blobCilent.GetBlobsAsync(BlobTraits.None, BlobStates.None, $"visitCnt/{day}"))
  54. {
  55. BlobClient tempClient = blobCilent.GetBlobClient(blobItem.Name);
  56. if (await tempClient.ExistsAsync())
  57. {
  58. using (var meomoryStream = new MemoryStream())
  59. {
  60. var response = blobCilent.GetBlobClient($"{blobItem.Name}").DownloadTo(meomoryStream);
  61. //var response = await blob.GetBlobClient($"{blobItem.Name}").DownloadToAsync(meomoryStream);
  62. //var temps = meomoryStream.ToString();
  63. //var temp1 = Encoding.UTF8.GetString(meomoryStream.ToArray());
  64. //var temp = Encoding.UTF8.GetString(meomoryStream.ToArray()).ToObject<RecCnt>();
  65. RecCnt recCnt = Encoding.UTF8.GetString(meomoryStream.ToArray()).ToString().ToObject<RecCnt>();
  66. string name = stringSuffix.MidStrEx(blobItem.Name, "/", ".");
  67. days.Add(name, recCnt);
  68. }
  69. }
  70. }
  71. return Ok(new { state = RespondCode.Ok, days = days.ToList() });
  72. }
  73. /// <summary>
  74. /// 查询七天的数据
  75. /// </summary>
  76. /// <param name="jsonElement"></param>
  77. /// <returns></returns>
  78. [ProducesDefaultResponseType]
  79. [HttpPost("get-sevendayapi")]
  80. public async Task<IActionResult> GetSevenDayApi(JsonElement jsonElement)
  81. {
  82. jsonElement.TryGetProperty("site", out JsonElement site);
  83. var blobCilent = _azureStorage.GetBlobContainerClient(containerName: "0-public");
  84. if ($"{site}".Equals(BIConst.Global))
  85. blobCilent = _azureStorage.GetBlobContainerClient(containerName: "0-public", BIConst.Global);
  86. List<RecApiCnt> savenDayApis = new();
  87. List<string> day7 = TimeHelper.GetNearDay(DateTimeOffset.UtcNow, 7);
  88. foreach (var item in day7)
  89. {
  90. await foreach (BlobItem blobItem in blobCilent.GetBlobsAsync(BlobTraits.None, BlobStates.None, $"visitCnt/{item}"))
  91. {
  92. BlobClient tempClient = blobCilent.GetBlobClient(blobItem.Name);
  93. if (await tempClient.ExistsAsync())
  94. {
  95. using (var meomoryStream = new MemoryStream())
  96. {
  97. var response = blobCilent.GetBlobClient($"{blobItem.Name}").DownloadTo(meomoryStream);
  98. //var response = await blob.GetBlobClient($"{blobItem.Name}").DownloadToAsync(meomoryStream);
  99. //var temps = meomoryStream.ToString();
  100. //var temp1 = Encoding.UTF8.GetString(meomoryStream.ToArray());
  101. //var temp = Encoding.UTF8.GetString(meomoryStream.ToArray()).ToObject<RecCnt>();
  102. RecCnt recCnt = Encoding.UTF8.GetString(meomoryStream.ToArray()).ToString().ToObject<RecCnt>();
  103. savenDayApis.AddRange(recCnt.apiCnt);
  104. }
  105. }
  106. }
  107. }
  108. return Ok(new { state = RespondCode.Ok, savenDayApis });
  109. }
  110. /// <summary>
  111. /// 查询三十天的数据
  112. /// </summary>
  113. /// <param name="jsonElement"></param>
  114. /// <returns></returns>
  115. [ProducesDefaultResponseType]
  116. [HttpPost("get-thirtydayapi")]
  117. public async Task<IActionResult> GetThirtyDayApi(JsonElement jsonElement)
  118. {
  119. jsonElement.TryGetProperty("site", out JsonElement site);
  120. var blobCilent = _azureStorage.GetBlobContainerClient(containerName: "0-public");
  121. if ($"{site}".Equals(BIConst.Global))
  122. blobCilent = _azureStorage.GetBlobContainerClient(containerName: "0-public", BIConst.Global);
  123. List<RecApiCnt> thirtyDayApi = new();
  124. List<string> day30 = TimeHelper.GetNearDay(DateTimeOffset.UtcNow, 30);
  125. foreach (var item in day30)
  126. {
  127. await foreach (BlobItem blobItem in blobCilent.GetBlobsAsync(BlobTraits.None, BlobStates.None, $"visitCnt/{item}"))
  128. {
  129. BlobClient tempClient = blobCilent.GetBlobClient(blobItem.Name);
  130. if (await tempClient.ExistsAsync())
  131. {
  132. using (var meomoryStream = new MemoryStream())
  133. {
  134. var response = blobCilent.GetBlobClient($"{blobItem.Name}").DownloadTo(meomoryStream);
  135. //var response = await blob.GetBlobClient($"{blobItem.Name}").DownloadToAsync(meomoryStream);
  136. //var temps = meomoryStream.ToString();
  137. //var temp1 = Encoding.UTF8.GetString(meomoryStream.ToArray());
  138. //var temp = Encoding.UTF8.GetString(meomoryStream.ToArray()).ToObject<RecCnt>();
  139. RecCnt recCnt = Encoding.UTF8.GetString(meomoryStream.ToArray()).ToString().ToObject<RecCnt>();
  140. thirtyDayApi.AddRange(recCnt.apiCnt);
  141. }
  142. }
  143. }
  144. }
  145. return Ok(new { state = RespondCode.Ok, thirtyDayApi });
  146. }
  147. /// <summary>
  148. /// 本地Json
  149. /// </summary>
  150. /// <param name="jsonElement"></param>
  151. /// <returns></returns>
  152. [HttpPost("get-visitjson")]
  153. public async Task<IActionResult> GetVisitJson(JsonElement jsonElement)
  154. {
  155. jsonElement.TryGetProperty("path", out JsonElement _path);
  156. jsonElement.TryGetProperty("time", out JsonElement _time);
  157. var path = $"{_environment.ContentRootPath}/JsonFile/TempFile/PT1H.json";
  158. StreamReader streamReader = new StreamReader(new FileStream(path, FileMode.Open, FileAccess.Read, FileShare.ReadWrite), Encoding.UTF8);
  159. List<object> objs = new();
  160. StringBuilder visits = new StringBuilder("[");
  161. string text;
  162. while ((text = streamReader.ReadLine()) != null)
  163. {
  164. if (streamReader.EndOfStream)
  165. visits.Append($"{text.ToString()}");
  166. else
  167. visits.Append($"{text.ToString()},");
  168. }
  169. visits.Append("]");
  170. streamReader.Close();
  171. string input = visits.ToString();
  172. List<AGInfo> aGInfos = input.ToObject<List<AGInfo>>();
  173. DateTimeOffset dtime = DateTimeOffset.UtcNow;
  174. string cHour = dtime.ToString("yyyyMMddHH");
  175. string cDay = dtime.ToString("yyyyMMdd");
  176. if (aGInfos.Count > 0)
  177. {
  178. cHour = aGInfos.Select(s => DateTimeOffset.Parse(s.time).ToString("yyyyMMddHH")).First();
  179. cDay = aGInfos.Select(s => DateTimeOffset.Parse(s.time).ToString("yyyyMMdd")).First();
  180. }
  181. RecCnt saveCnts = new();
  182. //var ipGroup = aGInfos.GroupBy(g => g.properties.clientIp).ToDictionary(k => k.Key, k => k.Count()).ToList();
  183. List<RecAppGWInfo> recInfo = aGInfos.Select(s => new RecAppGWInfo { hour = cHour, ip = s.properties.clientIp, api = s.properties.requestUri.Split("?").ToList().Count() > 1 ? s.properties.requestUri.Split("?").ToList()[0] : s.properties.requestUri, hostName = s.properties.hostname }).ToList();
  184. List<RecApiCnt> apiCnt = recInfo.GroupBy(a => a.api).Select(g => new RecApiCnt { api = g.Key, count = g.Count(), hour = cHour, hostName = g.Select(h => h.hostName).Distinct().ToList(), ip = g.Select(i => i.ip).Distinct().ToList() }).ToList();
  185. saveCnts.apiCnt= apiCnt;
  186. List<RecIpCnt> ipCnt = recInfo.GroupBy(a => a.ip).Select(g => new RecIpCnt { ip = g.Key, count = g.Count(), hour = cHour, hostName = g.Select(h => h.hostName).Distinct().ToList(), api = g.Select(i => i.api).Distinct().ToList() }).ToList();
  187. saveCnts.ipCnt = ipCnt;
  188. ////保存存至Blob文件
  189. var url = await _azureStorage.GetBlobContainerClient("0-public").UploadFileByContainer(saveCnts.ToJsonString(), $"visitCnt/{cDay}", $"{cHour}.json");
  190. var blob = _azureStorage.GetBlobContainerClient($"0-public");
  191. List<RecCnt> recCnts = new();
  192. await foreach (BlobItem blobItem in blob.GetBlobsAsync(BlobTraits.None, BlobStates.None, $"visitCnt/{cDay}"))
  193. {
  194. BlobClient blobClient = blob.GetBlobClient(blobItem.Name);
  195. if (await blobClient.ExistsAsync())
  196. {
  197. using (var meomoryStream = new MemoryStream())
  198. {
  199. var response = blob.GetBlobClient($"{blobItem.Name}").DownloadTo(meomoryStream);
  200. //var response = await blob.GetBlobClient($"{blobItem.Name}").DownloadToAsync(meomoryStream);
  201. var temps = meomoryStream.ToString();
  202. var temp1 = Encoding.UTF8.GetString(meomoryStream.ToArray());
  203. var temp = Encoding.UTF8.GetString(meomoryStream.ToArray()).ToObject<RecCnt>();
  204. RecCnt recCnt = Encoding.UTF8.GetString(meomoryStream.ToArray()).ToString().ToObject<RecCnt>();
  205. recCnts.Add(recCnt);
  206. }
  207. }
  208. }
  209. return Ok(new { state = 200, recCnts, apiCon = apiCnt.Count(), apiSum = apiCnt.Select(ap => ap.count).Sum(), ipCount = ipCnt.Count, ipSum = ipCnt.Select(ip => ip.count).Sum(), ipCnt, apiCnt }); ;
  210. }
  211. /// <summary>
  212. /// 日志访问秘钥
  213. /// </summary>
  214. /// <param name="jsonElement"></param>
  215. /// <returns></returns>
  216. [HttpPost("get-loginfos")]
  217. public async Task<IActionResult> GetOSLog(JsonElement jsonElement)
  218. {
  219. jsonElement.TryGetProperty("site", out JsonElement site);
  220. var blobClient = _azureStorage.GetBlobContainerClient($"insights-logs-applicationgatewayfirewalllog",name:BIConst.LogChina);
  221. if ($"{site}".Equals(BIConst.Global))
  222. {
  223. blobClient = _azureStorage.GetBlobContainerClient($"insights-logs-applicationgatewayfirewalllog", name: BIConst.LogGlobal);
  224. }
  225. //List<ReadContent> contents = new();
  226. List<RecCnt> recCnts = new();
  227. List<string> urls = new();
  228. //地址: y={year}/m={month}/d={day}/h={hour}/m=00/PT1H.json
  229. string logName = "resourceId=/SUBSCRIPTIONS/73B7F9EF-D8B7-4444-9E8D-D80B43BF3CD4/RESOURCEGROUPS/TEAMMODELCHENGDU/PROVIDERS/MICROSOFT.NETWORK/APPLICATIONGATEWAYS/OSFIREWARE";
  230. await foreach (BlobItem blobItem in blobClient.GetBlobsAsync(BlobTraits.None, BlobStates.None, logName))
  231. {
  232. StringBuilder visits = new("[");
  233. BlobClient tempBlobClient = blobClient.GetBlobClient(blobItem.Name);
  234. BlobDownloadInfo download = tempBlobClient.Download();
  235. var content = download.Content;
  236. string text;
  237. using (var streamReader = new StreamReader(content))
  238. {
  239. while ((text = streamReader.ReadLine()) != null)
  240. {
  241. if (streamReader.EndOfStream)
  242. visits.Append($"{text.ToString()}");
  243. else
  244. visits.Append($"{text.ToString()},");
  245. }
  246. visits.Append("]");
  247. streamReader.Close();
  248. }
  249. string input = visits.ToString();
  250. List<AGInfo> aGInfos = input.ToObject<List<AGInfo>>();
  251. DateTimeOffset dtime = DateTimeOffset.UtcNow;
  252. string cHour = dtime.ToString("yyyyMMddHH");
  253. string cDay = dtime.ToString("yyyyMMdd");
  254. if (aGInfos.Count > 0)
  255. {
  256. cHour = aGInfos.Select(s => DateTimeOffset.Parse(s.time).ToString("yyyyMMddHH")).First();
  257. cDay = aGInfos.Select(s => DateTimeOffset.Parse(s.time).ToString("yyyyMMdd")).First();
  258. }
  259. RecCnt saveCnts = new();
  260. List<RecAppGWInfo> recInfo = aGInfos.Select(s => new RecAppGWInfo { hour = cHour, ip = s.properties.clientIp, api = s.properties.requestUri.Split("?").ToList().Count() > 1 ? s.properties.requestUri.Split("?").ToList()[0] : s.properties.requestUri, hostName = s.properties.hostname }).ToList();
  261. List<RecApiCnt> apiCnt = recInfo.GroupBy(a => a.api).Select(g => new RecApiCnt { api = g.Key, count = g.Count(), hour = cHour, hostName = g.Select(h => h.hostName).Distinct().ToList(), ip = g.Select(i => i.ip).Distinct().ToList() }).ToList();
  262. saveCnts.apiCnt = apiCnt;
  263. List<RecIpCnt> ipCnt = recInfo.GroupBy(a => a.ip).Select(g => new RecIpCnt { ip = g.Key, count = g.Count(), hour = cHour, hostName = g.Select(h => h.hostName).Distinct().ToList(), api = g.Select(i => i.api).Distinct().ToList() }).ToList();
  264. saveCnts.ipCnt = ipCnt;
  265. recCnts.Add(saveCnts);
  266. ////保存存至Blob文件
  267. var url = await _azureStorage.GetBlobContainerClient("0-public").UploadFileByContainer(saveCnts.ToJsonString(), $"visitCnt/{cDay}", $"{cHour}.json");
  268. urls.Add(url);
  269. }
  270. return Ok(new { state = 200, recCnts, urls });
  271. }
  272. }
  273. }