Справочник функций

Ваш аккаунт

Войти через: 
Забыли пароль?
Регистрация
Информацию о новых материалах можно получать и без регистрации:

Почтовая рассылка

Подписчиков: -1
Последний выпуск: 19.06.2015

Создание поставщика MemberShip

2.0K
29 декабря 2008 года
nevile
138 / / 05.01.2007
Почитал MSDN по этому вопросу. Из него понял что для реализации поставщика необходимо в файле web.config:
1. В разделе <connectionStrings> написать строку подключения. Я написал следующее:
 
Код:
<add name="MembershipConnString" connectionString="Data Source=(local)\SQLExpress;Initial Catalog=training;Integrated Security=SSPI"/>

2. В разделе <membership> написать провайдера. Я написал следующее:
 
Код:
<membership defaultProvider ="MembershipProvider">
      <providers>
        <add name="MembershipProvider" type="System.Web.Security.SqlMembershipProvider" connectionStringName="MembershipConnString" enablePasswordRetrieval="false" enablePasswordReset="true" requiresUniqueEmail="true" passwordFormat="Hashed"/>
       
      </providers>
     
    </membership>

3. Сконфигурировать его для авторизации на основе форм. Это тоже сделал.
Но не понятно где прописать таблицу и колонки к которым он должен обращаться. Ну и соответственно при попытке авторизации пользователя он выдает что ошибку следующего содержимого:
 
Код:
System.Data.SqlClient.SqlException: Could not find stored procedure 'dbo.aspnet_CheckSchemaVersion'.


Помогите если кто сталкивался с этим или хотя бы знает в теории.
5
29 декабря 2008 года
hardcase
4.5K / / 09.08.2005
Цитата: nevile
Но не понятно где прописать таблицу и колонки к которым он должен обращаться. Ну и соответственно при попытке авторизации пользователя он выдает что ошибку следующего содержимого:
 
Код:
System.Data.SqlClient.SqlException: Could not find stored procedure 'dbo.aspnet_CheckSchemaVersion'.
Помогите если кто сталкивался с этим или хотя бы знает в теории.


В ASP.NET во встроенном провайдере членства пользователей собственный формат базы. Структура создается из вижуал студии (консоль управления веб приложением) или с помощью утиллиты aspnet_regsql.

2.0K
29 декабря 2008 года
nevile
138 / / 05.01.2007
Цитата: hardcase
В ASP.NET во встроенном провайдере членства пользователей собственный формат базы. Структура создается из вижуал студии (консоль управления веб приложением) или с помощью утиллиты aspnet_regsql.



Вроде не дурак, но найти консоль управления веб приложенем не смог не подскажите где она расположена (студия 2008).

5
29 декабря 2008 года
hardcase
4.5K / / 09.08.2005
Цитата: nevile
Вроде не дурак, но найти консоль управления веб приложенем не смог не подскажите где она расположена (студия 2008).


Выделите проект в солюшн эксплорере. В главном меню студии появится пункт Website. Там будет под-пункт ASP.NET Configuration.

