Как назначить значения профиля?

Я не знаю, что мне не хватает, но я добавил свойства профиля в файл Web.config, но не могу получить доступ к профилю.Элемент в коде или создать новый профиль.

10 ответов

Решение

У меня была такая же проблема сегодня, и я многому научился.

В Visual Studio существует два вида проектов - "Проекты веб-сайтов" и "Проекты веб-приложений". По причинам, которые являются для меня полной загадкой, проекты веб-приложений не могут использовать профиль. напрямую... строго типизированный класс не генерируется волшебным образом для вас из файла Web.config, так что вы должны свернуть свой собственный.

Пример кода в MSDN предполагает, что вы используете проект веб-сайта, и они говорят вам просто добавить <profile> раздел к вашему Web.config и вечеринка с Profile.свойство, но это не работает в проектах веб-приложений.

У вас есть два варианта бросить свой собственный:

(1) Используйте Web Profile Builder. Это пользовательский инструмент, который вы добавляете в Visual Studio, который автоматически генерирует нужный вам объект профиля из вашего определения в Web.config.

Я решил не делать этого, потому что я не хотел, чтобы мой код зависел от этого дополнительного инструмента для компиляции, что могло вызвать проблемы у кого-то другого, когда они пытались построить мой код, не осознавая, что им нужен этот инструмент.

(2) Сделайте свой собственный класс, который происходит от ProfileBase представлять свой пользовательский профиль. Это проще, чем кажется. Вот очень простой пример, который добавляет поле строкового профиля "FullName":

В вашем web.config:

<profile defaultProvider="SqlProvider" inherits="YourNamespace.AccountProfile">

<providers>
     <clear />
     <add name="SqlProvider"
          type="System.Web.Profile.SqlProfileProvider"
          connectionStringName="sqlServerMembership" />
</providers>

</profile>

В файле с именем AccountProfile.cs:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.Profile;
using System.Web.Security;

namespace YourNamespace
{
    public class AccountProfile : ProfileBase
    {
        static public AccountProfile CurrentUser
        {
            get { return (AccountProfile)
                         (ProfileBase.Create(Membership.GetUser().UserName)); }
        }

        public string FullName
        {
            get { return ((string)(base["FullName"])); }
            set { base["FullName"] = value; Save(); }
        }

        // add additional properties here
    }
}

Чтобы установить значение профиля:

AccountProfile.CurrentUser.FullName = "Snoopy";

Чтобы получить значение профиля

string x = AccountProfile.CurrentUser.FullName;

Проекты веб-приложений могут по-прежнему использовать объект ProfileCommon, но только во время выполнения. Код для него просто не генерируется в самом проекте, но класс генерируется ASP.Net и присутствует во время выполнения.

Самый простой способ добраться до объекта - использовать динамический тип, как показано ниже.

В файле Web.config объявите свойства профиля:

<profile ...
 <properties>
   <add name="GivenName"/>
   <add name="Surname"/>
 </properties>

Затем для доступа к свойствам:

dynamic profile = ProfileBase.Create(Membership.GetUser().UserName);
string s = profile.GivenName;
profile.Surname = "Smith";

Чтобы сохранить изменения в свойствах профиля:

profile.Save();

Вышеприведенное прекрасно работает, если вы удобны в использовании динамических типов и не обращаете внимания на отсутствие проверки во время компиляции и intellisense.

Если вы используете это с ASP.Net MVC, вам придется проделать некоторую дополнительную работу, если вы передадите объект динамического профиля своим представлениям, поскольку вспомогательные методы HTML плохо работают с динамическими объектами модели. Вам нужно будет присвоить свойства профиля статически типизированным переменным, прежде чем передавать их вспомогательным методам HTML.

// model is of type dynamic and was passed in from the controller
@Html.TextBox("Surname", model.Surname) <-- this breaks

@{ string sn = model.Surname; }
@Html.TextBox("Surname", sn); <-- will work

