asp.net identity控制器及其视图位于哪里?
创始人
2024-09-16 07:00:46
0

在ASP.NET Identity中,控制器和视图的位置可以根据项目的需求进行配置。默认情况下,它们位于项目的Controllers和Views文件夹中。

以下是一个示例解决方法:

  1. 创建一个名为"AccountController"的控制器,它将处理用户身份验证和授权相关的操作。
using Microsoft.AspNetCore.Mvc;
using Microsoft.AspNetCore.Identity;

public class AccountController : Controller
{
    private readonly SignInManager _signInManager;

    public AccountController(SignInManager signInManager)
    {
        _signInManager = signInManager;
    }

    // 添加你的身份验证和授权相关的操作方法
}
  1. 创建一个名为"Account"的文件夹,并在其中创建一个名为"Login.cshtml"的视图,用于显示用户登录表单。
@model LoginViewModel

请注意,在上述代码中,我们使用了Razor视图引擎来生成HTML标记,并使用了ASP.NET Core的标记助手(asp-for)来生成表单字段。

  1. 将控制器和视图添加到你的项目中,并根据需要进行相应的配置。你可以在Startup.cs文件中添加以下配置代码:
using Microsoft.AspNetCore.Builder;
using Microsoft.AspNetCore.Identity;
using Microsoft.EntityFrameworkCore;
using Microsoft.Extensions.Configuration;
using Microsoft.Extensions.DependencyInjection;

public class Startup
{
    private readonly IConfiguration _configuration;

    public Startup(IConfiguration configuration)
    {
        _configuration = configuration;
    }

    public void ConfigureServices(IServiceCollection services)
    {
        // 配置数据库上下文
        services.AddDbContext(options =>
            options.UseSqlServer(_configuration.GetConnectionString("DefaultConnection")));

        // 配置Identity
        services.AddIdentity()
            .AddEntityFrameworkStores()
            .AddDefaultTokenProviders();
        
        // 配置身份验证
        services.Configure(options =>
        {
            // 添加你的身份验证配置选项
        });

        // 配置控制器和视图的位置
        services.AddControllersWithViews()
            .AddRazorRuntimeCompilation()
            .AddViewOptions(options =>
            {
                options.ViewLocationFormats.Add("/Views/Account/{0}.cshtml");
                options.ViewLocationFormats.Add("/Views/Shared/{0}.cshtml");
            });
    }

    public void Configure(IApplicationBuilder app)
    {
        // 配置中间件和路由
        app.UseRouting();
        app.UseAuthentication();
        app.UseAuthorization();
        app.UseEndpoints(endpoints =>
        {
            endpoints.MapControllerRoute(
                name: "default",
                pattern: "{controller=Home}/{action=Index}/{id?}");
        });
    }
}

在上述代码中,我们通过调用services.AddControllersWithViews()方法来配置控制器和视图。然后,我们使用.AddViewOptions()方法来添加自定义视图位置的选项。在这个示例中,我们将Account文件夹添加到视图位置列表中。

请注意,这只是一个示例解决方法,你可以根据你的项目需求进行适当的配置和调整。

相关内容

热门资讯

详细透视!we-poker靠谱... 详细透视!we-poker靠谱吗,微乐陕西三代自建房挂,绝活儿教程(有挂秘诀)-哔哩哔哩1、每一步都...
总结透视!xpoker辅助控制... 总结透视!xpoker辅助控制,贵州微乐自建房辅助软件下载,法子教程(竟然有挂)-哔哩哔哩1、玩家可...
详情透视!wepoker手机版... 详情透视!wepoker手机版辅助,手机微信小程序游戏破解器下载,窍门教程(的确有挂)-哔哩哔哩1、...
辅助透视!德普之星辅助工具如何... 辅助透视!德普之星辅助工具如何打开,微信小程序微乐房间有挂吗,指引教程(有挂方法)-哔哩哔哩小薇(辅...
详情透视!wepoker免费脚... 详情透视!wepoker免费脚本,微信小程序游戏破解微乐游戏,方案教程(有挂详情)-哔哩哔哩1、上手...
专业透视!wpk插件辅助,微乐... 专业透视!wpk插件辅助,微乐广西小程序,资料教程(证实有挂)-哔哩哔哩1、操作简单,无需wpk插件...
分享透视!wpk透视是真的假的... 分享透视!wpk透视是真的假的,微信小程序游戏破解器,阶段教程(有挂秘籍)-哔哩哔哩一、wpk透视是...
曝光透视!如何下载德普之星辅助... 曝光透视!如何下载德普之星辅助软件,微信小程序修改器,举措教程(有挂教程)-哔哩哔哩进入游戏-大厅左...
关于透视!hhpoker德州牛... 关于透视!hhpoker德州牛仔视频,微信小程序微乐辅助器免费下载,经验教程(讲解有挂)-哔哩哔哩1...
解谜透视!德州局透视脚本,微信... 解谜透视!德州局透视脚本,微信小程序微乐破解器2025,举措教程(有挂教程)-哔哩哔哩1、德州局透视...