VeraCrypt
aboutsummaryrefslogtreecommitdiff
path: root/doc/html/ru/Sharing over Network.html
diff options
context:
space:
mode:
Diffstat (limited to 'doc/html/ru/Sharing over Network.html')
-rw-r--r--doc/html/ru/Sharing over Network.html66
1 files changed, 66 insertions, 0 deletions
diff --git a/doc/html/ru/Sharing over Network.html b/doc/html/ru/Sharing over Network.html
new file mode 100644
index 00000000..cb945651
--- /dev/null
+++ b/doc/html/ru/Sharing over Network.html
@@ -0,0 +1,66 @@
+<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
+ "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
+<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="ru" lang="ru">
+<head>
+<meta http-equiv="content-type" content="text/html; charset=utf-8" />
+<title>VeraCrypt - Бесплатное надёжное шифрование дисков с открытым исходным кодом</title>
+<meta name="description" content="VeraCrypt это бесплатное программное обеспечение для шифрования дисков с открытым исходным кодом для Windows, Mac OS X (macOS) и Linux. В случае, если злоумышленник вынуждает вас раскрыть пароль, VeraCrypt обеспечивает правдоподобное отрицание наличия шифрования. В отличие от пофайлового шифрования, VeraCrypt шифрует данные в реальном времени (на лету), автоматически, прозрачно, требует очень мало памяти и не использует временные незашифрованные файлы."/>
+<meta name="keywords" content="encryption, security, шифрование, безопасность"/>
+<link href="styles.css" rel="stylesheet" type="text/css" />
+</head>
+<body>
+
+<div>
+<a href="Documentation.html"><img src="VeraCrypt128x128.png" alt="VeraCrypt"/></a>
+</div>
+
+<div id="menu">
+ <ul>
+ <li><a href="Home.html">Начало</a></li>
+ <li><a href="/code/">Исходный код</a></li>
+ <li><a href="Downloads.html">Загрузить</a></li>
+ <li><a class="active" href="Documentation.html">Документация</a></li>
+ <li><a href="Donation.html">Поддержать разработку</a></li>
+ <li><a href="https://sourceforge.net/p/veracrypt/discussion/" target="_blank">Форум</a></li>
+ </ul>
+</div>
+
+<div>
+<p>
+<a href="Documentation.html">Документация</a>
+<img src="arrow_right.gif" alt=">>" style="margin-top: 5px">
+<a href="Miscellaneous.html">Разное</a>
+<img src="arrow_right.gif" alt=">>" style="margin-top: 5px">
+<a href="Sharing%20over%20Network.html">Общий доступ по сети</a>
+</p></div>
+
+<div class="wikidoc">
+<h1>Общий доступ по сети</h1>
+<p>Если требуется доступ к одному и тому же тому VeraCrypt одновременно из нескольких операционных
+систем, возможны два варианта:</p>
+<ol>
+<li>Том VeraCrypt монтируется только на одном компьютере (скажем, на сервере), а по сети совместно используется
+только содержимое смонтированного тома VeraCrypt (то есть файловая система внутри тома VeraCrypt). Пользователи
+других компьютеров или систем не монтируют том (он уже смонтирован на сервере).
+<p><strong>Преимущества</strong><span>: все пользователи могут записывать данные в том VeraCrypt. Совместно
+используемый том может быть как на основе файла, так и на основе раздела/устройства.</span></p>
+<p><strong>Недостаток</strong><span>: пересылаемые по сети данные не будут зашифрованными. Тем не менее их
+всё-таки можно шифровать с помощью SSL, TLS, VPN и других технологий.</span></p>
+<p><strong>Замечания</strong>: примите к сведению, что при перезагрузке системы общий сетевой ресурс будет
+автоматически восстановлен только в случае, если это системный избранный том или зашифрованный системный
+раздел/диск (о том, как сделать том системным избранным томом, см. в главе <a href="System%20Favorite%20Volumes.html">
+<em>Системные избранные тома</em></a>).</p>
+</li><li>Размонтированный файловый контейнер VeraCrypt хранится на одном компьютере (скажем, на сервере).
+Этот зашифрованный файл доступен по сети. Пользователи других компьютеров или систем будут локально монтировать
+этот общий файл. Таким образом, том будет монтироваться одновременно в нескольких операционных системах.
+<p><strong>Преимущество</strong><span>: пересылаемые по сети данные будут зашифрованными (тем не менее, их всё же
+рекомендуется шифровать с помощью SSL, TLS, VPN или других подходящих технологий, чтобы ещё сильнее осложнить
+анализ трафика и сохранить целостность данных).</span></p>
+<p><strong>Недостатки</strong>: общий том может быть только на основе файла-контейнера (но не на основе
+раздела/устройства). В каждой из систем том должен монтироваться в режиме только для чтения (о том, как
+смонтировать том в режиме только для чтения, см. раздел <em>Параметры монтирования</em>). Обратите внимание,
+что это требование относится и к незашифрованным томам. Одна из причин, например, в том, что данные, считанные
+из обычной файловой системы в среде одной ОС, в это же время могут быть изменены другой ОС, и потому
+окажутся несогласованными (что может привести к повреждению данных).</p>
+</li></ol>
+</div><div class="ClearBoth"></div></body></html>
pan class="k">static __int64 TotalSize; static __int64 resumedPointBytesDone; static BOOL bProgressBarReverse = FALSE; static BOOL bRWThroughput = FALSE; static BOOL bShowStatus = FALSE; static BOOL bPercentMode = FALSE; static wchar_t *seconds, *minutes, *hours, *days; // If bIOThroughput is TRUE, the speed reflects the amount of data read AND written per second (rather than // the speed of the "transform cursor"). void InitProgressBar (__int64 totalBytes, __int64 bytesDone, BOOL bReverse, BOOL bIOThroughput, BOOL bDisplayStatus, BOOL bShowPercent) { HWND hProgressBar = GetDlgItem (hCurPage, nPbar); SendMessage (hProgressBar, PBM_SETRANGE32, 0, 10000); SendMessage (hProgressBar, PBM_SETSTEP, 1, 0); bProgressBarReverse = bReverse; bRWThroughput = bIOThroughput; bShowStatus = bDisplayStatus; bPercentMode = bShowPercent; seconds = GetString ("SECONDS"); minutes = GetString ("MINUTES"); hours = GetString ("HOURS"); days = GetString ("DAYS"); prevTime = startTime = GetTickCount (); TotalSize = totalBytes; resumedPointBytesDone = bytesDone; } BOOL UpdateProgressBar (__int64 byteOffset) { return UpdateProgressBarProc (byteOffset); } BOOL UpdateProgressBarProc (__int64 byteOffset) { wchar_t text[100]; wchar_t speed[100]; HWND hProgressBar = GetDlgItem (hCurPage, nPbar); int time = GetTickCount (); int elapsed = (time - startTime) / 1000; uint64 bytesDone = (bProgressBarReverse ? (TotalSize - byteOffset) : byteOffset); uint64 bytesPerSec = (bProgressBarReverse ? (resumedPointBytesDone - byteOffset) : (bytesDone - resumedPointBytesDone)) / (elapsed + 1); if (bPercentMode) { double perc = (double) (100.0 * (bProgressBarReverse ? ((double) (TotalSize - byteOffset)) : ((double) byteOffset)) / (TotalSize == 0 ? 0.0001 : ((double) TotalSize))); if (perc > 99.999999999) wcscpy (text, GetString ("PROCESSED_PORTION_100_PERCENT")); else _snwprintf (text, sizeof text/2, GetString ("PROCESSED_PORTION_X_PERCENT"), perc); wcscat (speed, L" "); } else { GetSizeString (bytesDone, text); if (bytesDone < (unsigned __int64) BYTES_PER_MB * 1000000) swprintf(text, L"%I64d %s ", bytesDone / BYTES_PER_MB, GetString ("MB")); else if (bytesDone < (unsigned __int64) BYTES_PER_GB * 1000000) swprintf(text, L"%I64d %s ", bytesDone / BYTES_PER_GB, GetString ("GB")); else if (bytesDone < (unsigned __int64) BYTES_PER_TB * 1000000) swprintf(text, L"%I64d %s ", bytesDone / BYTES_PER_TB, GetString ("TB")); else swprintf(text, L"%I64d %s ", bytesDone / BYTES_PER_PB, GetString ("PB")); } SetWindowTextW (GetDlgItem (hCurPage, IDC_BYTESWRITTEN), text); if (!bShowStatus) { GetSpeedString (bRWThroughput ? bytesPerSec*2 : bytesPerSec, speed); wcscat (speed, L" "); SetWindowTextW (GetDlgItem (hCurPage, IDC_WRITESPEED), speed); } if (byteOffset < TotalSize) { int64 sec = (int64) ((bProgressBarReverse ? byteOffset : (TotalSize - byteOffset)) / (bytesPerSec == 0 ? 0.001 : bytesPerSec)); if (bytesPerSec == 0 || sec > 60 * 60 * 24 * 999) swprintf (text, L"%s ", GetString ("NOT_APPLICABLE_OR_NOT_AVAILABLE")); else if (sec >= 60 * 60 * 24 * 2) swprintf (text, L"%I64d %s ", sec / (60 * 24 * 60), days); else if (sec >= 120 * 60) swprintf (text, L"%I64d %s ", sec / (60 * 60), hours); else if (sec >= 120) swprintf (text, L"%I64d %s ", sec / 60, minutes); else swprintf (text, L"%I64d %s ", sec, seconds); SetWindowTextW (GetDlgItem (hCurPage, IDC_TIMEREMAIN), text); } prevTime = time; SendMessage (hProgressBar, PBM_SETPOS, (int) (10000.0 * (bProgressBarReverse ? (TotalSize - byteOffset) : byteOffset) / (TotalSize == 0 ? 1 : TotalSize)), 0); return bVolTransformThreadCancel; }