using FrontendWebApi.Jwt; using FrontendWebApi.Models; using Microsoft.AspNetCore.Authorization; using Microsoft.AspNetCore.Http; using Microsoft.AspNetCore.Mvc; using Microsoft.AspNetCore.Mvc.Filters; using Microsoft.Extensions.Configuration; using Repository.BackendRepository.Interface; using Repository.BaseRepository.Interface; using Repository.FrontendRepository.Interface; using Repository.Helper; using System; using System.Collections.Generic; using System.Linq; using System.Threading.Tasks; using Microsoft.Extensions.DependencyInjection; using Microsoft.Extensions.Logging; using System.IdentityModel.Tokens.Jwt; using System.Net; using Newtonsoft.Json; namespace FrontendWebApi.ApiControllers { public class MyBaseApiController : Controller where T : MyBaseApiController { private ILogger _logger; protected ILogger Logger => _logger ?? (_logger = HttpContext?.RequestServices.GetService>()); private IJwtHelpers jwt => HttpContext?.RequestServices.GetService(); public string baseURL => HttpContext?.Request.Scheme + "://" + HttpContext?.Request.Host + "/"; public MyBaseApiController() { } protected JwtGet myUser; protected string jwt_str = null; protected bool jwtlife = true; public string controllerName; public string actionName; public string main_system_type = "device_system_category_layer2"; public string sub_system_type = "device_system_category_layer3"; public string forge_node_name_system_type = "forge_check_tag_id"; public ErrorCode errorCode = new ErrorCode(); [Authorize] public override void OnActionExecuting(ActionExecutingContext filterContext) { controllerName = ControllerContext.RouteData.Values["controller"].ToString(); //controller名稱 actionName = ControllerContext.RouteData.Values["action"].ToString(); //action名稱 var ctx = filterContext.HttpContext; ctx.Response.Headers.Add("Access-Control-Allow-Origin", "*"); ctx.Response.Headers.Add("Access-Control-Allow-Headers", "*"); ctx.Response.Headers.Add("Access-Control-Allow-Credentials", "true"); EDFunction edFunction = new EDFunction(); myUser = new JwtGet() { account = User.Claims.Where(a => a.Type == "account").Select(e => e.Value).FirstOrDefault(), email = User.Claims.Where(a => a.Type == "email").Select(e => e.Value).FirstOrDefault(), full_name = User.Claims.Where(a => a.Type == "full_name").Select(e => e.Value).FirstOrDefault(), exp = User.Claims.Where(a => a.Type == "exp").Select(e => Convert.ToInt32(e.Value)).FirstOrDefault(), nbf = User.Claims.Where(a => a.Type == "nbf").Select(e => Convert.ToInt32(e.Value)).FirstOrDefault(), userinfo_guid = User.Claims.Where(a => a.Type == "userinfo_guid").Select(e => e.Value).FirstOrDefault(), }; Logger.LogError("MyBaseApi - 61 : " + JsonConvert.SerializeObject(myUser) + "---" + DateTime.Now.AddHours(-8).AddMinutes(10).Subtract(new DateTime(1970, 1, 1)).TotalSeconds); //if (myUser.exp == 0) //{ // jwt_str = "Jwt Token不合法"; // jwtlife = false; // filterContext.Result = new JsonResult(new { HttpStatusCode.Unauthorized }); //} //if (myUser.exp <= DateTime.Now.AddHours(-8).AddMinutes(10).Subtract(new DateTime(1970, 1, 1)).TotalSeconds) //{ jwtlife = true; JwtLogin jwtLoing = new JwtLogin() { account = myUser.account, email = myUser.email, full_name = myUser.full_name, userinfo_guid = myUser.userinfo_guid }; jwt_str = jwt.GenerateToken(jwtLoing).token; //} Logger.LogError("MyBaseApi - 98 : " + JsonConvert.SerializeObject(myUser)); base.OnActionExecuting(filterContext); } } }