Обновление маршрутов Identity в ASP.NET Core 7

· 5 мин чтения

Даже интересно, как Microsoft называет такие редкие вещи? Я всегда думал, что на самом деле они делают это не так уж и хорошо, но, ну, вот что это такое!

Хорошая вещь в этом то, что вы можете изменить практически все, пока разрабатываете!

Вы когда-нибудь заходили на страницу и сразу понимали, что это веб-проект ASP.NET, просто выполнив процесс регистрации или входа в систему?

Со мной это часто случалось, потому что по умолчанию в создаваемом вами проекте у вас есть эти URL-адреса для входа в систему и регистрации (а также у вас есть много других страниц).

В этом уроке показан способ обновить эти URL-адреса, чтобы ваш проект выглядел лучше!

Поведение по умолчанию

Когда мы создаем проект Blazor и решаем использовать его с Identity, он отображает что-то вроде этого:

И когда мы пытаемся выполнить вход или регистрацию, мы выбираем либо /Identity/Account/Login либо /Identity/Account/Register.

Но что, если я скажу вам, что вы можете действительно обновить эти URL-адреса, чтобы они стали другими?

Формирование страниц Login и Register

Чтобы обновить эти страницы, Microsoft скрывает их, но вы можете быстро создать их и внести нужные изменения!

Для этого вам нужно зайти и Add Scaffolded Item в контекстном меню проекта, вот так:

Затем появится модальное окно, и вам придется дважды выбрать Identity и нажать Add:

После этого появится еще одно модальное окно, в котором вы сможете выбрать, какие страницы из всей идентичности вы хотите обновить. Есть много страниц, которые вы можете обновить, но мы сосредоточимся на Account/Login и Account/Register:

Теперь дайте ему немного поработать, а затем проверьте обозреватель решений, вы найдете несколько новых файлов:

Эти новые файлы представляют собой страницу входа и регистрации, которую ASP.NET добавляет в ваш проект, когда вы выбираете ее для добавления Identity!

Обновление URL-адресов

Как вы, наверное, заметили, эти файлы являются Razor-файлами, поскольку их расширение — cshtml, поэтому мы просто собираемся использовать директиву для обновления URL-адреса страницы:

@page "/login"
@model LoginModel

@{
    ViewData["Title"] = "Log in";
}

<h1>@ViewData["Title"]</h1>
<div class="row">
    <div class="col-md-4">
        <section>
            <form id="account" method="post">
                <h2>Use a local account to log in.</h2>
                <hr />
                <div asp-validation-summary="ModelOnly" class="text-danger" role="alert"></div>
                <div class="form-floating mb-3">
                    <input asp-for="Input.Email" class="form-control" autocomplete="username" aria-required="true" placeholder="[email protected]" />
                    <label asp-for="Input.Email" class="form-label">Email</label>
                    <span asp-validation-for="Input.Email" class="text-danger"></span>
                </div>
                <div class="form-floating mb-3">
                    <input asp-for="Input.Password" class="form-control" autocomplete="current-password" aria-required="true" placeholder="password" />
                    <label asp-for="Input.Password" class="form-label">Password</label>
                    <span asp-validation-for="Input.Password" class="text-danger"></span>
                </div>
                <div class="checkbox mb-3">
                    <label asp-for="Input.RememberMe" class="form-label">
                        <input class="form-check-input" asp-for="Input.RememberMe" />
                        @Html.DisplayNameFor(m => m.Input.RememberMe)
                    </label>
                </div>
                <div>
                    <button id="login-submit" type="submit" class="w-100 btn btn-lg btn-primary">Log in</button>
                </div>
                <div>
                    <p>
                        <a id="forgot-password" asp-page="./ForgotPassword">Forgot your password?</a>
                    </p>
                    <p>
                        <a asp-page="./Register" asp-route-returnUrl="@Model.ReturnUrl">Register as a new user</a>
                    </p>
                    <p>
                        <a id="resend-confirmation" asp-page="./ResendEmailConfirmation">Resend email confirmation</a>
                    </p>
                </div>
            </form>
        </section>
    </div>
    <div class="col-md-6 col-md-offset-2">
        <section>
            <h3>Use another service to log in.</h3>
            <hr />
            @{
                if ((Model.ExternalLogins?.Count ?? 0) == 0)
                {
                    <div>
                        <p>
                            There are no external authentication services configured. See this <a href="https://go.microsoft.com/fwlink/?LinkID=532715">article
                            about setting up this ASP.NET application to support logging in via external services</a>.
                        </p>
                    </div>
                }
                else
                {
                    <form id="external-account" asp-page="./ExternalLogin" asp-route-returnUrl="@Model.ReturnUrl" method="post" class="form-horizontal">
                        <div>
                            <p>
                                @foreach (var provider in Model.ExternalLogins!)
                                {
                                    <button type="submit" class="btn btn-primary" name="provider" value="@provider.Name" title="Log in using your @provider.DisplayName account">@provider.DisplayName</button>
                                }
                            </p>
                        </div>
                    </form>
                }
            }
        </section>
    </div>