2.0K
30 декабря 2008 года
nevile
138 / / 05.01.2007
Это я уже делал :-[ Когда захожу в панель управления он мне все время одну и ту же ошибку выдает:
 
Код:
As a security measure, the Web Site Administration Tool times out after a period of inactivity. Changes to machine.config or web.config may also result in the tool needing to be restarted. To continue configuring your web site, restart the tool.
5
30 декабря 2008 года
hardcase
4.5K / / 09.08.2005
Веб конфиг в студию (ессно без логинов и паролей).
2.0K
30 декабря 2008 года
nevile
138 / / 05.01.2007
Код:
<?xml version="1.0"?>
<configuration>
    <configSections>
        <sectionGroup name="system.web.extensions" type="System.Web.Configuration.SystemWebExtensionsSectionGroup, System.Web.Extensions, Version=3.5.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35">
            <sectionGroup name="scripting" type="System.Web.Configuration.ScriptingSectionGroup, System.Web.Extensions, Version=3.5.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35">
                <section name="scriptResourceHandler" type="System.Web.Configuration.ScriptingScriptResourceHandlerSection, System.Web.Extensions, Version=3.5.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35" requirePermission="false" allowDefinition="MachineToApplication"/>
                <sectionGroup name="webServices" type="System.Web.Configuration.ScriptingWebServicesSectionGroup, System.Web.Extensions, Version=3.5.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35">
                    <section name="jsonSerialization" type="System.Web.Configuration.ScriptingJsonSerializationSection, System.Web.Extensions, Version=3.5.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35" requirePermission="false" allowDefinition="Everywhere"/>
                    <section name="profileService" type="System.Web.Configuration.ScriptingProfileServiceSection, System.Web.Extensions, Version=3.5.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35" requirePermission="false" allowDefinition="MachineToApplication"/>
                    <section name="authenticationService" type="System.Web.Configuration.ScriptingAuthenticationServiceSection, System.Web.Extensions, Version=3.5.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35" requirePermission="false" allowDefinition="MachineToApplication"/>
                    <section name="roleService" type="System.Web.Configuration.ScriptingRoleServiceSection, System.Web.Extensions, Version=3.5.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35" requirePermission="false" allowDefinition="MachineToApplication"/>
                </sectionGroup>
            </sectionGroup>
        </sectionGroup>
    </configSections>
    <appSettings/>
    <connectionStrings>
  <add name="trainingConnectionString" connectionString="Data Source=(local)\SQLExpress;Initial Catalog=training;Integrated Security=True"
   providerName="System.Data.SqlClient" />
    <add name="MembershipConnString" connectionString="Data Source=(local)\SQLExpress;Initial Catalog=training;Integrated Security=SSPI"/>
 </connectionStrings>
    <system.web>
        <!--
            Set compilation debug="true" to insert debugging
            symbols into the compiled page. Because this
            affects performance, set this value to true only
            during development.
        -->
        <compilation debug="true">
            <assemblies>
                <add assembly="System.Core, Version=3.5.0.0, Culture=neutral, PublicKeyToken=B77A5C561934E089"/>
                <add assembly="System.Data.DataSetExtensions, Version=3.5.0.0, Culture=neutral, PublicKeyToken=B77A5C561934E089"/>
                <add assembly="System.Web.Extensions, Version=3.5.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35"/>
                <add assembly="System.Xml.Linq, Version=3.5.0.0, Culture=neutral, PublicKeyToken=B77A5C561934E089"/>
            </assemblies>
        </compilation>
        <!--
            The <authentication> section enables configuration
            of the security authentication mode used by
            ASP.NET to identify an incoming user.
        -->
    <authentication mode="Forms">
      <forms loginUrl="default.aspx"
             timeout="95"
             cookieless="AutoDetect"></forms>
    </authentication>
        <!--
            The <customErrors> section enables configuration
            of what to do if/when an unhandled error occurs
            during the execution of a request. Specifically,
            it enables developers to configure html error pages
            to be displayed in place of a error stack trace.

        <customErrors mode="RemoteOnly" defaultRedirect="GenericErrorPage.htm">
            <error statusCode="403" redirect="NoAccess.htm" />
            <error statusCode="404" redirect="FileNotFound.htm" />
        </customErrors>
        -->
        <pages>
            <controls>
                <add tagPrefix="asp" namespace="System.Web.UI" assembly="System.Web.Extensions, Version=3.5.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35"/>
                <add tagPrefix="asp" namespace="System.Web.UI.WebControls" assembly="System.Web.Extensions, Version=3.5.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35"/>
            </controls>
        </pages>
        <httpHandlers>
            <remove verb="*" path="*.asmx"/>
            <add verb="*" path="*.asmx" validate="false" type="System.Web.Script.Services.ScriptHandlerFactory, System.Web.Extensions, Version=3.5.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35"/>
            <add verb="*" path="*_AppService.axd" validate="false" type="System.Web.Script.Services.ScriptHandlerFactory, System.Web.Extensions, Version=3.5.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35"/>
            <add verb="GET,HEAD" path="ScriptResource.axd" type="System.Web.Handlers.ScriptResourceHandler, System.Web.Extensions, Version=3.5.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35" validate="false"/>
        </httpHandlers>
        <httpModules>
            <add name="ScriptModule" type="System.Web.Handlers.ScriptModule, System.Web.Extensions, Version=3.5.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35"/>
        </httpModules>
    <authorization>
      <deny users="?"/>
    </authorization>
    <membership defaultProvider ="MembershipProvider">
      <providers>
        <add name="MembershipProvider" type="System.Web.Security.SqlMembershipProvider" connectionStringName="MembershipConnString" enablePasswordRetrieval="false" enablePasswordReset="true" requiresUniqueEmail="true" passwordFormat="Hashed"/>
       
      </providers>
     
    </membership>
   
    </system.web>
    <system.codedom>
        <compilers>
            <compiler language="c#;cs;csharp" extension=".cs" warningLevel="4" type="Microsoft.CSharp.CSharpCodeProvider, System, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089">
                <providerOption name="CompilerVersion" value="v3.5"/>
                <providerOption name="WarnAsError" value="false"/>
            </compiler>
        </compilers>
    </system.codedom>
    <!--
        The system.webServer section is required for running ASP.NET AJAX under Internet
        Information Services 7.0.  It is not necessary for previous version of IIS.
    -->
    <system.webServer>
        <validation validateIntegratedModeConfiguration="false"/>
        <modules>
            <remove name="ScriptModule"/>
            <add name="ScriptModule" preCondition="managedHandler" type="System.Web.Handlers.ScriptModule, System.Web.Extensions, Version=3.5.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35"/>
        </modules>
        <handlers>
            <remove name="WebServiceHandlerFactory-Integrated"/>
            <remove name="ScriptHandlerFactory"/>
            <remove name="ScriptHandlerFactoryAppServices"/>
            <remove name="ScriptResource"/>
            <add name="ScriptHandlerFactory" verb="*" path="*.asmx" preCondition="integratedMode" type="System.Web.Script.Services.ScriptHandlerFactory, System.Web.Extensions, Version=3.5.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35"/>
            <add name="ScriptHandlerFactoryAppServices" verb="*" path="*_AppService.axd" preCondition="integratedMode" type="System.Web.Script.Services.ScriptHandlerFactory, System.Web.Extensions, Version=3.5.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35"/>
            <add name="ScriptResource" preCondition="integratedMode" verb="GET,HEAD" path="ScriptResource.axd" type="System.Web.Handlers.ScriptResourceHandler, System.Web.Extensions, Version=3.5.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35"/>
        </handlers>
    </system.webServer>
    <runtime>
        <assemblyBinding xmlns="urn:schemas-microsoft-com:asm.v1">
            <dependentAssembly>
                <assemblyIdentity name="System.Web.Extensions" publicKeyToken="31bf3856ad364e35"/>
                <bindingRedirect oldVersion="1.0.0.0-1.1.0.0" newVersion="3.5.0.0"/>
            </dependentAssembly>
            <dependentAssembly>
                <assemblyIdentity name="System.Web.Extensions.Design" publicKeyToken="31bf3856ad364e35"/>
                <bindingRedirect oldVersion="1.0.0.0-1.1.0.0" newVersion="3.5.0.0"/>
            </dependentAssembly>
        </assemblyBinding>
    </runtime>
</configuration>
5
30 декабря 2008 года
hardcase
4.5K / / 09.08.2005
Цитата: nevile
 
Код:
<add name="MembershipConnString" connectionString="Data Source=(local)\SQLExpress;Initial Catalog=training;Integrated Security=[COLOR=Red]SSPI[/COLOR]"/>


Поставьте true вместо красного.

2.0K
06 января 2009 года
nevile
138 / / 05.01.2007
что-то не получается. ладно черт с ним сделаю тупо в лоб. нет уже времени с ним разбираться. тем более возникла новая проблема.
279
16 сентября 2009 года
bave
456 / / 07.03.2004
Если я правильно все понял - проблема в том, что в базе используемой приложением, не добавлена схема которую использует MembershipProvider - её добавить можно, используя aspnet_regsql, кторый можно найти в папке ...\WINDOWS\Microsoft.NET\Framework\v2.0.50727 - схема создается вобще легко, запускается aspnet_regsql и там пару раз мышкой шелкнуть...
-----------------------------------------------
Кстате в конекшион стринге даже не увидел с какой базой работает приложение...

Вот это вот:
 
Код:
connectionString="Data Source=(local)\SQLExpress;Initial Catalog=training;Integrated Security=SSPI"
- косячная строка соединения, особенно вот это - "Initial Catalog=training"
5
16 сентября 2009 года
hardcase
4.5K / / 09.08.2005
Цитата: bave
Если я правильно все понял - проблема в том, что в базе используемой приложением, не добавлена схема которую использует MembershipProvider - её добавить можно, используя aspnet_regsql

Про утиллиту сию я сразу сказал. ;)

Цитата: bave

Кстате в конекшион стринге даже не увидел с какой базой работает приложение...

Вот это вот:
 
Код:
connectionString="Data Source=(local)\SQLExpress;Initial Catalog=training;Integrated Security=SSPI"
- косячная строка соединения, особенно вот это - "Initial Catalog=training"


Initial Catalog - это и есть БД с которой работать нужно. SqlClient вполне понимает эту нотацию.



З.Ы. Ах да, тема-то старая же. ;)

Реклама на сайте | Обмен ссылками | Ссылки | Экспорт (RSS) | Контакты
Добавить статью | Добавить исходник | Добавить хостинг-провайдера | Добавить сайт в каталог