4

Asp.Net Mvc 4 Internet App を開きました。テンプレート。そして、データベースの接続文字列を次のように設定します。

<connectionStrings>
    <add name="DefaultConnection" connectionString="Data Source=ALI-PC\;Initial Catalog=OsosPlusDb;Persist Security Info=True;User ID=sa;Password=sa;" providerName="System.Data.SqlClient" />
</connectionStrings>

プロジェクトを実行し、登録ボタンをクリックします。次のような新しいユーザーを作成しました。

ここに画像の説明を入力

投稿するために登録をクリックすると、次のエラーが表示されます。

ここに画像の説明を入力

ただし、DB に新しいユーザーを作成し、membership_user を作成しません (Membership テーブルには追加されたユーザー情報が含まれていません)。

ここに画像の説明を入力

何が問題なのかわかりません。エラーが発生しない場合もあります。

アップデート

そして例外スナップショット:

ここに画像の説明を入力

アカウントモデル:

public class UsersContext : DbContext
{
    public UsersContext()
        : base("DefaultConnection")
    {
    }

    public DbSet<UserProfile> UserProfiles { get; set; }
}

[Table("UserProfile")]
public class UserProfile
{
    [Key]
    [DatabaseGeneratedAttribute(DatabaseGeneratedOption.Identity)]
    public int UserId { get; set; }
    public string UserName { get; set; }
}

InitializeSimpleMembershipAttribute.cs

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

最後の編集と要約

問題は文字 ("i") です。「i」を使用しない場合は、すべて問題ありません。しかし、私がそれを使用すると、そのエラーが発生しました。この問題を解決するにはどうすればよいですか。

4

3 に答える 3

8

データベースを手動で作成し (プロジェクトがデータベースを自動的に作成することを許可しないでください)、データベースを作成するときに、[オプション] で照合順序を Latin1_General_CI_AS に設定します。

また

データベースでトルコ語の文字を使用する場合、データベースの照合順序は Turkish_CI_AS である必要があり、列の照合順序を変更できます。手順に従います。

( PS:照合は、トルコ語の文字を使用し、a、b、c、ç、d、e、f、g、h、ı、i、.. のように並べ替えたい場合の並べ替えに関するものです。データベースの照合はトルコ語でなければなりません..)

1) UserName 列を右クリックし、[変更] をクリックします。

ここに画像の説明を入力

2) 照合..をクリックします。

ここに画像の説明を入力

3) そして、Latin1_General を選択します。

ここに画像の説明を入力

[OK] をクリックして、変更を保存します。

于 2013-02-26T15:55:15.307 に答える
2

少し遅れていることはわかっていますが、問題はデータベースの照合定義です。データベースの作成中に「TURKISH_CI_AS」照合を選択すると、MembershipProvider が期待どおりに動作しません。

于 2013-02-15T22:33:58.460 に答える
1

メンバーシップ テーブルの名前が間違っているか、列名が間違っていると思います。次のような行を確認してください

WebSecurity.InitializeDatabaseConnection(
     "StarterSite", "UserProfile", "UserId", "Email", autoCreateTables: true);

AppStart.cshtml ファイルで。

詳細については、次のリンクを参照してください: http://msdn.microsoft.com/en-us/library/webmatrix.webdata.websecurity.initializeddatabaseconnection(v=vs.111).aspx

于 2012-10-31T09:30:55.683 に答える