ASP .NET Core MVC 将文本文件上传到具有已登录用户外键的现有数据库
创始人
2024-11-11 13:31:16
0

要将文本文件上传到具有已登录用户外键的现有数据库,你可以按照以下步骤进行操作:

  1. 创建一个带有外键的数据库表,用于存储用户和上传的文件。可以使用Entity Framework Core来生成数据库模型和迁移脚本。
public class User
{
    public int Id { get; set; }
    public string Username { get; set; }
    // 其他用户属性...

    public ICollection Files { get; set; }
}

public class File
{
    public int Id { get; set; }
    public string FileName { get; set; }
    public byte[] Content { get; set; }
    // 其他文件属性...

    public int UserId { get; set; }
    public User User { get; set; }
}
  1. 创建一个文件上传视图和控制器动作。
// 上传文件视图
// 上传文件控制器动作 [HttpPost] public async Task Upload(IFormFile file) { if (file == null || file.Length == 0) { return BadRequest("No file selected"); } // 获取已登录用户的外键 int userId = // 获取已登录用户的外键代码 using (var memoryStream = new MemoryStream()) { await file.CopyToAsync(memoryStream); byte[] content = memoryStream.ToArray(); // 将文件保存到数据库 var newFile = new File { FileName = file.FileName, Content = content, UserId = userId }; // 使用Entity Framework Core将文件保存到数据库 _context.Files.Add(newFile); await _context.SaveChangesAsync(); } return RedirectToAction("Index", "Home"); }
  1. 在控制器中获取已登录用户的外键。这通常涉及到身份验证和授权。你可以使用ASP.NET Core Identity来管理用户登录和角色。
private readonly UserManager _userManager;

public MyController(UserManager userManager)
{
    _userManager = userManager;
}

public async Task GetLoggedInUserId()
{
    var user = await _userManager.GetUserAsync(User);
    return user.Id;
}

请注意,上述示例中的代码只是一个简单的示例,你可能需要根据自己的需求进行适当的修改和扩展。

相关内容

热门资讯

透视脚本!wepoker辅助器... 透视脚本!wepoker辅助器(透视)wepoker轻量版透视(都是一直总是有辅助器)-哔哩哔哩1、...
透视app!丽水都莱辅助软件(... 透视app!丽水都莱辅助软件(辅助)潮友辅助器开挂软件(一贯一直总是有挂)-哔哩哔哩1、在潮友辅助器...
透视技巧!德州局怎么透视(透视... 透视技巧!德州局怎么透视(透视)hhpoker免费透视脚本(其实是有脚本)-哔哩哔哩一、hhpoke...
透视技巧!wepoker辅助器... 透视技巧!wepoker辅助器软件下载(透视)wepoker高级辅助(切实是真的有挂)-哔哩哔哩1....
透视神器!wepoker透视脚... 您好,wepoker透视脚本苹果版这款游戏可以开挂的,确实是有挂的,需要了解加去威信【4852750...
透视工具!hhpoker作必弊... 透视工具!hhpoker作必弊码(透视)hhpoker怎么破解(本来是有挂)-哔哩哔哩一、hhpok...
透视技巧!wepoker数据分... 透视技巧!wepoker数据分析(透视)wepoker可以透视码(一直一直都是有透视)-哔哩哔哩1、...
透视方法!wepoker私人局... 透视方法!wepoker私人局俱乐部(透视)wepoker私人局有透视吗(本来一直都是有辅助器)-哔...
透视技巧!wepoker祈福有... 透视技巧!wepoker祈福有用吗(透视)wejoker免费脚本(果然一直都是有脚本)-哔哩哔哩1、...
透视app!wpk辅助购买(透... 透视app!wpk辅助购买(透视)wpk俱乐部是真的吗(都是存在有透视)-哔哩哔哩1、每一步都需要思...