</div>

@section Scripts {
    <partial name="_ValidationScriptsPartial" />
}

Как вы можете видеть, большая часть материала осталась прежней, но если вы посмотрите на самую первую строку в классе, я обновил то, что у нас было раньше:

@page

чтобы

@page "/login"

Ну, это было легко, не так ли? Теперь давайте проведем быстрый тест и проверим, работает ли это.

Прежде всего, давайте перейдем на страницу по умолчанию, которая у нас есть изначально, чтобы проверить, работает ли она еще:

Но это не так! Итак, теперь давайте проверим наш новый URL-адрес: /login:

И это работает!!

Теперь давайте сделаем то же самое для реестра: обновим его страницу и добавим нужный путь в директиву @page и проведем тест!

@page "/register"
@model RegisterModel
@{
    ViewData["Title"] = "Register";
}

<h1>@ViewData["Title"]</h1>

<div class="row">
    <div class="col-md-4">
        <form id="registerForm" asp-route-returnUrl="@Model.ReturnUrl" method="post">
            <h2>Create a new account.</h2>
            <hr />
            <div asp-validation-summary="ModelOnly" class="text-danger" role="alert"></div>
            <div class="form-floating mb-3">
                <input asp-for="Input.Email" class="form-control" autocomplete="username" aria-required="true" placeholder="[email protected]" />
                <label asp-for="Input.Email">Email</label>
                <span asp-validation-for="Input.Email" class="text-danger"></span>
            </div>
            <div class="form-floating mb-3">
                <input asp-for="Input.Password" class="form-control" autocomplete="new-password" aria-required="true" placeholder="password" />
                <label asp-for="Input.Password">Password</label>
                <span asp-validation-for="Input.Password" class="text-danger"></span>
            </div>
            <div class="form-floating mb-3">
                <input asp-for="Input.ConfirmPassword" class="form-control" autocomplete="new-password" aria-required="true" placeholder="password" />
                <label asp-for="Input.ConfirmPassword">Confirm Password</label>
                <span asp-validation-for="Input.ConfirmPassword" class="text-danger"></span>
            </div>
            <button id="registerSubmit" type="submit" class="w-100 btn btn-lg btn-primary">Register</button>
        </form>
    </div>
    <div class="col-md-6 col-md-offset-2">
        <section>
            <h3>Use another service to register.</h3>
            <hr />
            @{
                if ((Model.ExternalLogins?.Count ?? 0) == 0)
                {
                    <div>
                        <p>
                            There are no external authentication services configured. See this <a href="https://go.microsoft.com/fwlink/?LinkID=532715">article
                            about setting up this ASP.NET application to support logging in via external services</a>.
                        </p>
                    </div>
                }
                else
                {
                    <form id="external-account" asp-page="./ExternalLogin" asp-route-returnUrl="@Model.ReturnUrl" method="post" class="form-horizontal">
                        <div>
                            <p>
                                @foreach (var provider in Model.ExternalLogins!)
                                {
                                    <button type="submit" class="btn btn-primary" name="provider" value="@provider.Name" title="Log in using your @provider.DisplayName account">@provider.DisplayName</button>
                                }
                            </p>
                        </div>
                    </form>
                }
            }
        </section>
    </div>
</div>

@section Scripts {
    <partial name="_ValidationScriptsPartial" />
}

Я обновил верхнюю часть с помощью @page "/login" и теперь проверяем, работает ли она:

Тоже работает!!

Вот и всеНадеюсь, вы научились обновлять эти URL-адреса, главным образом потому, что в некоторых проектах, когда вы делаете URL-адреса определенным образом, а затем Identity выглядит по-другому, это отстой, ха-ха!

Если вам что-нибудь понадобится, просто напишите мне в Твиттере или отправьте электронное письмо, и я постараюсь помочь!