| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223 |
- using Hangfire;
- using Masuit.MyBlogs.Core.Common;
- using Masuit.MyBlogs.Core.Configs;
- using Masuit.MyBlogs.Core.Extensions;
- using Masuit.MyBlogs.Core.Infrastructure.Services;
- using Masuit.MyBlogs.Core.Models.Enum;
- using Masuit.Tools;
- using Masuit.Tools.Logging;
- using Masuit.Tools.Security;
- using Masuit.Tools.Systems;
- using Microsoft.AspNetCore.Diagnostics;
- using Microsoft.AspNetCore.Http;
- using Microsoft.AspNetCore.Mvc;
- using Microsoft.EntityFrameworkCore;
- using System;
- using System.Web;
- namespace Masuit.MyBlogs.Core.Controllers
- {
- /// <summary>
- /// 错误页
- /// </summary>
- [ApiExplorerSettings(IgnoreApi = true)]
- public class ErrorController : Controller
- {
- public BroadcastService BroadcastService { get; set; }
- /// <summary>
- /// 404
- /// </summary>
- /// <returns></returns>
- [Route("error"), Route("{*url}", Order = 99999), ResponseCache(Duration = 36000)]
- public ActionResult Index()
- {
- if (Request.Method.ToLower().Equals("get"))
- {
- Response.StatusCode = 404;
- return View();
- }
- return Json(new
- {
- StatusCode = 404,
- Success = false,
- Message = "页面未找到!"
- });
- }
- /// <summary>
- /// 503
- /// </summary>
- /// <returns></returns>
- [Route("ServiceUnavailable")]
- public ActionResult ServiceUnavailable()
- {
- var feature = HttpContext.Features.Get<IExceptionHandlerPathFeature>();
- if (feature != null)
- {
- string err;
- var req = HttpContext.Request;
- var ip = HttpContext.Connection.RemoteIpAddress.MapToIPv4().ToString();
- switch (feature.Error)
- {
- case DbUpdateConcurrencyException ex:
- err = $"异常源:{ex.Source},异常类型:{ex.GetType().Name},\n请求路径:{req.Scheme}://{req.Host}{HttpUtility.UrlDecode(req.Path)},客户端用户代理:{req.Headers["User-Agent"]},客户端IP:{ip}\t{ex.InnerException?.Message}\t";
- LogManager.Error(err, ex);
- break;
- case DbUpdateException ex:
- err = $"异常源:{ex.Source},异常类型:{ex.GetType().Name},\n请求路径:{req.Scheme}://{req.Host}{HttpUtility.UrlDecode(req.Path)},客户端用户代理:{req.Headers["User-Agent"]},客户端IP:{ip}\t{ex?.InnerException?.Message}\t";
- LogManager.Error(err, ex);
- break;
- case AggregateException ex:
- LogManager.Debug("↓↓↓" + ex.Message + "↓↓↓");
- ex.Handle(e =>
- {
- LogManager.Error($"异常源:{e.Source},异常类型:{e.GetType().Name},\n请求路径:{req.Scheme}://{req.Host}{HttpUtility.UrlDecode(req.Path)},客户端用户代理:{req.Headers["User-Agent"]},客户端IP:{ip}\t", e);
- return true;
- });
- break;
- case NotFoundException ex:
- Response.StatusCode = 404;
- return Request.Method.ToLower().Equals("get") ? (ActionResult)View("Index") : Json(new
- {
- StatusCode = 404,
- Success = false,
- ex.Message
- });
- default:
- LogManager.Error($"异常源:{feature.Error.Source},异常类型:{feature.Error.GetType().Name},\n请求路径:{req.Scheme}://{req.Host}{HttpUtility.UrlDecode(req.Path)},客户端用户代理:{req.Headers["User-Agent"]},客户端IP:{ip}\t", feature.Error);
- break;
- }
- }
- if (Request.Method.ToLower().Equals("get"))
- {
- Response.StatusCode = 503;
- return View();
- }
- return Json(new
- {
- StatusCode = 503,
- Success = false,
- Message = "服务器发生错误!"
- });
- }
- /// <summary>
- /// 访问被拒绝
- /// </summary>
- /// <returns></returns>
- [Route("AccessDeny"), ResponseCache(Duration = 360000)]
- public ActionResult AccessDeny()
- {
- if (Request.Cookies["Email"].MDString3(AppConfig.BaiduAK).Equals(Request.Cookies["FullAccessToken"]))
- {
- return Redirect("/");
- }
- Response.StatusCode = 403;
- return View();
- }
- /// <summary>
- /// 临时被拒绝
- /// </summary>
- /// <returns></returns>
- [Route("TempDeny"), ResponseCache(Duration = 360000)]
- public ActionResult TempDeny()
- {
- Response.StatusCode = 403;
- return View();
- }
- /// <summary>
- /// 网站升级中
- /// </summary>
- /// <returns></returns>
- [Route("ComingSoon"), ResponseCache(Duration = 360000)]
- public ActionResult ComingSoon()
- {
- return View();
- }
- /// <summary>
- /// 检查访问密码
- /// </summary>
- /// <param name="email"></param>
- /// <param name="token"></param>
- /// <returns></returns>
- [HttpPost, ValidateAntiForgeryToken, AllowAccessFirewall, ResponseCache(Duration = 115, VaryByQueryKeys = new[] { "email", "token" })]
- public ActionResult CheckViewToken(string email, string token)
- {
- if (string.IsNullOrEmpty(token))
- {
- return ResultData(null, false, "请输入访问密码!");
- }
- var s = RedisHelper.Get("token:" + email);
- if (!token.Equals(s))
- {
- return ResultData(null, false, "访问密码不正确!");
- }
- Response.Cookies.Append("Email", email, new CookieOptions
- {
- Expires = DateTime.Now.AddYears(1)
- });
- Response.Cookies.Append("FullAccessToken", email.MDString3(AppConfig.BaiduAK), new CookieOptions
- {
- Expires = DateTime.Now.AddYears(1)
- });
- return ResultData(null);
- }
- /// <summary>
- /// 检查授权邮箱
- /// </summary>
- /// <param name="email"></param>
- /// <returns></returns>
- [HttpPost, ValidateAntiForgeryToken, AllowAccessFirewall, ResponseCache(Duration = 115, VaryByQueryKeys = new[] { "email" })]
- public ActionResult GetViewToken(string email)
- {
- if (string.IsNullOrEmpty(email) || !email.MatchEmail())
- {
- return ResultData(null, false, "请输入正确的邮箱!");
- }
- if (RedisHelper.Exists("get:" + email))
- {
- RedisHelper.Expire("get:" + email, 120);
- return ResultData(null, false, "发送频率限制,请在2分钟后重新尝试发送邮件!请检查你的邮件,若未收到,请检查你的邮箱地址或邮件垃圾箱!");
- }
- if (!BroadcastService.Any(b => b.Email.Equals(email) && b.SubscribeType == SubscribeType.ArticleToken))
- {
- return ResultData(null, false, "您目前没有权限访问这个链接,请联系站长开通访问权限!");
- }
- var token = SnowFlake.GetInstance().GetUniqueShortId(6);
- RedisHelper.Set("token:" + email, token, 86400);
- BackgroundJob.Enqueue(() => CommonHelper.SendMail(CommonHelper.SystemSettings["Domain"] + "博客访问验证码", $"{CommonHelper.SystemSettings["Domain"]}本次验证码是:<span style='color:red'>{token}</span>,有效期为24h,请按时使用!", email));
- RedisHelper.Set("get:" + email, token, 120);
- return ResultData(null);
- }
- /// <summary>
- /// 响应数据
- /// </summary>
- /// <param name="data">数据</param>
- /// <param name="success">响应状态</param>
- /// <param name="message">响应消息</param>
- /// <returns></returns>
- public ActionResult ResultData(object data, bool success = true, string message = "")
- {
- return Ok(new
- {
- Success = success,
- Message = message,
- Data = data
- });
- }
- }
- }
|