Если вы создадите пользовательский класс профиля, как описано выше в Джоэле, ASP.Net по-прежнему будет генерировать класс ProfileCommon, но он будет наследоваться от вашего пользовательского класса профиля. Если вы не укажете пользовательский профиль, класс ProfileCommon будет наследоваться от System.Web.Profile.ProfileBase.

Если вы создаете свой собственный класс профиля, убедитесь, что вы не указали свойства профиля в файле Web.config, который вы уже объявили в своем пользовательском классе профиля. Если вы сделаете это, ASP.Net выдаст ошибку компилятора, когда попытается сгенерировать класс ProfileCommon.

Профиль также можно использовать в проектах веб-приложений. Свойства могут быть определены в Web.config во время разработки или программно. В Web.config:

<profile enabled="true" automaticSaveEnabled="true" defaultProvider="AspNetSqlProfileProvider">
      <providers>
        <clear/>
        <add name="AspNetSqlProfileProvider" type="System.Web.Profile.SqlProfileProvider" connectionStringName="ApplicationServices" applicationName="TestRolesNProfiles"/>
      </providers>
      <properties>
        <add name="FirstName"/>
        <add name="LastName"/>
        <add name ="Street"/>
        <add name="Address2"/>
        <add name="City"/>
        <add name="ZIP"/>
        <add name="HomePhone"/>
        <add name="MobilePhone"/>
        <add name="DOB"/>

      </properties>
    </profile>

или Программным путем создайте раздел профиля, создав экземпляр ProfileSection и создав индивидуальные свойства, используя ProfilePropertySettings и ProfilePropertySettingsColletion, которые находятся в пространстве имен System.Web.Configuration. Чтобы использовать эти свойства профиля, используйте System.Web.Profile.ProfileBase Objects. Свойства профиля не могут быть доступны с профилем. синтаксис, как упомянуто выше, но может быть легко сделан путем создания экземпляра ProfileBase и использования SetPropertyValue("PropertyName") и GetPropertyValue{"PropertyName") следующим образом:

ProfileBase curProfile = ProfileBase.Create("MyName");

или для доступа к профилю текущего пользователя:

ProfileBase curProfile = ProfileBase.Create(System.Web.Security.Membership.GetUser().UserName);



        curProfile.SetPropertyValue("FirstName", this.txtName.Text);
        curProfile.SetPropertyValue("LastName", this.txtLname.Text);
        curProfile.SetPropertyValue("Street", this.txtStreet.Text);
        curProfile.SetPropertyValue("Address2", this.txtAdd2.Text);
        curProfile.SetPropertyValue("ZIP", this.txtZip.Text);
        curProfile.SetPropertyValue("MobilePhone", txtMphone.Text);
        curProfile.SetPropertyValue("HomePhone", txtHphone.Text);
        curProfile.SetPropertyValue("DOB", txtDob.Text);
        curProfile.Save();

Когда вы создаете новый проект веб-сайта в Visual Studio, объект, который возвращается из профиля, будет (автоматически) создан для вас. Когда вы создаете проект веб-приложения или проект MVC, вам придется свернуть свой собственный.

Это, вероятно, звучит сложнее, чем есть. Вам нужно сделать следующее:

  • Создайте базу данных, используя aspnet_regsql.exe. Этот инструмент устанавливается вместе с платформой.NET.
  • Напишите класс, производный от ProfileGroupBase, или установите Web Profile Builder (WPB), который может сгенерировать этот класс для вас из определения в Web.Config. Я использовал WPB некоторое время, и до сих пор он сделал то, что от него ожидают. Если у вас много свойств, использование WPB может сэкономить немного времени.
  • Убедитесь, что соединение с базой данных правильно настроено в Web.Config.
  • Теперь вы можете создать экземпляр класса вашего профиля (в контроллере)
  • Возможно, вам понадобятся значения свойств профиля в ваших представлениях. Мне нравится передавать сам объект профиля в представление (не отдельные свойства).

Если вы используете проект веб-приложения, вы не можете получить доступ к объекту Profile во время разработки сразу после установки. Вот утилита, которая предположительно делает это для вас: http://weblogs.asp.net/joewrobel/archive/2008/02/03/web-profile-builder-for-web-application-projects.aspx. Лично эта утилита вызвала ошибку в моем проекте, поэтому я в итоге выбрал собственный класс профиля для наследования от ProfileBase. Это было не сложно сделать вообще.

