728x90
반응형
728x170
▶ CustomNameConstraint.cs
using Microsoft.AspNetCore.Http;
using Microsoft.AspNetCore.Routing;
using System;
using System.Globalization;
using System.Text.RegularExpressions;
namespace TestProject
{
/// <summary>
/// 커스텀 명칭 제약 조건
/// </summary>
public class CustomNameConstraint : IRouteConstraint
{
//////////////////////////////////////////////////////////////////////////////////////////////////// Field
////////////////////////////////////////////////////////////////////////////////////////// Private
#region Field
/// <summary>
/// 정규식
/// </summary>
private Regex regex;
#endregion
//////////////////////////////////////////////////////////////////////////////////////////////////// Constructor
////////////////////////////////////////////////////////////////////////////////////////// Public
#region 생성자 - CustomNameConstraint()
/// <summary>
/// 생성자
/// </summary>
public CustomNameConstraint()
{
this.regex = new Regex
(
@"^[1-9]*$",
RegexOptions.CultureInvariant | RegexOptions.IgnoreCase,
TimeSpan.FromMilliseconds(100)
);
}
#endregion
//////////////////////////////////////////////////////////////////////////////////////////////////// Method
////////////////////////////////////////////////////////////////////////////////////////// Public
#region 매칭 여부 구하기 - Match(httpContext, route, routeKey, valueDictionary, routeDirection)
/// <summary>
/// 매칭 여부 구하기
/// </summary>
/// <param name="httpContext">HTTP 컨텍스트</param>
/// <param name="router">라우터</param>
/// <param name="routeKey">경로 키</param>
/// <param name="valueDictionary">경로 값 딕셔너리</param>
/// <param name="routeDirection">경로 방향</param>
/// <returns>매칭 여부</returns>
public bool Match
(
HttpContext httpContext,
IRouter router,
string routeKey,
RouteValueDictionary valueDictionary,
RouteDirection routeDirection
)
{
if(valueDictionary.TryGetValue(routeKey, out object value))
{
string parameterValue = Convert.ToString(value, CultureInfo.InvariantCulture);
if(parameterValue == null)
{
return false;
}
return regex.IsMatch(parameterValue);
}
return false;
}
#endregion
}
}
728x90
▶ Startup.cs
using Microsoft.AspNetCore.Builder;
using Microsoft.AspNetCore.Hosting;
using Microsoft.Extensions.Configuration;
using Microsoft.Extensions.DependencyInjection;
using Microsoft.Extensions.Hosting;
namespace TestProject
{
/// <summary>
/// 시작
/// </summary>
public class Startup
{
//////////////////////////////////////////////////////////////////////////////////////////////////// Property
////////////////////////////////////////////////////////////////////////////////////////// Public
#region 구성 - Configuration
/// <summary>
/// 구성
/// </summary>
public IConfiguration Configuration { get; }
#endregion
//////////////////////////////////////////////////////////////////////////////////////////////////// Constructor
////////////////////////////////////////////////////////////////////////////////////////// Public
#region 생성자 - Startup(configuration)
/// <summary>
/// 생성자
/// </summary>
/// <param name="configuration">구성</param>
public Startup(IConfiguration configuration)
{
Configuration = configuration;
}
#endregion
//////////////////////////////////////////////////////////////////////////////////////////////////// Method
////////////////////////////////////////////////////////////////////////////////////////// Public
#region 서비스 컬렉션 구성하기 - ConfigureServices(services)
/// <summary>
/// 서비스 컬렉션 구성하기
/// </summary>
/// <param name="services">서비스 컬렉션</param>
public void ConfigureServices(IServiceCollection services)
{
services.AddControllersWithViews();
services.AddRouting
(
options =>
{
options.ConstraintMap.Add("customName", typeof(CustomNameConstraint));
}
);
}
#endregion
#region 구성하기 - Configure(app, environment)
/// <summary>
/// 구성하기
/// </summary>
/// <param name="app">애플리케이션 빌더</param>
/// <param name="environment">웹 호스트 환경</param>
public void Configure(IApplicationBuilder app, IWebHostEnvironment environment)
{
if(environment.IsDevelopment())
{
app.UseDeveloperExceptionPage();
}
app.UseHttpsRedirection();
app.UseRouting();
app.UseAuthorization();
app.UseEndpoints
(
endpoints =>
{
endpoints.MapControllers();
}
);
}
#endregion
}
}
300x250
▶ Controllers/TestController.cs
using Microsoft.AspNetCore.Mvc;
using Microsoft.Docs.Samples;
namespace TestProject.Controllers
{
/// <summary>
/// 테스트 컨트롤러
/// </summary>
[ApiController]
[Route("api/[controller]")]
public class TestController : ControllerBase
{
//////////////////////////////////////////////////////////////////////////////////////////////////// Method
////////////////////////////////////////////////////////////////////////////////////////// Public
// GET /api/test/3
#region 구하기 - Get(id)
/// <summary>
/// 구하기
/// </summary>
/// <param name="id">ID</param>
/// <returns>액션 결과</returns>
[HttpGet("{id:customName}")]
public IActionResult Get(string id)
{
return ControllerContext.MyDisplayRouteInfo(id);
}
#endregion
// GET /api/test/my/3
#region 구하기 - Get(id)
/// <summary>
/// 구하기
/// </summary>
/// <param name="id">ID</param>
/// <returns>액션 결과</returns>
[HttpGet("my/{id:customName}")]
public IActionResult Get(int id)
{
return ControllerContext.MyDisplayRouteInfo(id);
}
#endregion
}
}
728x90
반응형
그리드형(광고전용)
'C# > Web API' 카테고리의 다른 글
[C#/WEB API/.NET5] 대용량 데이터를 스트리밍 방식으로 전달받기 (PostgreSQL 연동) (0) | 2021.07.25 |
---|---|
[C#/WEB API/.NET5] PostgreSQL 데이터베이스 사용하기 (0) | 2021.07.25 |
[C#/WEB API/.NET5] 커스텀 미들웨어를 사용해 API 키 인증하기 (0) | 2021.07.24 |
[C#/WEB API/.NET5] IAsyncActionFilter 인터페이스 : API 키 인증하기 (0) | 2021.07.24 |
[C#/WEB API/.NETCORE] ControllerBase 클래스 : StatusCode 메소드를 사용해 검증 오류 처리하기 (0) | 2020.10.30 |
[C#/WEB API/.NETCORE] 스캐폴딩 기능을 사용해 WEB API 앱 만들기 (0) | 2020.10.20 |
[C#/WEB API/.NETCORE] 대용량 데이터를 스트리밍 방식으로 전달받기 (0) | 2020.10.20 |
[C#/WEB API] 대용량 데이터를 스트리밍 방식으로 전달받기 (0) | 2020.10.19 |
[C#/WEB API/.NETCORE] ConsumesAttribute/ProducesAttribute 클래스 - 요청/응답 컨텐트 타입 설정하기 (0) | 2020.10.11 |
[C#/WEB API/.NETCORE] ControllerBase 클래스 : Response 속성을 사용해 파일 다운로드시 스트리밍 처리하기 (0) | 2020.10.10 |
댓글을 달아 주세요