Server и отчет из BLOB-а

отредактировано 14:30 Раздел: FastReport 3.0
Все еще изучаю возможность использовать FR 3 в качестве сервера отчетов у нас на предприятии. Очередная забавность.

Все отчеты лежат в базе в BLOB-е. Судя по документации, сервер может загрузить такой отчет используя событие OnGetReport. Чем и пользуюсь. И при попытке посмотреть такой отчет в IE получаю на сервере системную ошибку "отказано в доступе".
Расследование показывает, что ошибка возникает на RecreateWnd при присвоении DialogPage.BorderStyle. Что в общем-то и естественно, учитывая что создает диалоговое окно (т.е. загружает отчет из базы) один поток, ( Synchronize(DoOnGetReport) ), а строит отчет другой...

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

Комментарии

  • отредактировано 14:30
    P.S. Да, кстати, если убрать Synchronize, то все почти работает.
  • отредактировано 14:30
    Вот еще одна забавная вещица всплыла, отражения в документации которой я не нашел, к сожалению.
    Оказывается, чтобы отчет, загруженый на frxReportServer.OnGetReport, надо после загрузки отчета из базы обязательно прописать Report.FileName (по крайней мере для отчетов с формами запроса, я делаю Report.FileName := ReportName, хотя, похоже, неважно что там написать - лишь бы не пустую строку). Иначе после заполнения формы получим от сервера 403 - нет доступа.
    Фишка в том, что если при разборе заголовка запроса в frxServerSession.ParseHTTPHeader не находится фраза report="ReportName", то возвращает как раз 403. А этот самый ReportName в заголовке прописывается в TfrxReportSession.DoSaveForm как WebForm.ReportName := ExtractReportName(FReport.FileName).
    Вот.

    P.S. Ничего что я здесь об ошибках? А то, к сожалению, на ru-boarde соответствующая тема больше авторами не читается, в том числе и мои пожелания/замечания/исправления там нечитаны уже недели три лежат ;)
  • отредактировано 14:30
    Ну ладно, раз мне не хочет никто отвечать, то я тогда и дальше тихо сам с собой, тем более, что похоже, отчетами в WEB никто особо больше и не занимается ;)

    Так вот, есть еще маленькое предложение по облегчению жизни пользователям ;)
    Если в TfrxReportSession.ShowReportDialog добавить две строчки

    FReport.DoNotifyEvent(Page, Page.OnActivate);
    и
    FReport.DoNotifyEvent(Page, Page.OnDeactivate);

    после DialogActive := True и DialogActive := False соответственно.

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

    procedure Page3OnDeactivate(Sender: TfrxComponent);
    begin
    Set('InvoiceNumber', edInvoiceNum.Text);
    end

    а параметру в датасете сказать, что значение его берется из InvoiceNember.

    Этим достигается возможность тройственного использования отчета

    1. Выбрать в приложении в гриде нужную запись и сказать напечатать отчет по ней, при этом передать в отчет переменную InvoiceNumber и скрыть диалоговую форму запроса.
    2. Показать отчет из приложения с запросом нужной записи через диалоговую форму отчета.
    3. То же самое, но не из приложения, а в web-браузере ;)


  • отредактировано 14:30
    DmLam написал:
    P.S. Да, кстати, если убрать Synchronize, то все почти работает.
    привет

    а какой выход ты нашел?
  • отредактировано 14:30
    dimm написал:
    dimm написал:
    P.S. Да, кстати, если убрать Synchronize, то все почти работает.
    привет

    а какой выход ты нашел?
    dimm написал:
    dimm написал:
    P.S. Да, кстати, если убрать Synchronize, то все почти работает.
    привет

    а какой выход ты нашел?

    Так убрал Synchronize ;) , благо при загрузке отчета ничего потокозависимого не делается
  • отредактировано 14:30
    у меня если убрать synchronize, сыпется с "не был вызван CoInitialize"

    связи не вижу..блин ;)
  • отредактировано 14:30
    dimm написал:
    у меня если убрать synchronize, сыпется с "не был вызван CoInitialize"

    связи не вижу..блин ;)
    frxADOComponents убрал? И юнит из uses тоже убрал? Верни обратно ;)
    Хотя бы юнит в uses. Не знаю почему - не разбирался еще, но где-то он пытается к этому ADO обращаться.
  • отредактировано 14:30
    frxADOcomponents лежат на форме и есть в uses
    все равно сыпет
    в чем дело?
  • отредактировано 14:30
    вообще не совсем понятно,почему "отказано в доступе"
    ведь при вызове synchronize поток,строящий отчет,замораживается до загрузки отчета
  • отредактировано 14:30
    написал:
    frxADOcomponents лежат на форме и есть в uses
    все равно сыпет
    в чем дело?

    Тогда ищи что изменял сам, тут больше ничего сказать не могу. У меня на CoInitialize ругался, когда я пытался выкинуть ненужный мне ADO из сервера. Разбираться в проблеме не стал, просто вернул все на место.
    написал:
    вообще не совсем понятно,почему "отказано в доступе"
    ведь при вызове synchronize поток,строящий отчет,замораживается до загрузки отчета

    Потому что отчет загружается в одном потоке (основном потоке приложения), при этом загружается диалоговая страница и, видимо, создается форма (т.е. окно) для нее. А строится отчет в другом потоке, при этом он пытается установить этой диалоговой форме BorderStyle bsDialog вместо bsSized. Для этого делается RecreateWnd, который на самом деле разрушение окна с последующим его созданием с новыми свойствами. Получается, что создано окно одним потоком, а разрушить его пытается другой. Что, согласно msdn невозможно. Вот система и говорит, что у потока, который строит отчет нет доступа к окну, созданному в основном потоке приложения.

Оставить комментарий

Многофункциональный текстовый редактор. Чтобы отредактировать стиль параграфа, нажмите TAB, чтобы перейти к меню абзаца. Там вы можете выбрать стиль. По умолчанию не выбран ни один стиль. Когда вы выберете текст, появится встроенное меню форматирования. Нажмите TAB, чтобы войти в него. Некоторые элементы, такие как многофункциональные вставки ссылок, картинок, индикаторов загрузки и сообщений об ошибок могут быть вставлены в редактор. Вы можете перемещаться по ним, используя стрелки внутри редактора и удалять с помощью клавиш delete или backspace.