Я также работал через ту же проблему. Но вместо создания класса, который наследуется от ProfileBase, я использовал HttpContext.

Укажите свойства в файле web.config следующим образом: -ProfilePropertyWeb.config

Теперь напишите следующий код: -

Код позади свойств профиля

Скомпилируйте и запустите код. Вы получите следующий вывод: -

Выход

Пошаговое руководство по MSDN для создания пользовательского класса (он же метод Джоэла):
http://msdn.microsoft.com/en-us/magazine/cc163624.aspx

Web Profile Builder работал отлично для меня. В сгенерированном им классе гораздо больше, чем описано в посте Джоэла. Действительно ли это действительно необходимо или полезно, я не знаю.

В любом случае, для тех, кто ищет простой способ создания класса, но не хочет иметь зависимость от внешнего инструмента сборки, вы всегда можете

  • использовать конструктор веб-профилей
  • удалить все следы этого!
  • продолжать использовать сгенерированный класс профиля

ИЛИ (не проверено, но может просто работать)

  • создать проект веб- сайта
  • создать свой элемент
  • привязать сгенерированный класс и скопировать его в ваш проект веб-проекта

если этот второй подход действительно работает, может кто-нибудь дать мне знать для дальнейшего использования

Просто хочу добавить к ответу Джоэла Спольски

Я реализовал его решение, блестяще работая между прочим - Cudos!

Для тех, кто хочет получить профиль пользователя, который не является зарегистрированным пользователем, которого я использовал:

web.config:

  <connectionStrings>
    <clear />
    <add name="LocalSqlConnection" connectionString="Data Source=***;Database=***;User Id=***;Password=***;Initial Catalog=***;Integrated Security=false" providerName="System.Data.SqlClient" />
  </connectionStrings>

а также

<profile defaultProvider="SqlProvider" inherits="NameSpace.AccountProfile" enabled="true">
  <providers>
    <clear/>
    <add name="SqlProvider" type="System.Web.Profile.SqlProfileProvider" connectionStringName="LocalSqlConnection"/>
  </providers>

И тогда мой пользовательский класс:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.Profile;
using System.Web.Security;

namespace NameSpace
{
    public class AccountProfile : ProfileBase
    {
        static public AccountProfile CurrentUser
        {
            get
            {
                return (AccountProfile)
                 (ProfileBase.Create(Membership.GetUser().UserName));
            }
        }

        static public AccountProfile GetUser(MembershipUser User)
        {
            return (AccountProfile)
                (ProfileBase.Create(User.UserName));
        }

        /// <summary>
        /// Find user with matching barcode, if no user is found function throws exception
        /// </summary>
        /// <param name="Barcode">The barcode to compare against the user barcode</param>
        /// <returns>The AccountProfile class with matching barcode or null if the user is not found</returns>
        static public AccountProfile GetUser(string Barcode)
        {
            MembershipUserCollection muc = Membership.GetAllUsers();

            foreach (MembershipUser user in muc)
            {
                if (AccountProfile.GetUser(user).Barcode == Barcode)
                {
                    return (AccountProfile)
                        (ProfileBase.Create(user.UserName));
                }
            }
            throw new Exception("User does not exist");
        }

        public bool isOnJob
        {
            get { return (bool)(base["isOnJob"]); }
            set { base["isOnJob"] = value; Save(); }
        }

        public string Barcode
        {
            get { return (string)(base["Barcode"]); }
            set { base["Barcode"] = value; Save(); }
        }
    }
}

Работает как шарм...

Отличный пост,

Просто обратите внимание на web.config, если вы не указали атрибут наследования в элементе профиля, вам нужно будет указать каждое индивидуальное свойство профиля внутри элемента профиля в web.config, как показано ниже

 <properties>
    <clear/>
    <add name="property-name-1" />
    <add name="property-name-2" />
    ..........

 </properties>
Другие вопросы по тегам