This commit is contained in:
xljiulang 2021-08-13 20:50:17 +08:00
commit 3f4f451435
7 changed files with 33 additions and 17 deletions

View File

@ -6,6 +6,7 @@
<Copyright>https://github.com/dotnetcore/FastGithub</Copyright> <Copyright>https://github.com/dotnetcore/FastGithub</Copyright>
<RuntimeIdentifier>win-x64</RuntimeIdentifier> <RuntimeIdentifier>win-x64</RuntimeIdentifier>
<TargetFrameworks>net5.0;net6.0</TargetFrameworks> <TargetFrameworks>net5.0;net6.0</TargetFrameworks>
<DisableImplicitNamespaceImports>true</DisableImplicitNamespaceImports>
</PropertyGroup> </PropertyGroup>
<PropertyGroup Condition="'$(Configuration)'=='Release'"> <PropertyGroup Condition="'$(Configuration)'=='Release'">

View File

@ -97,12 +97,6 @@ namespace FastGithub.DomainResolve
throw new FastGithubException($"dns{dns}解析不到{domain}的ip"); throw new FastGithubException($"dns{dns}解析不到{domain}的ip");
} }
// 不允许域名解析指向FastGithub自身造成消息死循环
if (LocalMachine.ContainsIPAddress(address) == true)
{
throw new FastGithubException($"dns{dns}被污染,解析{domain}为{address}");
}
this.logger.LogInformation($"[{domain}->{address}]"); this.logger.LogInformation($"[{domain}->{address}]");
return address; return address;
} }

View File

@ -1,6 +1,9 @@
using FastGithub.Configuration; using FastGithub.Configuration;
using FastGithub.DomainResolve; using FastGithub.DomainResolve;
using System.Net.Http; using System.Net.Http;
using System.Net.Http.Headers;
using System.Threading;
using System.Threading.Tasks;
namespace FastGithub.Http namespace FastGithub.Http
{ {
@ -9,6 +12,11 @@ namespace FastGithub.Http
/// </summary> /// </summary>
public class HttpClient : HttpMessageInvoker public class HttpClient : HttpMessageInvoker
{ {
/// <summary>
/// 插入的UserAgent标记
/// </summary>
private readonly static ProductInfoHeaderValue userAgent = new(new ProductHeaderValue(nameof(FastGithub), "1.0"));
/// <summary> /// <summary>
/// http客户端 /// http客户端
/// </summary> /// </summary>
@ -28,5 +36,21 @@ namespace FastGithub.Http
: base(handler, disposeHandler) : base(handler, disposeHandler)
{ {
} }
/// <summary>
/// 发送请求
/// </summary>
/// <param name="request"></param>
/// <param name="cancellationToken"></param>
/// <returns></returns>
public override Task<HttpResponseMessage> SendAsync(HttpRequestMessage request, CancellationToken cancellationToken)
{
if (request.Headers.UserAgent.Contains(userAgent))
{
throw new FastGithubException($"由于{request.RequestUri}实际指向了{nameof(FastGithub)}自身,{nameof(FastGithub)}已中断本次转发");
}
request.Headers.UserAgent.Add(userAgent);
return base.SendAsync(request, cancellationToken);
}
} }
} }

View File

@ -10,15 +10,15 @@ namespace FastGithub.ReverseProxy
/// <summary> /// <summary>
/// 请求日志中间件 /// 请求日志中间件
/// </summary> /// </summary>
sealed class RequestLoggingMilldeware sealed class RequestLoggingMiddleware
{ {
private readonly ILogger<RequestLoggingMilldeware> logger; private readonly ILogger<RequestLoggingMiddleware> logger;
/// <summary> /// <summary>
/// 请求日志中间件 /// 请求日志中间件
/// </summary> /// </summary>
/// <param name="logger"></param> /// <param name="logger"></param>
public RequestLoggingMilldeware(ILogger<RequestLoggingMilldeware> logger) public RequestLoggingMiddleware(ILogger<RequestLoggingMiddleware> logger)
{ {
this.logger = logger; this.logger = logger;
} }
@ -31,8 +31,7 @@ namespace FastGithub.ReverseProxy
/// <returns></returns> /// <returns></returns>
public async Task InvokeAsync(HttpContext context, RequestDelegate next) public async Task InvokeAsync(HttpContext context, RequestDelegate next)
{ {
var stopwatch = new Stopwatch(); var stopwatch = Stopwatch.StartNew();
stopwatch.Start();
try try
{ {

View File

@ -16,8 +16,8 @@ namespace FastGithub
/// <returns></returns> /// <returns></returns>
public static IApplicationBuilder UseRequestLogging(this IApplicationBuilder app) public static IApplicationBuilder UseRequestLogging(this IApplicationBuilder app)
{ {
var middlware = app.ApplicationServices.GetRequiredService<RequestLoggingMilldeware>(); var middleware = app.ApplicationServices.GetRequiredService<RequestLoggingMiddleware>();
return app.Use(next => context => middlware.InvokeAsync(context, next)); return app.Use(next => context => middleware.InvokeAsync(context, next));
} }
/// <summary> /// <summary>

View File

@ -19,7 +19,7 @@ namespace FastGithub
.AddMemoryCache() .AddMemoryCache()
.AddHttpForwarder() .AddHttpForwarder()
.AddSingleton<CertService>() .AddSingleton<CertService>()
.AddSingleton<RequestLoggingMilldeware>() .AddSingleton<RequestLoggingMiddleware>()
.AddSingleton<ReverseProxyMiddleware>(); .AddSingleton<ReverseProxyMiddleware>();
} }
} }

View File

@ -1,3 +1 @@
@{ 
Layout = "_Layout";
}