Manual:Image administration/ru

From MediaWiki.org
Jump to navigation Jump to search
This page is a translated version of the page Manual:Image administration and the translation is 61% complete.

Outdated translations are marked like this.
Other languages:
Bahasa Indonesia • ‎Deutsch • ‎English • ‎español • ‎français • ‎polski • ‎português • ‎português do Brasil • ‎русский • ‎العربية • ‎中文 • ‎日本語 • ‎한국어

Данная статья содержит сведения о том, как MediaWiki хранит файлы и о том, как настроить этот функционал.

Это относится к изображениям так же, как и к любым другим типам файлов, которые могут быть загружены (uploaded). Все файлы хранятся с соответствующей статьёй в пространстве имён "File:" ("Файл:"). MediaWiki до версии 1.14 использовали пространство имён "Image:" вместо "File:". "Image:" до сих пор поддерживается как псевдоним для обратной совместимости.

Загрузка и использование изображений

См. Справка:Изображения

Включение функции загрузки файлов

Для загрузки файла должны совпасть три условия:

  1. Функция загрузки файлов в MediaWiki должна быть включена. Установите для $wgEnableUploads значение «true».
  2. Тип файла должен быть разрешённым. Подробности: $wgFileExtensions .
  3. Участник должен входить в группу с правом «upload». По умолчанию это право дано всем авторизованным участникам.

Загрузка файлов выполняется посредством служебной страницы Special:Upload.

См. Manual:Настройка загрузки файлов , Manual:Mime type detection

Параметры, относящиеся к работе с файлами

Следующие параметры имеют отношения к функционалу работы с файлами:

Создание миниатюр изображений

Расширенный синтаксис изображений MediaWiki позволяет автоматически создавать миниатюры изображений (см. Manual:Configuring file uploads/ru по общей помощи по загрузке файлов).

Функция создания миниатюр (Image thumbnailing) требует наличия ImageMagick или библиотеки GD - ни один из этих продуктов не входит в дистрибутив MediaWiki по умолчанию, хотя некоторые версии PHP включают GD. Рекомендуется использовать ImageMagick для получения миниатюр лучшего качества. Загрузить ImageMagick можно с imagemagick.org. GD включён в некоторые версии PHP, а в системах под управлением ОС Windows рекомендуется использовать именно GD. Библиотека GD доступна для загрузки с LibGD GitHub.

Осторожно! Предупреждение: Версия MediaWiki 1.17 требует, чтобы ImageMagick был как минимум в версии 6.5.6-2.

В новых версиях этого не требуется.

Если вы используете ImageMagick, установите $wgUseImageMagick в значение «true» в файле LocalSettings.php. Убедитесь что $wgImageMagickConvertCommand указывает на (абсолютный) путь к расположению команды конвертации в вашей инсталляции, а также что команда выполнима для веб-сервера. К примеру, пользователи ОС Windows могут захотеть изменить значение по умолчанию на «C:\ImageMagick\convert.exe» (или что-то подобное).

To re-create old thumbnail files before you used ImageMagick you can use $wgThumbnailEpoch .

If rendering fails silently, check and increase $wgMaxShellMemory .

See the help page on Image Thumbnails not working for troubleshooting.

GraphicsMagick can now also be used as an alternative to ImageMagick. You will need to set $wgImageMagickConvertCommand to the (absolute) location of the 'gm' command. Например:

$wgImageMagickConvertCommand = "/usr/bin/gm";

GIF

Для создания миниатюр для анимированных GIF-файлов в среде Windows, вам потребуется установить ImageMagick согласно описанию выше.

SVG

Wikimania 2016 presentation on Dynamic SVG

MediaWiki поддерживает возможность рендеринга изображений в формате SVG: если такая возможность включена, изображения в формате SVG могут использоваться так же, как и любые другие — они будут автоматически растеризоваться и отображаться в виде файлов в формате PNG, с генерацией миниатюр «на лету», по мере необходимости. If you're on a shared host and no SVG renderer is pre-installed, you should probably ask your provider to install it for you.

