• 15 апреля стартует «Курс «SQL-injection Master» ©» от команды The Codeby

    За 3 месяца вы пройдете путь от начальных навыков работы с SQL-запросами к базам данных до продвинутых техник. Научитесь находить уязвимости связанные с базами данных, и внедрять произвольный SQL-код в уязвимые приложения.

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

    Запись на курс до 25 апреля. Получить промодоступ ...

Richtext+thruhtml

  • Автор темы ivashkalotus
  • Дата начала
Статус
Закрыто для дальнейших ответов.
I

ivashkalotus

Есть задание: создать отчет с помщью агента.
Агент пробегает по базе и заполняет единственное RichText-поле формы данными.
Чтобы это все было красиво предлагают использовать Pass-Thru HTML.

Как это провернуть?
Про агента пока не надо, думаю сделаю, а вот про Pass-Thru я бы послушал. ;)
Обычный Pass-Thru в форме я представляю, а вот в RichText-е?
 

Medevic

Что это ? :)
Green Team
10.12.2004
3 334
1
BIT
4
Как сделать html в ричтексте. Создаем форму ReportForm. На нем поле "body" типа RichText (в свойствах стоит галочка на "Store contents as HTML and MIME").
Дальше, откуда надо формировать отчет, создаем кнопку с таким кодом:
Код:
Sub Click(Source As Button)
Dim session As New NotesSession
Dim ws As New NotesUIWorkspace
Dim db As NotesDatabase
Dim dbReportDoc As NotesDocument
Dim stream As NotesStream
Dim body As NotesMIMEEntity
Dim html As Variant

Set db = session.CurrentDatabase
Set dbReportDoc = New NotesDocument(db)
dbReportDoc.Form = "ReportForm"
Set stream = session.CreateStream
session.ConvertMIME = False
Set body = dbReportDoc.CreateMIMEEntity

html = html + "<H1>Test</H1>"

Call stream.WriteText(html)
Call body.SetContentFromText(stream, {text/html; charset="UTF-8"}, ENC_IDENTITY_BINARY)
Call dbReportDoc.ComputeWithForm(False, False)
Call stream.Close
Call ws.EditDocument(False, dbReportDoc, False)
session.ConvertMIME = True

End Sub
 
I

ivashkalotus

Спасибо Medevic, все работает, только я не понял где ты присваиваешь значение полю body, или это поле стандартное в таких случаях, и переименовать его нельзя?
 

Medevic

Что это ? :)
Green Team
10.12.2004
3 334
1
BIT
4
Почитай про CreateMIMEEntity. "Body" - по-умолчанию.
Заполняется поле в этой строке:
<!--QuoteBegin-Medevic+3:05:2006, 12:44 -->
<span class="vbquote">(Medevic @ 3:05:2006, 12:44 )</span><!--QuoteEBegin-->Call body.SetContentFromText(stream, {text/html; charset="UTF-8"}, ENC_IDENTITY_BINARY)
[snapback]34823" rel="nofollow" target="_blank[/snapback]​
[/quote]
 
I

ivashkalotus

<!--QuoteBegin-Medevic+3:05:2006, 12:44 -->
<span class="vbquote">(Medevic @ 3:05:2006, 12:44 )</span><!--QuoteEBegin-->Set body = dbReportDoc.CreateMIMEEntity
[snapback]34823" rel="nofollow" target="_blank[/snapback]​
[/quote]
<!--QuoteBegin-Medevic+3:05:2006, 12:44 -->
<span class="vbquote">(Medevic @ 3:05:2006, 12:44 )</span><!--QuoteEBegin-->Call body.SetContentFromText(stream, {text/html; charset="UTF-8"}, ENC_IDENTITY_BINARY)
[snapback]34823" rel="nofollow" target="_blank[/snapback]​
[/quote]
Это я видел, но body в этом случае только локальная переменная!

<!--QuoteBegin-Medevic+3:05:2006, 13:00 -->
<span class="vbquote">(Medevic @ 3:05:2006, 13:00 )</span><!--QuoteEBegin-->Почитай про CreateMIMEEntity
[snapback]34829" rel="nofollow" target="_blank[/snapback]​
[/quote]
Спасибо, почитаю
 

Medevic

Что это ? :)
Green Team
10.12.2004
3 334
1
BIT
4
<!--QuoteBegin-ivashkalotus+3:05:2006, 13:05 -->
<span class="vbquote">(ivashkalotus @ 3:05:2006, 13:05 )</span><!--QuoteEBegin-->Это я видел, но body в этом случае только локальная переменная!
[snapback]34830" rel="nofollow" target="_blank[/snapback]​
[/quote]
Ну да. Можно назвать как угодно.
А вот имя поля опционально задается именно в Set body = dbReportDoc.CreateMIMEEntity
Т.е. это равносильно Set body = dbReportDoc.CreateMIMEEntity("Body")
 
I

ivashkalotus

Спасибо еще раз.
Все фурычит. Даже агент получился ;)
 
Статус
Закрыто для дальнейших ответов.
Мы в соцсетях:

Обучение наступательной кибербезопасности в игровой форме. Начать игру!