• Познакомьтесь с пентестом веб-приложений на практике в нашем новом бесплатном курсе

    «Анализ защищенности веб-приложений»

    🔥 Записаться бесплатно!

  • CTF с учебными материалами Codeby Games

    Обучение кибербезопасности в игровой форме. Более 200 заданий по Active Directory, OSINT, PWN, Веб, Стеганографии, Реверс-инжинирингу, Форензике и Криптографии. Школа CTF с бесплатными курсами по всем категориям.

Проблема MIME потеря форматирования

oshmianski

Достойный программист
Lotus Team
25.04.2012
711
59
BIT
2
Доброго времени,

Имеем RTF с поднятой галочкой "Store contents as HTML and MIME".

Имеем значение этого поля:
MIME_PART_HAS_HEADERS
MIME_PART_BODY
ByteCount: 339
Boundary: ""
Headers: "Content-Type: text/html;charset=UTF-8

"
Body: "<p dir="ltr"><span style="font-family: arial,helvetica,sans-serif;"><span style="font-size: 12px;">ðƒÐÇð©ð▓ðÁÐéÔÇïÔÇï</span></span></p>
<br /><br />ð×Ðéð▓ðÁÐéÐüÐéð▓ðÁð¢ð¢Ðïð╣: ðÆð©ð¢ÐåðÁð╗ð¥ð▓ð©Ðç ðí. ðÿ.<br />ðúÐçÐÇðÁðÂð┤ðÁð¢ð©ðÁ: ðóðÁÐüÐéð¥ð▓Ðïð╣ ð¥ð┐ð¥ÐÇð¢Ðïð╣ ð¥ð▒ÐèðÁð║Ðé ð¥Ðé 18.07.2018<br />"

После обработки документа (чтение значения из этого поля и сохранение документа при session.ConvertMime = True) в UI Notes имеем значение:
MIME_PART_HAS_HEADERS
MIME_PART_BODY
ByteCount: 380
Boundary: ""
Headers: "Content-Type: text/html; charset="KOI8-R"
Content-Transfer-Encoding: base64

"
Body: "PHNwYW4gc3R5bGU9IiBmb250LXNpemU6OXB0O2ZvbnQtZmFtaWx5OkFyaWFsIj7w0snXxdQmIzgy
MDM7JiM4MjAzOzwvc3Bhbj4NCjxicj48c3BhbiBzdHlsZT0iIGZvbnQtc2l6ZToxMnB0Ij48YnI+
DQo8YnI+DQrv1NfF1NPU18XOztnKOiD3yc7DxczP18neIPMuIOkuPGJyPg0K9d7SxdbExc7JxTog
9MXT1M/X2cogz9DP0s7ZyiDPwt/Fy9Qgz9QNCjE4LjA3LjIwMTg8L3NwYW4+DQo=
"

если раскрыть base64, то имеем:
<span style=" font-size:9pt;font-family:Arial">Привет&#8203;&#8203;</span>
<br><span style=" font-size:12pt"><br>
<br>
Ответственный: ТУТ_ФИО<br>
Учреждение: Тестовый опорный объект от
18.07.2018</span>


Вопросы:
1. Почему меняется кодировка?
2. Почему преобразуется в base64?
3. Почему коверкается содержимое (меняется html разметка, стили)?
 

oshmianski

Достойный программист
Lotus Team
25.04.2012
711
59
BIT
2

lmike

нет, пердело совершенство
Lotus Team
27.08.2008
7 933
609
BIT
177
У меня ж уже все в MIME, зачем еще что-то делать?

вот после сохранения документа и меняется. или я не совсем понимаю термин "стадия"?
правильно, но есть уверенность что до сохранения там уже не кракозябры?
 

lmike

нет, пердело совершенство
Lotus Team
27.08.2008
7 933
609
BIT
177
Хорошо, тогда другой вопрос.
Если сделать session.ConvertMime = False, то как значение одного rtf (MIME) запихнуть в другое rtf (native), т.е. как html преобразовать в rtf?
это очень может зависеть от задачи, но прямой конвертации нет и получается - никак
 

oshmianski

Достойный программист
Lotus Team
25.04.2012
711
59
BIT
2
правильно, но есть уверенность что до сохранения там уже не кракозябры?
кракозяблы то меня не особо волнуют, а вот потеря html форматирования (с документами в основном работают в вебе) удручает :-(
 

lmike

нет, пердело совершенство
Lotus Team
27.08.2008
7 933
609
BIT
177
Есть две системы (бд) - с одной работают в вебе, вторая только Notes.
Пользователь второй бд из толстого клиента создает копию содержания документа из одной системы в другую.
подозреваю "наследуемую" систему и предлагать изменить подход даже не буду ;)
решения с сохранением форматирования завязаны на адекватный рендерер содержимого (как в веб так и в нотусне), в нотусне его нет (и, полагаю, уже не будут делать) :(
 
Мы в соцсетях:

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