Для включения поддержки SVG необходимо:

  1. Разрешите в LocalSettings.php возможность загрузки файлов SVG: $wgFileExtensions[] = 'svg'; Обратите внимание, что по соображениям безопасности MediaWiki откажется обрабатывать SVG-файлы, содержащие JavaScript.
  1. ːЧтобы избежать ложных срабатываний, добавьте $wgAllowTitlesInSVG = true; в файл LocalSettings.php .
  1. ːЕсли вы получаете сообщение об ошибке, где говорится, что файл повреждён, убедитесь, что определение типа MIME работает нормально.
  1. Добавьте $wgSVGConverter в файл LocalSettings.php и выберите инструмент, который вы хотите использовать для растеризации.
    Можно выбирать из ImageMagick, ImagickExt, sodipodi, inkscape, batik, rsvg, и imgserv.
    For example: $wgSVGConverter = 'ImageMagick';
    • Если путь к выбранному программному конвертеру не содержится в переменной окружения system path, то нужно явно задать папку этой программы посредством параметра $wgSVGConverterPath ..
    • librsvg быстр, но не очень аккуратен. It depends on a large number of libraries. To automatically install all these libraries, you may want to use a package manager. Проекты Викимедиа используют rsvg 2.14.
    • Batik обеспечивает наиболее точную отрисовку SVG среди доступных решений, хотя подчас недостаточно хорошо справляется со сглаживанием (anti-aliasing). У него более строгие правила разбора SVG, что заставляет его отвергать «почти правильные» SVG-файлы, принимаемые другими конвертерами (например, commons:File:UbuntuCoF.svg). Батик основан на Java, и гораздо медленнее, чем rsvg, хотя это не может быть большой проблемой, если только вы постоянно не добавляете SVG-файлы. См. сравнительные тесты SVG. Требуется много усилий, чтобы заставить его работать, если только он не входит в ваш дистрибутив.
    • Inkscape также не слишком аккуратно обрабатывает SVG-файлы, и примерно в два раза медленне, чем rsvg. При этом он был спроектирован для интерактивной работы с графигой, поэтому требует, чтобы у запускающего его пользователя была на сервере домашняя папка (home directory) с правами на запись. Поскольку он будет работать как пользователь www или кто-то подобный, он будет пытаться создать папки .inkscape/ и .gnome2/ в соответствующей домашней папке, и молча сломается, если это ему не удастся. Inkscape предпочтительнее, чем rsvg, в случаях (а) если используется среда Windows (если говорить об отдельном пакете) или (б) если у вас имеются важные SVG-файлы, нарисованные в Inkscape, которые некорректно обрабатываются в rsvg. Inkscape связан сложной цепью зависимостей с librsvg — используйте, только если эти компоненты есть в вашем дистрибутиве или доступны в качестве полностью автономного пакета.
    • Sodipodi — это ответвление от Inkscape. Применимо всё то же самое, что и к Inkscape. Sodipod в настоящее время активно не разрабатывается.
    • ImageMagick обрабатывает SVG-файлы, но с массой ошибок. Это значение по умолчанию, но избегайте его, если только это возможно. However, it does work. On Windows, $wgConvertPath must be set to avoid a conflict with Windows' own convert.exe. One simple alternative in this scenario is to add to LocalSettings.php the line $wgSVGConverters['ImageMagick'] = '"' . $wgImageMagickConvertCommand . '" -background white -thumbnail $widthx$height^! $input PNG:$output';, which also allows for spaces in the path.
    • The PHP Imagick extension supports SVG rendering, however the same considerations as for the regular ImageMagick apply.
    • Библиотека GD не способна преобразовывать изображения SVG в формат PNG, по крайней мере, согласно записи Джоя Асмуссена (Joen Asmussen) в блоге NoScope от июня 2008.
    • Многие современные веб-браузеры, за исключением Internet Explorer, умеют отображать файлы SVG напрямую — быстро, но неаккуратно (примерно так же, как ImageMagick). Использование librsvg для растенризации SVG и преобразования его в формат PNG даст гораздо более аккуратный результат. Прямое отображение SVG в MediaWiki по умолчанию не поддерживается (задача T5593), однако вы можете установить для этой цели расширение NativeSvgHandler.

Set $wgSVGConverter = false if SVG rendering is not needed and you wish to make your users download the svg file in order to view it.

Troubleshooting

If you see a blank square instead of SVG (Chrome) or no image at all (Firefox) and all PNG links lead to 404 error and you don't see any other error message anywhere please check $wgGenerateThumbnailOnParse variable. Setting it to false may make SVG transformation deferred always. Make sure that proc_open and symlink PHP methods are enabled (they may be disabled in php.ini for security or performance reasons).

