如何在C#类(.cs文件)和ASP.NET .aspx文件中使用相同的OracleMembershipProvider?

时间:2011-10-11 22:14:18

标签: c# asp.net asp.net-membership

问题在于,我想使用内置的Membership功能处理用户,特别是使用Oracle.Web.Security.OracleMembershipProvider。我让提供程序在.aspx文件中工作,正确地将新用户插入适当的Oracle表并处理登录。但是,我在解决方案的网站组件旁边有一个Web服务。我只想通过网站注册的用户可以发送有效的用户名/密码和网络请求,以便能够访问数据。

无论如何,在.cs文件中我这样做:

OracleMembershipProvider provider = new OracleMembershipProvider(); 
if (!provider.ValidateUser(username, password)) 
{
    return null;
}

对ValidateUser的调用会引发异常,详细信息:“OracleConnection.ConnectionString无效”。

我想认为连接字符串在.aspx页面上工作的事实足以确认连接字符串是否有效。

以下是.aspx文件中的内容,第二行的密钥是MembershipProvider =“MyOracleMembershipProvider”

<asp:Login ID="LoginUser" runat="server" EnableViewState="false" 
    RenderOuterTable="false" MembershipProvider="MyOracleMembershipProvider">
    <LayoutTemplate>
        <span class="failureNotification">
            <asp:Literal ID="FailureText" runat="server"></asp:Literal>
        </span>
        <asp:ValidationSummary ID="LoginUserValidationSummary" runat="server" CssClass="failureNotification" 
             ValidationGroup="LoginUserValidationGroup"/>
        <div class="accountInfo">
            <fieldset class="login">
                <legend>Account Information</legend>
                <p>
                    <asp:Label ID="UserNameLabel" runat="server" AssociatedControlID="UserName">Username:</asp:Label>
                    <asp:TextBox ID="UserName" runat="server" CssClass="textEntry"></asp:TextBox>
                    <asp:RequiredFieldValidator ID="UserNameRequired" runat="server" ControlToValidate="UserName" 
                         CssClass="failureNotification" ErrorMessage="User Name is required." ToolTip="User Name is required." 
                         ValidationGroup="LoginUserValidationGroup">*</asp:RequiredFieldValidator>
                </p>
                //blah blah blah, code removed for length.
            </fieldset>
            <p class="submitButton">
                <asp:Button ID="LoginButton" runat="server" CommandName="Login" Text="Log In" ValidationGroup="LoginUserValidationGroup"/>
            </p>
        </div>
    </LayoutTemplate>
</asp:Login>

查看'provider'的一些细节基本上显示所有null / default值,表明它未正确初始化。我的印象是构造函数应该使用我的默认成员资格提供程序初始化成员资格提供程序,根据我的web.config文件,如下所示:

<configuration>
  <system.data>
    <DbProviderFactories>      
      <clear />
      <add name="xxxOracleDataProvider" invariant="Oracle.DataAccess.Client" description=".Net Framework Data Provider for Oracle" 
       type="Oracle.DataAccess.Client.OracleClientFactory, 
             Oracle.DataAccess, 
             Version=4.112.2.0, 
             Culture=neutral, 
             PublicKeyToken=89b483f429c47342" />
</DbProviderFactories>
</system.data>  

<connectionStrings>
  <add name="MEMBERSHIP_PROVIDER" 
     connectionString="
      Persist Security Info=True;
      user id = xxxxxx; 
      password = xxxxxx; 
      data source=
      (DESCRIPTION = 
        (ADDRESS_LIST = 
          (ADDRESS = 
            (PROTOCOL = TCP)
            (HOST = xxxxxxx)
            (PORT = xxxxxxxx)
          )
        )
        (CONNECT_DATA = 
         (SERVICE_NAME = xxxxx)
         (SERVER = DEDICATED)
        )
      );"
     providerName="Oracle.DataAccess"
     />       
</connectionStrings>

<system.web>
<customErrors mode="Off"/>
<webServices>
  <protocols>
    <add name="HttpGet"/>
    <add name="HttpPost"/>
  </protocols>
</webServices>
<compilation debug="true"/>    
<authentication mode="Forms">
  <forms loginUrl="~/Account/Login.aspx" timeout="2880"/>
</authentication>
<membership defaultProvider="MyOracleMembershipProvider" hashAlgorithmType="SHA1">
  <providers>
    <clear />        
    <add name="MyOracleMembershipProvider"
         type="Oracle.Web.Security.OracleMembershipProvider, 
         Oracle.Web, Version=4.112.1.2, Culture=neutral,
         PublicKeyToken=89b483f429c47342"
         connectionStringName="MEMBERSHIP_PROVIDER"
         applicationName="xxx_xxxx_xxxxxx"
         enablePasswordRetrieval="false"
         enablePasswordReset="true"
         requiresQuestionAndAnswer="false"
         requiresUniqueEmail="true"
         passwordFormat="Hashed"
         minRequiredNonalphanumericCharacters="0"
         maxInvalidPasswordAttempts="7"
         minRequiredPasswordLength="12"
         passwordAttemptWindow="8"             
         />
  </providers>
</membership>    
</system.web>
<system.webServer>
<modules runAllManagedModulesForAllRequests="true"/>
</system.webServer>
</configuration>

我试过了:

 Membership.Provider.ValidateUser(username, password)

也是。它总是返回false,并且Providers属性与我的默认提供者的属性不匹配(当我设置断点并观察对象时)。

任何人都有任何想法如何解决此问题?我觉得它应该很简单,因为数据提供程序在.aspx页面上工作正常,但我不能在我的生活中获得.cs文件来使用相同的提供程序,甚至看到提供程序存在。

1 个答案:

答案 0 :(得分:0)

请参阅LordHitsHow do I call Initialize on a custom MembershipProvider?

上给出的第一个答案

这可能是你问题的答案。