Файлы manifest что это
Зачем Win32-приложению манифест?
Недавно на руборде в разделе Программирование был задан вопрос: «Зачем Win32-приложению манифест? На что он влияет?». Первое, что сразу приходит в голову большинству программистов — это темы оформления. Но на самом деле в современных виндах манифест нужен не только для этого. Я подумал и написал пять ключевых аспектов, на которые влияет манифест или его отсутствие. После этого сразу несколько человек попросили оформить этот пост в виде более развернутой статьи.
Для начала предлагаю вспомнить, как вообще в Windows появились манифесты, и как они развивались.
История манифеста
В древние времена в мире Win95/98 царил ад, точнее DLL hell. Возник он из-за того, что Windows задумывалась как идеальная система. Все приложения в ней всегда должны были писаться с использованием самых свежих версий системных библиотек. А различные версии самих библиотек должны были быть взаимозаменяемыми. Реальность быстро доказала всем, что для популярной операционки это несбыточная мечта, так и возник ад. Каждое второе приложение во время инсталляции перезаписывало системные библиотеки нужными ему версиями. В результате после установки приложения X установленное ранее приложение Y начинало глючить. А после переустановки приложения Y глючить начинало приложение X. В общем юзерам жилось весело.
Всем был хорош SxS кроме одного — он был ужасно неудобен для программиста. В 99% случаев манифест применялся только для включения тех самых тем оформления, и ни для чего больше. Разработчикам винды стало ясно, что нужен новый, более простой в использовании способ указать поддерживаемые версии системных библиотек. Тогда они придумали простое правило: в пределах одной версии системы интерфейс и поведение этих библиотек не изменяется. Нужно было только каким то образом научится определять какая их версия требуется конкретному приложению. Так в Windows 7 в манифесте появилась секция Compatibility, где можно указать с какими версиями ОС тестировалось приложение.
Также в манифесте начиная с Windows Vista появилось еще несколько секций, обо всех о них ниже.
Функции манифеста
Справа тоже самое приложение без манифеста:
Запрос разрешения пользователя:
Виртуализация файловой системы в деле:
Разработчики Висты не стерпели подобного безобразия, и заложили в DWM возможность производить масштабирование самостоятельно, а приложениям врать, что DPI по прежнему равен 96. Причем зависящие от него системные настройки, разрешение монитора и даже положение мыши, также пересчитываются. К сожалению разработчики Висты небыли волшебниками, поэтому масштабирование DWM производит с помощью простых алгоритмов растягивания изображений. И если интерфейс приложения нужно увеличить, то происходит замыливание картинки. Представьте что было бы, если бы разработчики Фотошопа не могли это отключить. Таких бунтов на корабле никто не хотел, поэтому появилась возможность указать в манифесте, что ваше приложение таки умеет нормально масштабировать свой интерфейс, и помощь DWM ему не нужна. За это отвечает параметр dpiAware. Тут правда следует отметить, что по умолчанию масштабирование силами DWM включается при увеличении 150% и выше. Видимо в Microsoft посчитали, что при масштабировании 125% артефакты как на скриншоте выше вполне терпимы.
Слева масштабирование силами DWM, а справа — самого приложения:
В Windows 8.1 появилась возможность указывать разный масштаб разным мониторам, если подключено сразу несколько. Соответственно у ключа dpiAware появилось новое значение «True/PM». Оно означает, что приложение умеет динамически изменять масштаб своего интерфейса при переносе окон с одного монитора на другой.
Наиболее интересен вопрос: «На что влияют эти GUID-ы?» Пока что список различий в поведении системных библиотек невелик. Наиболее интересно упоминание об оптимизации RPC. Получается что приложения, задекларировавшие совместимость с семеркой, будут работать быстрее.
В будущем этот раздел манифеста наверняка будет играть большую роль чем сейчас. Ведь в винде полно разных хаков призванных обеспечивать совместимость. И теперь есть возможность оградить от них нормальные приложения.
Если GUID-ы полностью отсутствуют в манифесте, то к приложению применяются правила как к совместимому с Вистой:
Расширение файла MANIFEST
Windows Application Manifest Format
Что такое файл MANIFEST?
Для чего нужны файлы MANIFEST?
Манифест файловых приложений
Манифест и CDF-MS файлы
Файлы MANIFEST обычно компилируются в файлы CDF-MS, чтобы позволить основной программе иметь более быстрый доступ к параметрам приложения.
Программы, которые поддерживают MANIFEST расширение файла
В следующем списке перечислены программы, совместимые с файлами MANIFEST, которые разделены на категории 3 в зависимости от операционной системы, в которой они доступны. Файлы с суффиксом MANIFEST могут быть скопированы на любое мобильное устройство или системную платформу, но может быть невозможно открыть их должным образом в целевой системе.
Программы, обслуживающие файл MANIFEST
Как открыть файл MANIFEST?
Проблемы с доступом к MANIFEST могут быть вызваны разными причинами. К счастью, наиболее распространенные проблемы с файлами MANIFEST могут быть решены без глубоких знаний в области ИТ, а главное, за считанные минуты. Мы подготовили список, который поможет вам решить ваши проблемы с файлами MANIFEST.
Шаг 1. Получить Microsoft Visual Studio
Наиболее распространенной причиной таких проблем является отсутствие соответствующих приложений, поддерживающих файлы MANIFEST, установленные в системе. Наиболее очевидным решением является загрузка и установка Microsoft Visual Studio или одной из перечисленных программ: ClickOnce, Windows Notepad, NotePad++ text editor. Выше вы найдете полный список программ, которые поддерживают MANIFEST файлы, классифицированные в соответствии с системными платформами, для которых они доступны. Одним из наиболее безопасных способов загрузки программного обеспечения является использование ссылок официальных дистрибьюторов. Посетите сайт Microsoft Visual Studio и загрузите установщик.
Шаг 2. Убедитесь, что у вас установлена последняя версия Microsoft Visual Studio
Если проблемы с открытием файлов MANIFEST по-прежнему возникают даже после установки Microsoft Visual Studio, возможно, у вас устаревшая версия программного обеспечения. Проверьте веб-сайт разработчика, доступна ли более новая версия Microsoft Visual Studio. Разработчики программного обеспечения могут реализовать поддержку более современных форматов файлов в обновленных версиях своих продуктов. Если у вас установлена более старая версия Microsoft Visual Studio, она может не поддерживать формат MANIFEST. Последняя версия Microsoft Visual Studio должна поддерживать все форматы файлов, которые совместимы со старыми версиями программного обеспечения.
Шаг 3. Настройте приложение по умолчанию для открытия MANIFEST файлов на Microsoft Visual Studio
Если у вас установлена последняя версия Microsoft Visual Studio и проблема сохраняется, выберите ее в качестве программы по умолчанию, которая будет использоваться для управления MANIFEST на вашем устройстве. Метод довольно прост и мало меняется в разных операционных системах.
Процедура изменения программы по умолчанию в Windows
Процедура изменения программы по умолчанию в Mac OS
Шаг 4. Убедитесь, что MANIFEST не неисправен
Если проблема по-прежнему возникает после выполнения шагов 1-3, проверьте, является ли файл MANIFEST действительным. Отсутствие доступа к файлу может быть связано с различными проблемами.
1. Проверьте MANIFEST файл на наличие вирусов или вредоносных программ.
Если MANIFEST действительно заражен, возможно, вредоносное ПО блокирует его открытие. Немедленно просканируйте файл с помощью антивирусного инструмента или просмотрите всю систему, чтобы убедиться, что вся система безопасна. MANIFEST файл инфицирован вредоносным ПО? Следуйте инструкциям антивирусного программного обеспечения.
2. Проверьте, не поврежден ли файл
Если файл MANIFEST был отправлен вам кем-то другим, попросите этого человека отправить вам файл. Возможно, файл был ошибочно скопирован, а данные потеряли целостность, что исключает доступ к файлу. При загрузке файла с расширением MANIFEST из Интернета может произойти ошибка, приводящая к неполному файлу. Попробуйте загрузить файл еще раз.
3. Проверьте, есть ли у пользователя, вошедшего в систему, права администратора.
Существует вероятность того, что данный файл может быть доступен только пользователям с достаточными системными привилегиями. Переключитесь на учетную запись с необходимыми привилегиями и попробуйте снова открыть файл Windows Application Manifest Format.
4. Убедитесь, что ваше устройство соответствует требованиям для возможности открытия Microsoft Visual Studio
Если система перегружена, она может не справиться с программой, которую вы используете для открытия файлов с расширением MANIFEST. В этом случае закройте другие приложения.
5. Убедитесь, что у вас установлены последние версии драйверов, системных обновлений и исправлений
Регулярно обновляемая система, драйверы и программы обеспечивают безопасность вашего компьютера. Это также может предотвратить проблемы с файлами Windows Application Manifest Format. Устаревшие драйверы или программное обеспечение могли привести к невозможности использования периферийного устройства, необходимого для обработки файлов MANIFEST.
Вы хотите помочь?
Если у Вас есть дополнительная информация о расширение файла MANIFEST мы будем признательны, если Вы поделитесь ею с пользователями нашего сайта. Воспользуйтесь формуляром, находящимся здесь и отправьте нам свою информацию о файле MANIFEST.
Манифесты приложений
Манифест приложения — это файл XML, который описывает и определяет общие и закрытые сборки одновременного выполнения, которые приложению следует подключить во время выполнения. Это должны быть те же версии сборок, что и использованные для проверки приложения. Манифесты приложения также могут описывать метаданные закрытых для приложения файлов.
Полный список схем XML см. в разделе Схема файла манифеста.
Манифесты приложений имеют следующие элементы и атрибуты.
Элемент | Атрибуты | Обязательно |
---|---|---|
сборок | Да | |
манифестверсион | Да | |
не наследовать | Нет | |
Неправильн | Да | |
type | Да | |
name | Да | |
язык | Нет | |
processorArchitecture | Нет | |
version | Да | |
publicKeyToken | Нет | |
см | Нет | |
приклад | Нет | |
суппортедос | Id | Нет |
maxversiontested укажите установленную | Id | Нет |
зависимостей | Нет | |
dependentAssembly | Нет | |
File | Нет | |
name | Нет | |
hashAlg | Нет | |
hash | Нет | |
активекодепаже | Нет | |
автоповышение | Нет | |
дисаблесеминг | Нет | |
дисаблевиндовфилтеринг | Нет | |
дпиаваре | Нет | |
дпиаваренесс | Нет | |
гдискалинг | Нет | |
хигхресолутионскроллингаваре | Нет | |
лонгпасаваре | Нет | |
принтердриверисолатион | Нет | |
ултрахигхресолутионскроллингаваре | Нет | |
msix | Нет | |
хеаптипе | Нет |
Расположение файла
Манифесты приложений должны быть добавлены в качестве ресурсов в EXE-файл или библиотеку DLL приложения.
Дополнительные сведения см. в разделе Установка параллельных сборок.
Синтаксис имени файла
Имя файла манифеста приложения — это имя исполняемого объекта приложения, за которым следует manifest.
Элементы
В именах элементов и атрибутов учитывается регистр. Значения элементов и атрибутов не учитывают регистр, за исключением значения атрибута Type.
сборка
Элемент Assembly должен находиться в пространстве имен urn: schemas-microsoft-com: ASM. v1. Дочерние элементы сборки также должны находиться в этом пространстве имен путем наследования или добавления тегов.
Элемент Assembly имеет следующие атрибуты.
attribute | Описание |
---|---|
манифестверсион | Атрибут манифестверсион должен иметь значение 1,0. |
не наследовать
Элемент NoInherit является необязательным и обычно опускается. Большинство сборок работает неправильно с помощью контекста активации без наследования, так как сборка должна быть специально разработана для управления распространением собственного контекста активации. Использование элемента NoInherit требует, чтобы все зависимые сборки, на которые ссылается манифест приложения, имели элемент NoInherit в манифесте сборки.
assemblyIdentity
Элемент assemblyIdentity имеет следующие атрибуты. У него нет вложенных элементов.
совместимость
Содержит по крайней мере одно приложение. У него нет атрибутов. Необязательный элемент. манифесты приложений без элемента compatibility по умолчанию Windows совместимость с Vista на Windows 7.
application
суппортедос
Элемент суппортедос имеет следующий атрибут. У него нет вложенных элементов.
attribute | Описание |
---|---|
Id | Задайте для атрибута ID значение , чтобы запустить приложение с помощью функции Vista. это может позволить приложению, предназначенному для Windows Vista, работать в более поздней версии операционной системы. задайте для атрибута Id значение , чтобы запустить приложение с помощью функции Windows 7. приложения, поддерживающие Windows Vista, Windows 7 и функции Windows 8, не нуждаются в отдельных манифестах. в этом случае добавьте идентификаторы guid для всех операционных систем Windows. сведения о поведении атрибута Id в Windows см. в разделе Windows 8 и Windows Server 2012 Compatibility Cookbook. Следующие идентификаторы GUID соответствуют указанным операционным системам: — > Windows 10, Windows 11, Windows Server 2016, Windows server 2019 и Windows server 2022 — > Windows 8.1 и Windows Server 2012 R2 — > Windows 8 и Windows Server 2012 — > Windows 7 и Windows Server 2008 R2 — > Windows Vista и Windows Server 2008 вы можете протестировать это на Windows 7 или Windows 8. x, запустив монитор ресурсов (ресмон), перейдя на вкладку цп, щелкнув правой кнопкой мыши метки столбцов, «выбрать столбец. » и установив флажок «контекст операционной системы». на Windows 8. x можно также найти этот столбец, доступный в диспетчере задач (панели диспетчер задач). содержимое столбца показывает наибольшее найденное значение или «Windows Vista» в качестве значения по умолчанию. |
maxversiontested укажите установленную
элемент maxversiontested укажите установленную указывает версии Windows, на которые проверялось приложение, начиная с минимальной версии ос, поддерживаемой приложением до максимальной версии. Полный набор версий можно найти здесь. Он предназначен для использования в приложениях для настольных систем, использующих острова XAML и не развернутых в пакете MSIX. этот элемент поддерживается в Windows 10, версии 1903 и более поздних версиях.
Элемент maxversiontested укажите установленную имеет следующий атрибут. У него нет вложенных элементов.
attribute | Описание |
---|---|
Id | задайте для атрибута Id строку версии из 4 частей, которая указывает максимальную версию Windows, с которой было протестировано приложение. Например, «10.0.18226.0». |
dependency
Содержит по меньшей мере один dependentAssembly. У него нет атрибутов. Необязательный элемент.
dependentAssembly
Указывает файлы, являющиеся частными для приложения. Необязательный элемент.
Элемент File содержит атрибуты, приведенные в следующей таблице.
attribute | Описание |
---|---|
name | Имя файла. Например, Comctl32.dll. |
hashAlg | Алгоритм, используемый для создания хэша файла. Это значение должно быть SHA1. |
hash | Хэш файла, на который ссылается имя. Шестнадцатеричная строка длины в зависимости от хэш-алгоритма. |
активекодепаже
в Windows 10 этот элемент заставляет процесс использовать UTF-8 в качестве кодовой страницы процесса. Дополнительные сведения см. в разделе Использование кодовой страницы UTF-8. в Windows 10 единственным допустимым значением для активекодепаже является UTF-8.
начиная с Windows 11, этот элемент также позволяет выбрать устаревшую кодовую страницу не в кодировке UTF-8 или кодовые страницы для определенного языкового стандарта для совместимости с устаревшими приложениями. Современные приложения настоятельно рекомендуется использовать Юникод. в Windows 11 для активекодепаже также может быть задано значение Legacy или имя локали, например en-US или ja-JP.
этот элемент впервые был добавлен в Windows 10 версии 1903 (обновление 2019 мая). вы можете объявить это свойство и целевой объект или выполнить его в более ранних Windows сборках, но необходимо как обычно выполнять обнаружение и преобразование кодовых страниц прежних версий. Этот элемент не содержит атрибуты.
В следующем примере показано, как использовать этот элемент, чтобы заставить текущий процесс использовать UTF-8 в качестве кодовой страницы процесса.
автоповышение
Указывает, включен ли автоматический повышенный уровень прав. Значение true указывает, что он включен. У него нет атрибутов.
дисаблесеминг
Указывает, отключено ли предоставление элементов пользовательского интерфейса для темы. Значение true указывает, что отключено. У него нет атрибутов.
дисаблевиндовфилтеринг
Указывает, следует ли отключить фильтрацию окон. True — отключить фильтрацию окон, чтобы можно было перечислить иммерсивное окно с рабочего стола. дисаблевиндовфилтеринг был добавлен в Windows 8 и не имеет атрибутов.
дпиаваре
Указывает, учитывается ли текущий процесс в точках на дюйм (DPI).
В следующей таблице описывается поведение, получаемое в зависимости от наличия элемента дпиаваре и содержащегося в нем текста. В тексте элемента не учитывается регистр.
Дополнительные сведения о параметрах осведомленности о dpi см. в разделе Сравнение уровней осведомленности о dpi.
дпиаваре не имеет атрибутов.
дпиаваренесс
Указывает, учитывается ли текущий процесс в точках на дюйм (DPI).
Элемент дпиаваренесс может содержать один элемент или список элементов с разделителями-запятыми. В последнем случае используется первый (крайний левый) элемент в списке, распознанном операционной системой. таким образом можно указать различные варианты поведения, поддерживаемые в будущих Windows версиях операционных систем.
В следующей таблице описывается поведение, получаемое в зависимости от наличия элемента дпиаваренесс и содержащегося в нем текста в его левом распознанном элементе. В тексте элемента не учитывается регистр.
Дополнительные сведения о параметрах осведомленности о разрешении, поддерживаемых этим элементом, см. в разделе _ Поддержка dpi и _ _ контекст осведомленностио dpi.
дпиаваренесс не имеет атрибутов.
гдискалинг
Платформа GDI (интерфейс графических устройств) может применять масштабирование DPI к примитивам и тексту на уровне отдельных мониторов без обновления самого приложения. Это может быть полезно для приложений GDI, которые больше не обновляются.
Невекторная графика (например, точечные рисунки, значки или панели инструментов) не может масштабироваться этим элементом. Кроме того, графика и текст, отображаемые в растровых изображениях, динамически создаваемые приложениями, также не могут масштабироваться этим элементом.
Значение true указывает, что этот элемент включен. У него нет атрибутов.
хигхресолутионскроллингаваре
Указывает, включено ли разрешение на прокрутку с высоким разрешением. Значение true указывает, что он включен. У него нет атрибутов.
лонгпасаваре
принтердриверисолатион
Указывает, включена ли изоляция драйвера принтера. Значение true указывает, что он включен. У него нет атрибутов. изоляция драйвера принтера повышает надежность службы Windows печати, позволяя драйверам принтера выполняться в процессах, отделяющих от процесса, в котором работает диспетчер очереди печати. поддержка изоляции драйвера принтера запущена в Windows 7 и Windows Server 2008 R2. Приложение может объявить изоляцию драйвера принтера в своем манифесте приложения, чтобы изолировать себя от драйвера принтера и повысить его надежность. Это значит, что приложение не будет завершаться сбоем, если в драйвере принтера произошла ошибка.
ултрахигхресолутионскроллингаваре
Указывает, включено ли разрешение на прокрутку Ultra-High-resolution. Значение true указывает, что он включен. У него нет атрибутов.
Указывает сведения об удостоверении разреженного пакета MSIX для текущего приложения. этот элемент поддерживается в Windows 10, версии 2004 и более поздних версиях.
attribute | Описание |
---|---|
publisher | Описание сведений об издателе. это значение должно соответствовать атрибуту Publisher в элементе Identity манифеста разреженного пакета. |
PackageName | Описывает содержимое пакета. Это значение должно соответствовать атрибуту Name в элементе Identity манифеста разреженного пакета. |
applicationId | Уникальный идентификатор приложения. Это значение должно соответствовать атрибуту ID в элементе Application в манифесте разреженного пакета. |
хеаптипе
Файл манифеста AndroidManifest.xml
Файл манифеста AndroidManifest.xml предоставляет основную информацию о программе системе. Каждое приложение должно иметь свой файл AndroidManifest.xml. Редактировать файл манифеста можно вручную, изменяя XML-код или через визуальный редактор Manifest Editor (Редактор файла манифеста), который позволяет осуществлять визуальное и текстовое редактирование файла манифеста приложения.
Назначение файла
Общая структура манифеста
Файл манифеста инкапсулирует всю архитектуру Android-приложения, его функциональные возможности и конфигурацию. В процессе разработки приложения вам придется постоянно редактировать данный файл, изменяя его структуру и дополняя новыми элементами и атрибутами.
Описание
Элемент является корневым элементом манифеста. По умолчанию Eclipse создает элемент с четырьмя атрибутами:
Атрибуты
объявляет разрешение, которое используется для ограничения доступа к определенным компонентам или функциональности данного приложения. В этой секции описываются права, которые должны запросить другие приложения для получения доступа к вашему приложению. Приложение может также защитить свои собственные компоненты (деятельности, службы, приемники широковещательных намерений и контент-провайдеры) разрешениями. Оно может использовать любое из системных разрешений, определенных Android или объявленных другими приложениями, а также может определить свои собственные разрешения.
android:name название разрешения android:label имя разрешения, отображаемое пользователю android:description описание разрешения android:icon значок разрешения android:permissionGroup определяет принадлежность к группе разрешений android:protectionLevel уровень защиты
Элемент запрашивает разрешение, которые приложению должны быть предоставлены системой для его нормального функционирования. Разрешения предоставляются во время установки приложения, а не во время его работы.
android:name имеет единственный атрибут с именем разрешения android:name. Это может быть разрешение, определенное в элементе
данного приложения, разрешение, определенное в другом приложении или одно из стандартных системных разрешений, например: android:name=»android.permission.CAMERA» или android:name=»»android.permission.READ_CONTACTS»
Наиболее распространенные разрешения
объявляет базовое имя для дерева разрешений. Этот элемент объявляет не само разрешение, а только пространство имен, в которое могут быть помещены дальнейшие разрешения.
определяет имя для набора логически связанных разрешений. Это могут быть как объявленные в этом же манифесте с элементом
разрешения, так и объявленные в другом месте. Этот элемент не объявляет разрешение непосредственно, только категорию, в которую могут быть помещены разрешения. Разрешение можно поместить в группу, назначив имя группы в атрибуте permissionGroup элемента