JPEG (с использованием GD)

Об ошибках, связанных с созданием миниатюр JPEG-файлов, см.

$wgUseImageMagick = false;

Об ошибках, связанных с созданием миниатюр JPEG-файлов, см. JPEG (с использованием GD).

TIFF

Для создания миниатюр файлов TIFF требуется MediaWiki версии 1.15.0 или выше.

  1. Разрешите в LocalSettings.php возможность загрузки файлов TIFF: $wgFileExtensions[] = 'tif';

$wgFileExtensions [] = 'tif';

  1. Добавьте в LocalSettings.php параметр $wgTiffThumbnailType и установите его значение в jpg или png в зависимости от того, какой из этих форматов вы предпочитаете для создания миниатюр.
  1. Изготовление миниатюр для файлов TIFF может потребовать дополнительных системных ресурсов помимо тех, которые необходимы для миниатюр JPEG, GIF и PNG.

Соответствующие настройки для этого — $wgMaxImageArea и $wgMaxShellMemory.

DjVu

Удаление изображений

Файлы, как и вики-страницы, могут удалять только участники с правами «Delete pages (delete)» (по умолчанию — administrators). Удаление файла вызывает также и удаление ассоциированной с ним вики-страницы с описанием (то же достигается, если перейти по ссылке «delete all» в таблице «File history»).

Удаление отдельных версий файлов

Если файл был изменён, то история его изменений отображается на странице его описания. Каждая версия сопровождается ссылкой «delete». Перейдя по ней, можно навсегда удалить данную версию файла вместе с записью в истории изменений.

История версий файлов отличается от истории изменений страниц с их описанием.

Информация о старых версиях файлов хранится в таблице «oldimage », в то время как информация о старых версиях страниц хранится в таблице «revision ».

Восстановление файлов

Внимание Внимание: Вплоть до версии MediaWiki 1.8, удаление изображений/файлов было невосстановимым (могли быть восстановлены только связанные с файлами страницы описаний).

Начиная с версии MediaWiki 1.8 и вплоть до 1.10, архивирование удалённых изображений/файлов (и, следовательно, их восстановление) по умолчанию отключено, но может включаться через настройку $wgSaveDeletedFiles = true.

Начиная с версии MediaWiki 1.11, эта функция по умолчанию включена, и $wgSaveDeletedFiles считается устаревшим. Вместо этого, поведение в отношении файлов контролируется с помощью $wgFileStore .

Since 1.24 its controlled by Manual:$wgDeletedDirectory

Информация об удалённых файлах хранится в таблице «filearchive».

Удаление архивных версий файлов

Since MediaWiki version 1.11, deleted images are still stored on the server by default. If you want to delete selected archived images, you can do so using the eraseArchivedFile.php maintenance script. If you want to delete all of them completely, you can do that with the deleteArchivedFiles.php script. If you delete archived files, you can not undelete those files anymore.

Причины удаления файлов

When choosing to delete a file, as described above, users will be asked to provide a reason for deletion. The available reasons can be edited on the MediaWiki:Filedelete-reason-dropdown of your wiki.

Хранение данных

Как только изображение загружается, создаётся следующее:

  1. Статья в пространстве имён file с именем этого файла, например, File:MyPicture.png. Эта страница хранится и может редактироваться подобно любой другой странице.
  1. Сам файл, хранящийся в папке файловой системы.
  1. Если подключено создание миниатюр, при необходимости будут создаваться уменьшенные версии этого файла (например, для использования на странице описания файла). Они хранятся в папке thumb внутри директории images, в отдельной папке для каждого основного файла.

Если $wgHashedUploadDirectory включена (по умолчанию), MediaWiki создает несколько подпапок в папке «images».

Названия папок являются первыми двумя символами md5-хеша конечного имени файла.

Папки

Все файлы изображений хранятся в отдельной папке, расположение которой определяется посредством $wgUploadPath (по умолчанию, images/).

Описание именованных подпапок изображений:

archive
Это место хранения файлов, которые заменены более новыми версиями.
temp
используется при загрузке изображений. (Но для таких файлов может оказаться недоступным автоматическое их удаление — см. задача T11018)
thumb
Миниатюры файлов (автоматически создаваемые). Будучи удалены, будут при необходимости автоматически восстановлены.

