Как настроить параметры по умолчанию при развертывании Google Chrome для бизнеса?
Я хочу иметь возможность развертывать Google Chrome для бизнеса в своей организации без создания дополнительных ярлыков и без подсказок при первом запуске. Установщик Chrome для бизнеса - это файл установщика Windows (MSI), но это всего лишь оболочка для исполняемого установщика. У него нет таких свойств, как CreateDesktopShortcut, которые можно установить в командной строке msiexec, как это делают многие установщики MSI. Как я могу настроить мою установку? Я бы предпочел не писать и поддерживать сценарий установки.
2 ответа
Google Chrome сохраняет настройки пользователя по умолчанию в файле master_preferences. Это текстовый файл в формате JSON, и он включает в себя distribution
объект, содержащий настройки, которые будут прочитаны во время установки. Редактирование этого файла в существующей установке Chrome не решает проблему, потому что установка, очевидно, уже произошла в этот момент. Решение заключается в интеграции настраиваемого файла master_preferences в процесс установки установщика Windows с помощью файла преобразования. Для этого сделайте следующее.
Соберите необходимые установщики и инструменты
- Установщик Google Chrome для бизнеса.
Я скачаю 64-битную версию дляE:\Chrome for Business 38 (64-bit)
, - Microsoft Windows Software Development Kit (SDK) для Windows 8.1.
Я скачаю этоE:\WindowsSDK8.1
, - Установите Windows SDK:
E:\WindowsSDK8.1.\sdksetup.exe
, - Установите Orca (редактор базы данных установщика Windows):
msiexec /package "C:\Program Files (x86)\Windows Kits\8.1\bin\x86\Orca-x86_en-us.msi"
,
Напишите настроенный файл master_preferences
- Просмотрите доступные параметры распространения. Это свойства
distribution
объект, который содержится в анонимном объекте в файле master_preferences. Следующий список настроек был скомпилирован путем объединения двух исходных файлов Chromium: master_preferences_constants.h и master_preferences_constants.cc в / trunk / src / chrome / installer / util /. Обратите внимание, что следующее не является допустимым JSON, потому что для свойств не указаны значения. Пример показан ниже.
{
"distribution" : {
// All the preferences below are expected to be inside the JSON "distribution"
// block (as shown here). Some of them also have equivalent command line option.
// If same option is specified in master preference as well as command line,
// the command line value takes precedence.
// Boolean. Use alternate text for the shortcut. Cmd line override present.
"alternate_shortcut_text"
// Boolean. Whether to instruct the installer to auto-launch chrome on computer
// startup. The default (if not provided) is |false|.
"auto_launch_chrome"
// Boolean. This is to be a Chrome install. (When using MultiInstall)
"chrome"
// Boolean. This is to be a Chrome App Host install.
"app_host" // TODO(huangs): Remove by M27.
// Boolean. This is to be a Chrome App Launcher install.
"app_launcher"
// Integer. Icon index from chrome.exe to use for shortcuts.
"chrome_shortcut_icon_index"
// Boolean. This is a legacy preference and should no longer be used; it is
// kept around so that old master_preferences which specify
// "create_all_shortcuts":false still enforce the new
// "do_not_create_(desktop|quick_launch)_shortcut" preferences. Setting this to
// true no longer has any impact.
"create_all_shortcuts"
// Boolean pref that disables all logging.
"disable_logging"
// Name of the dictionary that holds the distribution values.
"distribution"
// Boolean pref that triggers silent import of the default browser bookmarks.
"import_bookmarks"
// String pref that triggers silent import of bookmarks from the html file at
// given path.
"import_bookmarks_from_file"
// Boolean pref that triggers silent import of the default browser history.
"import_history"
// Boolean pref that triggers silent import of the default browser homepage.
"import_home_page"
// Boolean pref that triggers silent import of the default search engine.
"import_search_engine"
// Integer. RLZ ping delay in seconds.
"ping_delay"
// String of Chrome version for which the "set as default browser" infobar will
// never be shown.
"suppress_default_browser_prompt_for_version"
// Boolean. Do not show first run bubble, even if it would otherwise be shown.
"suppress_first_run_bubble"
// Boolean. Prevent creation of all shortcuts to chrome, including the
// desktop, quick launch, taskbar and the start menu shortcuts.
"do_not_create_any_shortcuts"
// Boolean. Prevent creation of the Desktop shortcut on install (and later on
// Active Setup for each user on a system-level install).
"do_not_create_desktop_shortcut"
// Boolean. Prevent creation of the Quick Launch shortcut on install (and later
// on Active Setup for each user on a system-level install).
"do_not_create_quick_launch_shortcut"
// Boolean. Prevent creation of the Taskbar (since Windows 7) shortcut on
// install (and later on Active Setup for each user on a system-level install).
"do_not_create_taskbar_shortcut"
// Boolean. Do not launch Chrome after first install. Cmd line override present.
"do_not_launch_chrome"
// Boolean. Do not register with Google Update to have Chrome launched after
// install. Cmd line override present.
"do_not_register_for_update_launch"
// String. Specifies the file path to write logging info to.
"log_file"
// Boolean. Register Chrome as default browser. Cmd line override present.
"make_chrome_default"
// Boolean. Register Chrome as default browser for the current user.
"make_chrome_default_for_user"
// Boolean. Expect to be run by an MSI installer. Cmd line override present.
"msi"
// Boolean. Support installing multiple products at once.
"multi_install"
// Boolean. Show EULA dialog before install.
"require_eula"
// Boolean. Indicates that the first-run 'set-as-default' dialog should not be
// shown. Relevant in Windows 8+ context only. If this is true, the standard
// 'set default browser' prompt on the butter-bar will appear during the first
// run.
"suppress_first_run_default_browser_prompt"
// Boolean. Install Chrome to system wise location. Cmd line override present.
"system_level"
// Boolean. Run installer in verbose mode. Cmd line override present.
"verbose_logging"
// Name of the block that contains the extensions on the master preferences.
"extensions.settings"
}
}
- Просмотрите доступные параметры нераспространения. Эти настройки выходят за пределы
distribution
Объект в формате JSON. Они применяются к профилю пользователя, когда пользователь запускает Chrome впервые. Полный список настроек доступен в исходных файлах Chromium pref_names.h и pref_names.cc в / trunk / src / chrome / common /. Список довольно длинный, поэтому здесь отображается только подмножество.
{
// *************** PROFILE PREFS ***************
// These are attached to the user profile
// A string property indicating whether default apps should be installed
// in this profile. Use the value "install" to enable defaults apps, or
// "noinstall" to disable them. This property is usually set in the
// master_preferences and copied into the profile preferences on first run.
// Defaults apps are installed only when creating a new profile.
"default_apps"
// If set to true profiles are created in ephemeral mode and do not store their
// data in the profile folder on disk but only in memory.
"profile.ephemeral_mode"
// A boolean specifying whether the New Tab page is the home page or not.
"homepage_is_newtabpage"
// This is the URL of the page to load when opening new tabs.
"homepage"
// An integer pref. Holds one of several values:
// 0: (deprecated) open the homepage on startup.
// 1: restore the last session.
// 2: this was used to indicate a specific session should be restored. It is
// no longer used, but saved to avoid conflict with old preferences.
// 3: unused, previously indicated the user wants to restore a saved session.
// 4: restore the URLs defined in kURLsToRestoreOnStartup.
// 5: open the New Tab Page on startup.
"session.restore_on_startup"
// The URLs to restore on startup or when the home button is pressed. The URLs
// are only restored on startup if kRestoreOnStartup is 4.
"session.startup_urls"
// Boolean that is true when SafeBrowsing is enabled.
"safebrowsing.enabled"
// Boolean that tell us whether malicious download feedback is enabled.
"safebrowsing.extended_reporting_enabled"
/* Might be useful for highly-secure workstations. */
// Enum that specifies whether Incognito mode is:
// 0 - Enabled. Default behaviour. Default mode is available on demand.
// 1 - Disabled. Used cannot browse pages in Incognito mode.
// 2 - Forced. All pages/sessions are forced into Incognito.
"incognito.mode_availability"
// Boolean that is true when Suggest support is enabled.
"search.suggest_enabled"
// A boolean pref set to true if a Home button to open the Home pages should be
// visible on the toolbar.
"browser.show_home_button"
// Boolean that indicates whether we should check if we are the default browser
// on start-up.
"browser.check_default_browser"
// Policy setting whether default browser check should be disabled and default
// browser registration should take place.
"browser.default_browser_setting_enabled"
// Boolean that specifies whether to import bookmarks from the default browser
// on first run.
"import_bookmarks"
// Boolean that specifies whether to import the browsing history from the
// default browser on first run.
"import_history"
// Boolean that specifies whether to import the homepage from the default
// browser on first run.
"import_home_page"
// Boolean that specifies whether to import the search engine from the default
// browser on first run.
"import_search_engine"
// Boolean that specifies whether to import the saved passwords from the default
// browser on first run.
"import_saved_passwords"
// Boolean that specifies if the sign in promo is allowed to show on first run.
// This preference is specified in the master preference file to suppress the
// sign in promo for some installations.
"sync_promo.show_on_first_run_allowed"
// *************** LOCAL STATE ***************
// These are attached to the machine/installation
// Note: Both settings included below are for Windows only.
// Whether downloaded PDFs should be opened in Adobe Acrobat Reader.
"download.open_pdf_in_adobe_reader"
// Preference to be used while relaunching Chrome. This preference dictates if
// Chrome should be launched in Metro or Desktop mode.
// For more info take a look at ChromeRelaunchMode enum.
"relaunch.mode"
// Boolean that specifies if the sign in promo is allowed to show on first run.
// This preference is specified in the master preference file to suppress the
// sign in promo for some installations.
"sync_promo.show_on_first_run_allowed";
// Boolean that specifies if we should show a bubble in the new tab page.
// The bubble is used to confirm that the user is signed into sync.
"sync_promo.show_ntp_bubble";
// As part of the master preferences an optional section indicates the tabs
// to open during first run. An example is the following:
"first_run_tabs": [
"http://google.com/f1",
"https://google.com/f2"
]
// Note that the entries are usually urls but they don't have to be.
- Выберите нужные настройки и напишите свой собственный текстовый файл master_preferences. Вот тот, который встроен в файл установщика Windows (для удобства чтения расширен до нескольких строк):
{
"distribution" :
{
"msi" : true,
"system_level" : true,
"verbose_logging" : true
}
}
Вы должны включить все эти свойства, как показано в вашем файле master_preferences, чтобы установщик работал правильно. Поэтому вы должны начать с этого и добавить к нему. Мой файл показан ниже. Единственный способ остановить Chrome от запроса пользователя на настройку учетной записи Google - это настроить first_run_tabs
имущество.
{
"browser" : {
"check_default_browser" : false
},
"distribution" : {
"import_bookmarks" : false,
"import_history" : false,
"import_home_page" : false,
"import_search_engine" : false,
"suppress_first_run_bubble" : true,
"do_not_create_desktop_shortcut" : true,
"do_not_create_quick_launch_shortcut" : true,
"do_not_create_taskbar_shortcut" : true,
"do_not_launch_chrome" : true,
"do_not_register_for_update_launch" : true,
"make_chrome_default" : false,
"make_chrome_default_for_user" : false,
"msi" : true,
"require_eula" : false,
"suppress_first_run_default_browser_prompt" : true,
"system_level" : true,
"verbose_logging" : true
},
"first_run_tabs" : [
"chrome://newtab"
],
"homepage" : "chrome://newtab",
"homepage_is_newtabpage" : true,
"sync_promo" : {
"show_on_first_run_allowed" : false
}
}
Перейдите по http://jslint.com/, скопируйте JSON в поле "Источник" и нажмите кнопку "JSLint". Это подтвердит, что у вас есть хороший JSON. Это важно, потому что подача искаженного JSON в установщик приведет к неожиданным и / или нежелательным результатам. Сохраните проверенный файл для дальнейшего использования.
Сделайте копию своего проверенного JSON и удалите все пробелы и новые строки. Установщик Chrome не может обрабатывать переводы строк; включение новых строк приведет к поврежденной установке, которая должна быть удалена с помощью операции реестра и ручного удаления файлов. Удаление пробелов может не потребоваться, но это соответствует тому, что авторы установки сделали со стандартным JSON. Мой показан ниже.
{"browser":{"check_default_browser":false},"distribution":{"import_bookmarks":false,"import_history":false,"import_home_page":false,"import_search_engine":false,"suppress_first_run_bubble":true,"do_not_create_desktop_shortcut":true,"do_not_create_quick_launch_shortcut":true,"do_not_create_taskbar_shortcut":true,"do_not_launch_chrome":true,"do_not_register_for_update_launch":true,"make_chrome_default":false,"make_chrome_default_for_user":false,"msi":true,"require_eula":false,"suppress_first_run_default_browser_prompt":true,"system_level":true,"verbose_logging":true},"first_run_tabs":["chrome://newtab"],"homepage":"chrome://newtab","homepage_is_newtabpage":true,"sync_promo":{"show_on_first_run_allowed":false}}
Запустите новый JSON без пробелов через JSLint, чтобы убедиться, что вы не допустили ошибок.
Скопируйте проверенный JSON без пробелов и символов новой строки в кодировщик URL. Я использовал URL Encode / Decode Online. Сохраните закодированный JSON для использования в установщике и для дальнейшего использования. Мой кодированный JSON показан ниже.
%7B%22browser%22%3A%7B%22check_default_browser%22%3Afalse%7D%2C%22distribution%22%3A%7B%22import_bookmarks%22%3Afalse%2C%22import_history%22%3Afalse%2C%22import_home_page%22%3Afalse%2C%22import_search_engine%22%3Afalse%2C%22suppress_first_run_bubble%22%3Atrue%2C%22do_not_create_desktop_shortcut%22%3Atrue%2C%22do_not_create_quick_launch_shortcut%22%3Atrue%2C%22do_not_create_taskbar_shortcut%22%3Atrue%2C%22do_not_launch_chrome%22%3Atrue%2C%22do_not_register_for_update_launch%22%3Atrue%2C%22make_chrome_default%22%3Afalse%2C%22make_chrome_default_for_user%22%3Afalse%2C%22msi%22%3Atrue%2C%22require_eula%22%3Afalse%2C%22suppress_first_run_default_browser_prompt%22%3Atrue%2C%22system_level%22%3Atrue%2C%22verbose_logging%22%3Atrue%7D%2C%22first_run_tabs%22%3A%5B%22chrome%3A%2F%2Fnewtab%22%5D%2C%22homepage%22%3A%22chrome%3A%2F%2Fnewtab%22%2C%22homepage_is_newtabpage%22%3Atrue%2C%22sync_promo%22%3A%7B%22show_on_first_run_allowed%22%3Afalse%7D%7D
Написать преобразование установщика Windows
- Запустите Orca.
- Откройте загруженный файл Chrome для бизнеса MSI только для чтения. (Полагаю, вы могли бы отредактировать фактический файл, но мне нравится использовать преобразования, поэтому у меня всегда есть предоставленный поставщиком файл в качестве базового, если что-то пойдет не так.) Я загрузил 64-разрядную версию Chrome для бизнеса, и имя файла было
googlechromestandaloneenterprise64.msi
, - В меню " Преобразование" выберите " Новое преобразование". Теперь все таблицы базы данных установщика Windows доступны для редактирования, поскольку вы редактируете новый файл преобразования.
- Выберите таблицу свойств.
- Щелкните правой кнопкой мыши в столбце "Свойства" и нажмите "Добавить строку". Установите свойство в
MASTER_PREFERENCES
и установите значение для вашего JSON в кодировке URL. Этот код будет применен во время развертывания и сохранен как установочныйmaster_preferences
файл установщиком. - Выберите таблицу CustomAction и найдите действие BuildInstallCommand.
- Дважды щелкните ячейку Target для действия BuildInstallCommand, чтобы сделать его редактируемым.
- В конце текста удалите существующий закодированный JSON, следуя
installerdata=
и замените его новым именем свойства в скобках. Обязательно сохраните заключительную кавычку. Это должно выглядеть так:installerdata=[MASTER_PREFERENCES]"
- Нажмите Enter, чтобы закончить редактирование ячейки.
- В меню " Преобразование" выберите " Создать преобразование…" и сохраните новый файл MST. Я спас мой как
E:\Chrome for Business 38 (64-bit)\MasterPreferences.mst
, - Выход Орка.
Примечание. Необходимо использовать свойство, а не вставлять JSON непосредственно в настраиваемое действие, поскольку поле "Цель настраиваемого действия" имеет длину всего 255 символов. Схема этой таблицы не может быть изменена, и в большинстве пользовательских JSON общая длина этого поля будет превышать ограничение. Использование свойства позволяет избежать ограничения длины, поскольку практического ограничения длины значения свойства не существует.
Установите Chrome с вашей трансформацией
- Откройте окно командной строки с правами администратора.
- Установите Google Chrome с вашим преобразованием, установив
TRANSFORMS
Свойство к его имени файла. Включите ведение журнала, чтобы помочь вам найти что-то не так. Используя мои примеры папок и предполагая, что вы вошли в систему как администратор:msiexec /package "E:\Chrome for Business 38 (64-bit)\googlechromestandaloneenterprise64.msi" TRANSFORMS="E:\Chrome for Business 38 (64-bit)\MasterPreferences.mst" /l*v "C:\Users\Administrator\Desktop\ChromeInstallationLog.txt"
- Если Chrome устанавливается без ошибок, попробуйте запустить его как другой пользователь без прав администратора, чтобы убедиться, что параметры распространяются правильно.
- Наконец, настройте систему развертывания с помощью установщика и файла преобразования. Я использую System Center Configuration Manager 2012 R2. Моя командная строка для этого приложения похожа на следующее:
msiexec /package "googlechromestandaloneenterprise64.msi" /quiet TRANSFORMS="MasterPreferences.mst" /l*v "%TEMP%\ChromeInstallationLog.txt"
Это дает моим пользователям возможность работы в магазине приложений с приложением Центр программного обеспечения Configuration Manager, оставляет управление значками на рабочем столе и панели задач исключительно для пользователя и позволяет избежать раздражающих действий при первом запуске. Обычно это мой предпочтительный пользовательский опыт, но он особенно полезен для общедоступных компьютеров, например, в компьютерном классе, где изменения жесткого диска теряются при каждом перезапуске, и поэтому каждый вход в систему является "первым" входом в систему.
Заметки
См. Также документацию Google по файлу master_preferences, который охватывает подмножество доступных настроек, но не рассказывает, как перенести настройки на машину во время установки.
Спасибо grt@chromium.org за указание на возможность настройки MSI. Моя цель состояла в том, чтобы расширить эту информацию, чтобы предоставить исчерпывающее объяснение и пример решения. Я надеюсь, что это полезно.
У меня недостаточно репутации, чтобы оставить комментарий. Я использовал руководство Джея, чтобы решить проблему с автоматическим запуском загруженного файла. И это единственный способ сделать это на данный момент:
https://bugs.chromium.org/p/chromium/issues/detail?id=476668
-Эта ссылка ссылается на ошибку, которая AFAIK не исправлена. Репортер хотел бы иметь возможность устанавливать определенные типы файлов для автоматического запуска на д / л через объект групповой политики. Вариант использования для этого ограничен, учитывая последствия для безопасности, но иногда необходим в корпоративных развертываниях. Это может быть достигнуто с помощью техники Джея в.mst с master_preferences. (редактировать в ответ на комментарий Чика)
Я согласен с тобой, Томтом, должен быть более легкий путь. По большей части.admx от Google достаточно.