используя HttpHandlerFactory для рендеринга CMS и физических страниц - PullRequest
0 голосов
/ 09 сентября 2010

Я нахожусь в процессе написания системы CMS, и после прочтения и проработки нескольких примеров я остановился на HttpHandlerFactory , чтобы выполнить то, что мне нужно.

ключевой моментНаши сайты обычно представляют собой сочетание процессов копирования и регистрации.Поэтому в настоящее время мне нужно использовать HttpHandler по умолчанию для aspx для рендеринга страниц физической регистрации, пока я не смогу найти способ управления ими.

после создания класса обработчика я добавил следующее в веб-конфигурацию моего веб-сайта

<add verb="*" path="*.aspx" type="Web.Helpers.HttpCMSHandlerFactory, Web.Helpers"/>

Так как вышеуказанный путь обрабатывает физические и управляемые cms страницы, с небольшой проверкой в ​​коде я могу увидеть, существует ли страница физически, и затем может отобразить нужную страницу.

    public IHttpHandler GetHandler(HttpContext context, string requestType, string url, string pathTranslated)
    {
        string pageName = Path.GetFileNameWithoutExtension(context.Request.PhysicalPath);
        context.Items.Add("PageName", pageName);
        //DirectoryInfo di = new DirectoryInfo(context.Request.MapPath(context.Request.ApplicationPath));
        FileInfo fi = new FileInfo(context.Request.MapPath(context.Request.CurrentExecutionFilePath));
        //var file = fi.Where(x => string.Equals(x.Name, string.Concat(pageName, ".aspx"), StringComparison.InvariantCultureIgnoreCase)).SingleOrDefault();
        if (fi.Exists == false)
        {
           // think I had this the wrong way around, the url should come first with the renderer page second
            return PageParser.GetCompiledPageInstance(url, context.Server.MapPath("~/CMSPage.aspx"), context);
        }
        else
        {
            return PageParser.GetCompiledPageInstance(context.Request.CurrentExecutionFilePath, fi.FullName, context);
        }
    }

Вопрос, который у меня возникает, должен ли я использовать что-то кроме PageParser.GetCompiledPageInstance при наличии физической страницы?

Обновление: с тех пор как я приступил к разработке и HttpHandler для изображений, который снова работаетпо тому же принципу, если изображение существует, используйте его еще из базы данных.Возникла небольшая проблема с файлами png, но описанный ниже процесс работает для файлов указанных форматов.

        byte[] image = null;
        if (File.Exists(context.Request.PhysicalPath))
        {
            FileStream fs = new FileStream(context.Request.PhysicalPath, FileMode.Open, FileAccess.Read);
            BinaryReader br = new BinaryReader(fs);

            image = br.ReadBytes((int)fs.Length);
        }
        else
        {
            IKernel kernel = new StandardKernel(new ServiceModule());
            var cmsImageService = kernel.Get<IContentManagementService>();
            var framework = FrameworkSetup.GetSetFrameworkSettings();
            image = cmsImageService.GetImage(Path.GetFileName(context.Request.PhysicalPath), framework.EventId);
        }

        var contextType = "image/jpg";
        var format = ImageFormat.Jpeg;

        switch (Path.GetExtension(context.Request.PhysicalPath).ToLower())
        {
            case ".gif":
                contextType = "image/gif";
                format = ImageFormat.Gif;
                goto default;
            case ".jpeg":
            case ".jpg":
                contextType = "image/jpeg";
                format = ImageFormat.Jpeg;
                goto default;
            case ".png":
                contextType = "image/png";
                format = ImageFormat.Png;
                goto default;
            default:
                context.Cache.Insert(context.Request.PhysicalPath, image);
                context.Response.ContentType = contextType;
                context.Response.BinaryWrite(image);
                context.Response.Flush();
                break;
        }

1 Ответ

1 голос
/ 05 октября 2010

Я не уверен, что это полностью отвечает на ваш вопрос ... Я также создал ASP.NET CMS, которая была управляема HttpHandler, и которая также учитывает физические страницы .aspx. Поскольку у меня было только небольшое количество физических файлов .aspx и местоположений, самый простой способ управлять выполнением был через web.config.

Во-первых, я настраиваю веб-сайт (в общих чертах) для использования моего обработчика - за исключением страницы входа (в качестве примера):

<add verb="*" path="login.aspx" type="System.Web.UI.PageHandlerFactory"/>
<add verb="*" path="Register.aspx" type="System.Web.UI.PageHandlerFactory"/>
<add verb="*" path="*.aspx" type="Morphfolia.PublishingSystem.HttpHandlers.DefaultHandler, Morphfolia.PublishingSystem"/>

Другая вещь, которую вы можете сделать, это изолировать location, поэтому для этой части сайта я предпочитаю использовать готовый обработчик ASP.NET, который обычно обрабатывает «классический» ASP.NET запросы:

<location path="Morphfolia/_publishing">
  <system.web>
    <httpHandlers>
      <add verb="*" path="*.aspx" type="System.Web.UI.PageHandlerFactory"/>
    </httpHandlers>
  </system.web>
</location>
...