В зависимости от настроек, может использоваться дополнительная подпапка:

math
Папка для хранения растеризованных формул в формате TeX, см. также Manual:Enable TeX или Math.
x/xy
If $wgHashedUploadDirectory is set to true (which is the default), images will be stored in subfolders of the images, thus making file paths look like images/a/ab/filename.jpg. See Manual:$wgHashedUploadDirectory for more details on why this might be desired and how this system works.

Таблицы базы данных

  • The file description page is stored as any page in the page, text, revision etc. tables
  • image table: Holds some metadata such as the size of the file and the upload date.
  • oldimage table: This is stores information for files that have been replaced with newer versions.
  • filearchive table: holds the information on the deleted files.
  • imagelinks table: Records what pages use a file.

Использование дискового пространства

Files need considerably more space than articles. The following calculations assume a block size of 4KB with Linux/Unix servers.

Настройка по умолчанию выглядит как $wgHashedUploadDirectory = true.

Требуемое дисковое пространство для всех папок:

  • image directories: 0-f/x0-f: max. 16*16 = 256 directories = 256*4 KB = 1024 KB
  • archive directories: 0-f/x0-f: max. 16*16 = 256 directories = 256*4 KB = 1024 KB
  • thumb directories: 0-f/x0-f: max. 16*16 = 256 directories = 256*4 KB = 1024 KB
  • temp directories: 0-f/x0-f: max. 16*16 = 256 directories = 256*4 KB = 1024 KB

Therefore, the basic amount of space needed without any images uploaded is 4 MB in theory (although the directories are created only when needed).

Для каждого файла необходимо:

  • size of the original image file + 2 KB average overhead

Для файлов, которым требуются миниатюра:

  • size of the created thumbnail(s) + 2 KB average overhead (each)
  • directory for thumbnail (4KB) (each image has its own thumbnail directory)

Примеры:

  • image 20778 Byte png (small size, no thumb): 24 KB for the image: Total 24 KB
  • image 123.000 Byte jpeg (big size, auto thumb): 124 KB for the image, 4KB for the thumb directory, 64 KB for the thumb: Total: 192 KB

Доступ к файлам

Uploaded files are generally served directly by the web server, not through MediaWiki. While there may be a minimal level of security through obscurity with path encryption (eg. /c/c4/...) if $wgHashedUploadDirectory is set, the path can be calculated easily from the file name and does not provide true protection.

For limiting access to authorized users, see Image Authorization

Лицензирование

A feature of MediaWiki allows the Special:Upload Page to streamline licensing of images. Wikipedia's Upload Page has a Licensing drop down box below image summary. This feature is turned off in default MediaWiki. To turn this feature on a sysop needs to edit Licenses in the MediaWiki namespace (example: MediaWiki:Licenses). S/he can do this by going to the MediaWiki:Licenses page of their wiki and clicking 'create' or 'edit'.

The page MediaWiki:Licenses expects a certain format in a wiki list.

*subst:license 1|license 2|License text
* Header 1:
** cc-by-sa-2.5|Attribution ShareAlike 2.5

Line 1 will produce "License text" and substitute the license 1 template in the image page and transclude license 2.
Line 2 will show a greyed out header with text "Header 1:"
Line 3 will produce "Attribution ShareAlike 2.5" and transclude template cc-by-sa-2.5 on the image page.

For detailed real world example, see Wikipedia:MediaWiki:Licenses or Commons:MediaWiki:Licenses.

Внешние хранилища

It is possible to access files stored in foreign repositories, without needing to upload them to the wiki, by setting the $wgForeignFileRepos array. This feature offers several possibilities:

  • ForeignAPIRepo accesses files from a remote MediaWiki installation, such as Wikimedia Commons, through its API
  • ForeignDBRepo accesses files through a database, and is useful for creating wiki families
  • FSRepo accesses files from a local folder

In all cases, one would be able to embed files into a page using ordinary image syntax and specifying the name of the file in the foreign repository. Note that some of the above implementations are still experimental, and might not be suitable for production sites.

Версии MediaWiki

Применимо к версиям:

  • MediaWiki 1.9.x и выше
  • другие версии не проверялись