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;
}

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

相关内容

热门资讯

经核实!酷玩联盟破解版下载,聚... 经核实!酷玩联盟破解版下载,聚星ai辅助工具收费多少,窍要教程(有挂分析)-哔哩哔哩1、任何聚星ai...
透视能赢!德普之星透视软件免费... 透视能赢!德普之星透视软件免费入口官网,德普之星辅助工具如何设置(透视)果然存在有挂(有挂透视)-哔...
刚刚!黑科技辅助软件免费,wp... 刚刚!黑科技辅助软件免费,wpk俱乐部有没有辅助,妙计教程(有挂教学)-哔哩哔哩1、下载好wpk俱乐...
透视教程!德扑圈有透视吗,德普... 透视教程!德扑圈有透视吗,德普之星透视辅助软件是真的吗(透视)果然真的有挂(有挂细节)-哔哩哔哩1、...
连日来!微乐家乡麻辣自建房辅助... 连日来!微乐家乡麻辣自建房辅助app,越乡游辅助脚本,要领教程(有挂总结)-哔哩哔哩1、任何微乐家乡...
透视ai代打!德普辅助器怎么用... 透视ai代打!德普辅助器怎么用,德普之星辅助软件(透视)竟然真的是有挂(了解有挂)-哔哩哔哩1、许多...
随着!微信边锋辅助,微乐透视辅... 随着!微信边锋辅助,微乐透视辅助工具,阶段教程(有人有挂)-哔哩哔哩1、操作简单,无需微乐透视辅助工...
透视苹果版!德普之星透视辅助,... 透视苹果版!德普之星透视辅助,德普之星辅助工具如何打开(透视)果然真的是有挂(有挂详细)-哔哩哔哩1...
据了解!玄龙透视辅助,wepo... 据了解!玄龙透视辅助,wepoker有人用过吗,模块教程(有挂透视)-哔哩哔哩;1、wepoker有...
透视神器!德普之星辅助工具如何... 透视神器!德普之星辅助工具如何设置,德普之星怎么设置埋牌(透视)真是存在有挂(有挂方法)-哔哩哔哩1...