2010-10-05 78 views
2

我有MySqlMembershipProvider與Asp.Net MVC一起使用。我的問題是我怎樣才能配置表前綴...所以而不是'我的_aspnet_'前綴在表上,我希望這是沒有或由我定義。MySqlMembershipProvider的表前綴

我的web.config:

<?xml version="1.0"?> 

<add name="ApplicationServices" connectionString="server=localhost;user id=root;Password=*********;database=sparkSources" providerName="MySql.Data.MySqlClient"/> 

<authentication mode="Forms"> 
    <forms loginUrl="~/Account/LogOn" timeout="2880" /> 
</authentication> 

<membership defaultProvider="MySqlMembershipProvider"> 
    <providers> 
    <clear/> 
    <add name="MySqlMembershipProvider" 
     type="MySql.Web.Security.MySQLMembershipProvider, 
      MySql.Web, Version=6.3.4.0, Culture=neutral, 
      PublicKeyToken=c5687fc88969c44d" 
     autogenerateschema="true" 
     tablePrefix="ss" 
     connectionStringName="ApplicationServices" 
     enablePasswordRetrieval="false" 
     enablePasswordReset="true" 
     requiresQuestionAndAnswer="false" 
     requiresUniqueEmail="false" 
     passwordFormat="Hashed" 
     maxInvalidPasswordAttempts="5" 
     minRequiredPasswordLength="6" 
     minRequiredNonalphanumericCharacters="0" 
     passwordAttemptWindow="10" 
     passwordStrengthRegularExpression="" 
     applicationName="sparkSources" 
/> 
    </providers> 
</membership> 

<profile> 
    <providers> 
    <clear/> 
    <add name="AspNetSqlProfileProvider" type="System.Web.Profile.SqlProfileProvider" connectionStringName="ApplicationServices" applicationName="/" /> 
    </providers> 
</profile> 

<roleManager enabled="false"> 
    <providers> 
    <clear/> 
    <add name="AspNetSqlRoleProvider" type="System.Web.Security.SqlRoleProvider" connectionStringName="ApplicationServices" applicationName="/" /> 
    <add name="AspNetWindowsTokenRoleProvider" type="System.Web.Security.WindowsTokenRoleProvider" applicationName="/" /> 
    </providers> 
</roleManager> 

<pages> 
    <namespaces> 
    <add namespace="System.Web.Mvc" /> 
    <add namespace="System.Web.Mvc.Ajax" /> 
    <add namespace="System.Web.Mvc.Html" /> 
    <add namespace="System.Web.Routing" /> 
    </namespaces> 
</pages> 

回答

2

我想我會看看源令我驚訝的是,自版本6.3.4開始,「my_aspnet」表前綴是硬編碼的。更改了所有「my_aspnet」前綴並重新編譯連接器 - 所以如果你真的想改變表前綴 - 準備好一些源代碼潛水。