Vous devez appeler la " WebSecurity.Méthode InitializeDatabaseConnection "avant d'appeler toute autre méthode de la classe "WebSecurity"

Chaque fois que je redémarre le Débogage sous Visual Studio, j'obtiens cette foutu erreur:

vous devez appeler la " WebSecurity.Méthode InitializeDatabaseConnection" avant d'appeler toute autre méthode de la classe" WebSecurity". Ce l'appel doit être placé dans un _AppStart.cshtml fichier dans la racine de votre site.

mais c'est à chaque fois, et quand je déploie l'application à prod. J'obtiens cette erreur ici, et puis, au hasard.

je mets la bonne étiquette :

[Authorize(Roles = "admin")]
[InitializeSimpleMembership]
public class IndexController : Controller

à controller et voici le filtre tel qu'il est. Il juste ne marche pas envie de travailler.

using System;
using System.Data.Entity;
using System.Data.Entity.Infrastructure;
using System.Threading;
using System.Web.Mvc;
using MeetingTaskManagement.Models;
using WebMatrix.WebData;

namespace MeetingTaskManagement.Filters
{
    [AttributeUsage(AttributeTargets.Class | AttributeTargets.Method, AllowMultiple = false, Inherited = true)]
    public sealed class InitializeSimpleMembershipAttribute : ActionFilterAttribute
    {
        private static SimpleMembershipInitializer _initializer;
        private static object _initializerLock = new object();
        private static bool _isInitialized;

        public override void OnActionExecuting(ActionExecutingContext filterContext)
        {
            // Ensure ASP.NET Simple Membership is initialized only once per app start
            LazyInitializer.EnsureInitialized(ref _initializer, ref _isInitialized, ref _initializerLock);
        }

        private class SimpleMembershipInitializer
        {
            public SimpleMembershipInitializer()
            {
                Database.SetInitializer<UsersContext>(null);

                try
                {
                    using (var context = new UsersContext())
                    {
                        if (!context.Database.Exists())
                        {
                            // Create the SimpleMembership database without Entity Framework migration schema
                            ((IObjectContextAdapter)context).ObjectContext.CreateDatabase();
                        }
                    }

                    WebSecurity.InitializeDatabaseConnection("DefaultConnection", "UserProfile", "UserId", "UserName", autoCreateTables: true);
                }
                catch (Exception ex)
                {
                    throw new InvalidOperationException("The ASP.NET Simple Membership database could not be initialized. For more information, please see http://go.microsoft.com/fwlink/?LinkId=256588", ex);
                }
            }
        }
    }
}

quelqu'un peut-il m'aider à régler cette question?

21
demandé sur DarthVader 2013-07-24 19:52:47

6 réponses

supprimez L'attribut SimpleMemberShip de vos controllers et détruisez-le. Ajoutez ce qui suit à votre global.asax.

    private static SimpleMembershipInitializer _initializer;
    private static object _initializerLock = new object();
    private static bool _isInitialized;

    protected void Application_Start()
    {
        AreaRegistration.RegisterAllAreas();
        WebApiConfig.Register(GlobalConfiguration.Configuration);
        FilterConfig.RegisterGlobalFilters(GlobalFilters.Filters);
        RouteConfig.RegisterRoutes(RouteTable.Routes);
        BundleConfig.RegisterBundles(BundleTable.Bundles);
        AuthConfig.RegisterAuth();

        LazyInitializer.EnsureInitialized(ref _initializer, ref _isInitialized, ref _initializerLock);
    }

    public class SimpleMembershipInitializer
    {
        public SimpleMembershipInitializer()
        {
            using (var context = new UsersContext())
                context.UserProfiles.Find(1);

            if (!WebSecurity.Initialized)
                WebSecurity.InitializeDatabaseConnection("DefaultConnection", "UserProfile", "UserId", "UserName", autoCreateTables: true);
        }
    }
62
répondu Bastaspast 2013-07-25 09:58:10
class AuthConfig comme ceci:

public static class AuthConfig
{
    private static SimpleMembershipInitializer _initializer;
    private static object _initializerLock = new object();
    private static bool _isInitialized;

    public static void RegisterAuth()
    {
        // Ensure ASP.NET Simple Membership is initialized only once per app start
        LazyInitializer.EnsureInitialized(ref _initializer, ref _isInitialized, ref _initializerLock);

        // To let users of this site log in using their accounts from other sites such as Microsoft, Facebook, and Twitter,
        // you must update this site. For more information visit http://go.microsoft.com/fwlink/?LinkID=252166

        //OAuthWebSecurity.RegisterMicrosoftClient(
        //    clientId: "",
        //    clientSecret: "");

        //OAuthWebSecurity.RegisterTwitterClient(
        //    consumerKey: "",
        //    consumerSecret: "");

        //OAuthWebSecurity.RegisterFacebookClient(
        //    appId: "",
        //    appSecret: "");

        //OAuthWebSecurity.RegisterGoogleClient();
    }

    private class SimpleMembershipInitializer
    {
        public SimpleMembershipInitializer()
        {
            Database.SetInitializer<UsersContext>(null);

            try
            {
                using (var context = new UsersContext())
                {
                    if (!context.Database.Exists())
                    {
                        // Create the SimpleMembership database without Entity Framework migration schema
                        ((IObjectContextAdapter)context).ObjectContext.CreateDatabase();
                    }
                }

                WebSecurity.InitializeDatabaseConnection("DefaultConnection", "UserProfile", "UserId", "UserName", autoCreateTables: true);
            }
            catch (Exception ex)
            {
                throw new InvalidOperationException("The ASP.NET Simple Membership database could not be initialized. For more information, please see http://go.microsoft.com/fwlink/?LinkId=256588", ex);
            }
        }
    }
}
9
répondu Bolt Thunder 2013-09-16 11:26:08

je passe simplement le [InitializeSimpleMembership] au Controller HomeController, et je l'efface du Controller account. Parce que les initialisations sont faites dans une manière paresseuse.. J'ai juste envie de se précipiter.. et cela a fonctionné!!!

4
répondu lienysd 2013-11-23 21:37:10

j'étais un smartass en utilisant un seul contexte à la fois pour les fournisseurs de membres et pour mes modèles de domaines. Il s'avère que c'était le problème; vous ne pouvez pas utiliser les classes de fournisseur D'affiliation et de domaine dans un seul contexte.

vous devez avoir deux contextes.

1
répondu DarthVader 2013-07-24 19:49:56

L'exigence est seulement d'appeler la connexion à la base de données WebSecurity, vous pouvez faire ce qui suit qui fonctionne:

var WebSecDBContx = new UsersContext();
var CreatedByUser = WebSecDBContx.UserProfiles.Find(UserID);
string CreatedByUserName = CreatedByUser.UserName;
0
répondu raju1208 2014-09-27 09:35:36

pourquoi ne pas simplement créer le _AppStart.cshtml dans la racine du projet et y placer le code d'initialisation comme l'indique le message d'erreur.

@{WebMatrix.WebData.WebSecurity.InitializeDatabaseConnection("DefaultConnection", "TableName", "ColumnId", "ColumnName", autoCreateTables: false);}
0
répondu Daniel Madriz 2017-02-15 18:11:42