How to correctly implement other entity's reference to Identity user?

前端 未结 2 908
春和景丽
春和景丽 2021-01-21 10:13

I\'m using Identity which has his own context.

public class ApplicationUser : IdentityUser {
    // some custom fields
}

public class IdentityContext : Identity         


        
相关标签:
2条回答
  • 2021-01-21 11:02

    Ask yourself the question, what information does ApplicationUser have that you can use in your business model? And if so, is that the right location to store it? Or do you just want to link the user?

    ApplicationUser is located in different context, though in the same DB.

    But now suppose it is not. Suppose you want to use something like IdentityServer in the future.

    I think the best approach would be to keep your business information seperated from the identity information. I wouldn't want to expose login information to the business with the posibility that it may be read or changed.

    I've seen code where the ApplicationUser (as part of the business context) was sent in a ViewModel to the client, including HashPassword. Definately something you want to prevent.

    What you can do is add a User table in MyContext to store the data you want to use. The ApplicationUser doesn't have any information you want in your business model.

    I assume all you want is to link the information to a user. And you want to profit from Entiy Framework's object linking.

    So create a User table and add a property to ApplicationUser to store the UserId of your User table. Or you can link the other way around: add ApplicationUserId to your User table. It is also possible to use the same Id for both: set ApplicationUser.Id yourself (doesn't have to be a guid) or use the generated guid for User.Id.

    In case there is some additional information in the identity context that you want to use, e.g. EmailAddress, you may consider to add claims.

    -- update --

    The idea is to add a user table to your context, not the identity context. To make it more clear I will call the table Person (not user). Notice that Person does not inherit IdentyUser / ApplicationUser.

    public class Person {
        public int Id { get; set; }
        public string FirstName { get; set; }
        public string LastName { get; set; }
        //etc..
        public string ApplicationUserId { get; set; }
    }
    
    public class MyContext :DbContext {
       public DbSet<Comment> Comments { get; set; }
       public DbSet<Person> Persons { get; set; }
       //... other DbSets
    }
    
    public class Comment{
       public int Id {get;set;}
       public string Message{get;set;}
       public DateTime Time{get;set;}
       public virtual Person Author {get;set;}
    }
    

    Now when I query all comments for the current user I can lookup the Person.Id (based on User.Identity.GetUserId()).

    Do not forget to add a Person when you create a login.

    I hope this helps. If not, please let me know.

    0 讨论(0)
  • 2021-01-21 11:02

    Example:

    public class ApplicationUser : IdentityUser {
        // some custom fields
    }
    
    public class Comment{
       public int Id {get;set;}
       public string Message{get;set;}
       public DateTime Time{get;set;}
       public string AuthorId {get;set}
       [ForeignKey("AuthorId")]
       public virtual ApplicationUser Author {get;set;}
    }
    
    public class MyContext :IdentityDbContext<ApplicationUser> {
    
    public MyContext(): base("DefaultConnection", false){ }
    
       public DbSet<Comment> Comments { get; set; }
       //... other DbSets
    }
    

    I always flow this pattern. Hopefully it's help you.

    0 讨论(0)
提交回复
热议问题