zoukankan      html  css  js  c++  java
  • Sitecore Digital Marketing System, Part 1: Creating personalized, custom content for site visitors(自定义SiteCore中的 Item的Personalize的Condition) -摘自网络

    Sitecore’s Digital Marketing System (DMS) can help you personalize the content your site displays to your users/visitors and can be easily customized to fit your specific requirements while using all the functionality that Sitecore already offers.

    Let’s suppose you want to show different content modules to your users depending on their profile attributes like age, gender, number of twitter followers, number of achievements earned in the site, visitors without an account, etc.

    We will need to let the site editor choose and create new rules that may include one or more profile attributes; therefore we can’t create a set of fixed rules to be used. Also, it is important to note that as result of our personalization, we will be required to:

    -          Show a different sublayout

    -          Hide the sublayout

    -          Change the datasource of the sublayout

    First, here is my User Profile class: 

    namespace RulesEngine.Session

    {

        public class UserProfile

        {

            public int UserId { get; set; }       

            public DateTime RegistrationDate { get; set; }

            public string Nationality { get; set; }

            public UserMaritalStatus MaritalStatus { get; set; }

            public int NumberAchievements { get; set; }

        }

        public enum UserMaritalStatus

        {

            Single,

            Married,

            Divorced

        }

    }

    To keep this demo as simple as possible, I’ll also create a dummy user session manager using a query string value to simulate the current logged in user:

    namespace RulesEngine.Session

    {

        public static class UserSession

        {

            public static UserProfile GetCurrentUser()

            {

                var userId = HttpContext.Current.Request.QueryString["UserId"];

                if (string.IsNullOrEmpty(userId))

                {

                    //User not authenticated

                    return null;

                }

                UserProfile user = null;

                switch (userId)

                {

                    case "1":

                        user = new UserProfile()

                                   {

                                       UserId = 1,

                                       RegistrationDate = new DateTime(2009, 10, 6),

                                       MaritalStatus = UserMaritalStatus.Married,

                                       NumberAchievements = 10,

                                       Nationality = "British"

                                   };

                        break;

                    case "2":

                        user = new UserProfile()

                                   {

                                       UserId = 2,

                                       RegistrationDate = new DateTime(2005, 1, 26),

                                       MaritalStatus = UserMaritalStatus.Single,

                                       NumberAchievements = 55,

                                       Nationality = "Amreican"

                                   };

                        break;

                    case "3":

                        user = new UserProfile()

                                   {

                                       UserId = 3,

                                       RegistrationDate = new DateTime(2011, 2, 14),

                                       MaritalStatus = UserMaritalStatus.Divorced,

                                       NumberAchievements = 3,

                                       Nationality = "French"

                                   };

                        break;

                    case "4":

                        user = new UserProfile()

                                   {

                                       UserId = 4,

                                       RegistrationDate = new DateTime(1999, 8, 30),

                                       MaritalStatus = UserMaritalStatus.Single,

                                       NumberAchievements = 8,

                                       Nationality = "Ecuadorian"

                                   };

                        break;

                }

                return user;

            }

        }

    }

    Let’s start with the user’s nationality. All we need to do is create a new class with StringOperatorCondition as the base:

    using Sitecore.Rules;

    using Sitecore.Rules.Conditions;

    namespace RulesEngine.Rules

    {

        public class NationalityCondition<T> : StringOperatorCondition<T> where T : RuleContext

        {

            //This is the value the editor will enter

            public string Nationality { get; set; }

            /// <summary>

            /// This function will be called to test the condition

            /// </summary>       

            protected override bool Execute(T ruleContext)

            {

                //Get the current user from our dummy user session manager

                var user = UserSession.GetCurrentUser();

                //Check if the user is logged in, otherwise return false

                if (user == null)

                    return false;

                //Use base function to compare the values

                return this.Compare(user.Nationality, Nationality);

            }

        }

    }

    After a build of the solution, we need to register this new condition in Sitecore and copy the output dll to the website’s bin directory (if using a separate project). Open Sitecore’s content editor and navigate to the location: /sitecore/system/Settings/Rules/Conditional Renderings/Conditions and create a new folder:

    create a new folder

    Then we create a new condition:

    create a new condition

    The Text field is the content that will be shown to the editor when selecting this condition, we put the following text:

    where the user's nationality [operatorid,StringOperator,,compares to] [Nationality,Text,,nationality name]

    Notice that it has some special content surrounded by square brackets. This tag has four parameters: the first is the name of the a property in the condition, the second parameter is the name of the macro item (located in /Sitecore/System/Settings/Rules/Common/Macros), the third parameter is a parameter that will be sent to the macro item selected in the second parameter, and the fourth parameter is the text shown to the editor before he enters a value for the condition. In our case we have:

    Parameter

    Object

    operatorid

    Sitecore.Rules.Conditions.StringOperatorCondition.OperatorId

    StringOperator

    /sitecore/system/Settings/Rules/Common/String Operators

    (empty)

    We don’t need a parameter

    compares to

    This text will be shown to the editor

    Parameter

    Object

    Nationality

    Our RulesEngine.Rules.NationalityCondition.Nationality

    Text

    It will request a single line of text

    (empty)

    We don’t need a parameter

    nationality name

    This text will be shown to the editor

    To apply this new rule to our site, we go to the item we want to personalize, then go to Presentation -> Layout Details:

    layout details

    Then on the new window, click on Edit:

    edit layout details

    Under Controls, select the sublayout and click on Personalize. Notice that this Personalize button only appears once you add DMS to your Sitecore installation:

    personalize button

    Then click on New Condition:

    new condition button

    Enter a name for the condition and then click Edit:

    edit new condition

    Now we can select our new condition:

    select new condition

    See part two of this post for how to create conditions that will compare integer, dates and other custom values.

  • 相关阅读:
    阿里的GCIH技术
    java栈
    hotsport jvm后台线程包括哪些
    java运行时数据区
    java双亲委派
    获取类加载器方式
    用户自定义类加载器(java防止反编译)
    JSP-07-使用JavaBean封装数据
    JSP-06-使用JDBC操作数据库
    InstallShield 下载安装
  • 原文地址:https://www.cnblogs.com/haoliansheng/p/4353796.html
Copyright © 2011-2022 走看看