こんにちは!小林です!
企業や教育機関で使用されるデバイスの管理は、IT管理者にとって大きな課題です。特に、ブラウザのセキュリティ更新を確実に行うことは、サイバーセキュリティの観点から非常に重要です。
この記事では、Microsoft Intuneを使用して、Zoomを自動更新する方法について解説します。これにより、IT管理者は手動での更新作業から解放され、セキュリティリスクを最小限に抑えることができます。具体的な設定手順や注意点を含めて、初心者でも簡単に実践できるように説明していきますので、ぜひ最後までご覧ください。
data:image/s3,"s3://crabby-images/9850b/9850b7a715b47be77534843902cc106338680910" alt=""
目次
1.スクリプトの作成
今回はスクリプトを使いMicrosoft Intuneでアプリを配布する設定を行います。この記事で追加するアプリはZoomになります。
※使用するスクリプトは指定されたアプリをインストールまたはアンインストールするためのPowerShellスクリプトです。
1.スクリプトの保存
メモ帳を開き下記スクリプトをコピー&ペーストします。
スクリプトの解説につきましては、5.スクリプトの解説をご覧ください。
data:image/s3,"s3://crabby-images/0b231/0b2318019482caa371d824529654f502d30a031a" alt=""
param(
[string]$appName = "",
[string]$downloadUrl = "",
[switch]$remove = $false,
[switch]$debugMode = $false
)
if (!$debugMode){
$ProgressPreference = "SilentlyContinue"
}
if ($appName -eq "") {
exit 1
}
#アンインストール処理
if ($remove)
{
$productId32 = (Get-ChildItem -Path "Registry::HKLM\SOFTWARE\Microsoft\Windows\CurrentVersion\Uninstall" | Get-ItemProperty | Where-Object DisplayName -eq $appName | Select-Object -ExpandProperty PSChildName)
$productId64 = (Get-ChildItem -Path "Registry::HKLM\SOFTWARE\WOW6432Node\Microsoft\Windows\CurrentVersion\Uninstall" | Get-ItemProperty | Where-Object DisplayName -eq $appName | Select-Object -ExpandProperty PSChildName)
if ($productId32 -eq "" -and $productId64 -eq ""){
exit 1
}
$productId = ""
if (!($productId32 -ne "" -or $productId64 -ne "")){
$productId = $productId64
}else{
$productId = (echo $productId32$productId64)
}
Start-Process -NoNewWindow -PassThru -Wait -FilePath "msiexec" -ArgumentList "/x", $productId, "/qn"
Start-Sleep -Seconds 30
exit 0
}
if ($downloadUrl -eq "") {
exit 1
}
$appLabel = $appName.replace(" ","")
$installerFile = "$appLabel.msi"
Invoke-WebRequest -UseBasicParsing -Uri $downloadUrl -OutFile $installerFile
Start-Process -NoNewWindow -PassThru -Wait -FilePath "msiexec" -ArgumentList "/i", $installerFile, "/qn"
Start-Sleep -Seconds 30
exit 0
2.「ファイル」をクリックし、「名前を付けて保存」をクリックします。
data:image/s3,"s3://crabby-images/a952b/a952b8c746416dc3bef4828a8ae8910049b9aadd" alt=""
3.下記のように保存します。
—————————————ーーーーーーーーーーーーーーーーーーーー
保存先:任意
ファイル名:任意(ここでは「install_zoom.ps1」と入力します。)
ファイルの種類:任意(ここでは「テキスト ドキュメント」と指定します。)
———————————ーーーーーーーーーーーーーーーーーーーーーー
data:image/s3,"s3://crabby-images/b6ed0/b6ed045ad84e558b4928ad9aee57c00e6dc9fabc" alt=""
4.保存したファイルの形式を.intunewin形式に変換します。
変換方法は下記ブログをご参照ください。
・Microsoft Intuneでアプリをリモートインストールする方法 その1 exeバージョン | yjk365
5. intunewin形式に変換できました。
data:image/s3,"s3://crabby-images/82e2c/82e2cb08e4bd4e5e962b6b1560561b6a3da939b5" alt=""
2.スクリプト配布
Microsoft Intuneを使い、インストールしたいアプリを追加します。
1.Microsoft Intune 管理センターを開き、「アプリ」をクリックします。
data:image/s3,"s3://crabby-images/c41e9/c41e9839fc720af4871d7f9d14a3842be1777bce" alt=""
2.「Windows」をクリックします。
data:image/s3,"s3://crabby-images/9a203/9a203990ace1dab6fd734ae5899d6423122676d9" alt=""
3.「追加」をクリックします。
data:image/s3,"s3://crabby-images/eef68/eef68b3044b31aea7b2ffac57de35b65be8ab12e" alt=""
4.「アプリの種類」のプルダウンより「Windows アプリ(Win 32)」を選択し、「選択」をクリックします。
data:image/s3,"s3://crabby-images/cba10/cba10279fc98f47a939bb296744b864eb192698f" alt=""
5.「アプリ パッケージ ファイルの選択」をクリックし、「アプリのパッケージ ファイル」より、1.スクリプトを作成で保存したファイルを選択し、「OK」をクリックします。
data:image/s3,"s3://crabby-images/6e02b/6e02b609f7330f3f6fbb96a4d2ed4b0a961d3dc8" alt=""
6.下記のように設定します。
—————————————ーーーーーーーーーーーーーーーーーーーーー
名前:任意
グループ名:任意(ここでは「install_zoom.ps1」と入力します。)
説明:任意(ここでは「install_zoom.ps1」と入力します。)
発行先:任意(ここでは「tkadmin」と入力します。)
—————————————ーーーーーーーーーーーーーーーーーーーーー
data:image/s3,"s3://crabby-images/6d959/6d959f98f5de685adc89ffc2b99fe3377ac8e472" alt=""
7.下記のように設定し、「次へ」をクリックします。
※コマンドを入力する理由につきましては4.課題点で詳しく解説しています。
—————————————ーーーーーーーーーーーーーーーーーーーーー
名前:任意
インストール コマンド:
powershell -ExecutionPolicy Bypass “.\install_zoom.ps1 ‘Zoom Workplace (64-bit)’ ‘https://zoom.us/client/latest/ZoomInstallerFull.msi?archType=x64′”
アンインストール コマンド:
powershell -ExecutionPolicy Bypass “.\install_zoom.ps1 ‘Zoom Workplace (64-bit)’ -uninstall”
インストールに必要な時間(分):10
—————————————ーーーーーーーーーーーーーーーーーーーーー
data:image/s3,"s3://crabby-images/66be2/66be2bf1c6bc74d59ba6cfc0e6f1168b7446b74a" alt=""
8.下記のように設定し、「次へ」をクリックします。
—————————————ーーーーーーーーーーーーーーーーーーーーー
名前:任意
オペレーティング システムのアーキテクチャ:任意(ここでは「64 ビット」と入力します。)
最小なオペレーティング システム:任意(ここでは「Windows 10 1607」と入力します。)
—————————————ーーーーーーーーーーーーーーーーーーーーー
data:image/s3,"s3://crabby-images/75513/75513721eba045fc9f5f5d6b1dcf7760ac29e90e" alt=""
9.「規則の形式」のプルダウンより、「検出規則を手動で構成する」を選択します。
data:image/s3,"s3://crabby-images/f25f7/f25f784be80a93826b4e5a9e60c39905d68606e2" alt=""
10.「追加」をクリックし、「検出規則」を下記のように設定し、「OK」をクリックします。
—————————————ーーーーーーーーーーーーーーーーーーーーー
規則の種類:ファイル
パス: C:\Program Files\Zoom\bin
ファイルまたはフォルダー: Zoom.exe
—————————————ーーーーーーーーーーーーーーーーーーーーー
data:image/s3,"s3://crabby-images/83e61/83e6129c14534cac99064a67df05a2cdf0a8e08f" alt=""
11.「次へ」をクリックします。
data:image/s3,"s3://crabby-images/718a7/718a7d9c4055069b06393116be45d7fbc06a088f" alt=""
12.「次へ」をクリックします。
data:image/s3,"s3://crabby-images/83ed4/83ed4906eaa6a5785475ecc7d78df83e0586398f" alt=""
13.「グループの追加」をクリックします。
data:image/s3,"s3://crabby-images/df094/df094ef77b80587927b43ada6bc0096f2422719a" alt=""
14.検索欄に追加したいグループにチェックを入れ、「選択」をクリックします。
data:image/s3,"s3://crabby-images/3e18d/3e18d4c0f69db28723e21a9171812d7655db9d44" alt=""
15 .「次へ」をクリックします。
data:image/s3,"s3://crabby-images/30c8c/30c8cc5af2e269663b62343f040f90fe0f307963" alt=""
16.内容を確認し、「作成」をクリックします。
data:image/s3,"s3://crabby-images/5db87/5db87d28e8f84b101090a306d408551715647d04" alt=""
17.スクリプトを使ってアプリケーションが作成されました。
data:image/s3,"s3://crabby-images/4df22/4df22bcd38138c63dfe4562be462e3723a7d6474" alt=""
18.追加したアプリ(Zoom)のアップロードも完了されました。
data:image/s3,"s3://crabby-images/d0caa/d0caaef8e8acf567e28994c76ffc122089a3f652" alt=""
Windows側からIntuneへ同期
Intune上でアプリを配布設定後、Windows側からIntuneへ同期する必要があります。下記が同期手順(Windows 11 ver.)になります。
1.「設定」を開き、「アカウント」をクリックし、「職場または、学校にアクセスする」をクリックします。
data:image/s3,"s3://crabby-images/9fec6/9fec6c2f2697cd43dd14d756c44fec423e2655e6" alt=""
2.接続済みアカウントのタブを開き、「情報」をクリックします。
data:image/s3,"s3://crabby-images/8e27e/8e27ecaebc2fecc234344dc37af04db1996edeb6" alt=""
3.「同期」をクリックします。
data:image/s3,"s3://crabby-images/5c356/5c3569040296df9a782c9bb2b93c50f6138460c0" alt=""
これにより同期が完了し、先ほど行った配布が反映されます。
同期してから反映にかかった時間 | 約20分 |
Windows 10 ver.はWindows10側からIntuneへ同期をすぐに実行する方法 | yjk365 をご参照ください。
3.配布状況の確認
同期後、反映されたか確認してみましょう。
必要ならば、再起動も実施してみてください。
ホーム画面にZoomがインストールされていました。
data:image/s3,"s3://crabby-images/11065/110650c5f3331be0bf99786e8cdfe821853cc7eb" alt=""
Microsoft Intune上でも確認できました。
data:image/s3,"s3://crabby-images/22fba/22fba75823e6c6f0b44c48caccc878364458699f" alt=""
4.課題点
2-7.でコマンドを入れる作業について少し言及します。
本来ならば、コマンドなしでもアプリの配布設定は可能です。
コマンドを入れた主な理由として、この記事の題名でもある 「アプリを自動でアップデート」に関係があります。 今回、使用したスクリプトはアプリの自動更新が出来ません。 なのでコマンド欄でアプリの各Install command、Uninstall commandを入力し配布することで自動更新の実現が可能になります。(※完全自動ではないのでアプリが更新するたびに都度、新しいURLを再入力、再配布の実施が必要です。)
Install command | powershell -ExecutionPolicy Bypass “.\{ps1ファイルを指定} ‘{正式アプリケーション名を指定}’ ‘{調べたURLを指定}'” |
Uninstall command | powershell -ExecutionPolicy Bypass “.\{ps1ファイルを指定} ‘{正式アプリケーション名を指定}’ -uninstall” |
install command, uninstall commandに必要な正式アプリケーション名と直接ダウンロードリンクの調べ方は下記ブログでご参考ください。
・正式アプリケーション名の調べ方と直接ダウンロードリンクの調べ方
5.スクリプトの解説
パラメータの定義
param( [string]$appName = "", [string]$downloadUrl = "", [switch]$remove = $false, [switch]$debugMode = $false )
- $appName: アプリケーションの名前を指定します。
- $downloadUrl: インストーラーのダウンロードURLを指定します。
- $remove: アンインストールを行うかどうかを示すスイッチです。
- $debugMode: デバッグモードを有効にするスイッチです。
デバッグモードの設定
if (!$debugMode){
$ProgressPreference = “SilentlyContinue”
}
- デバックモードが無効な場合、進行状況メッセージを抑制します。
アプリケーション名のチェック
if ($appName -eq “”) {
exit 1
}
アプリケーション名が指定されていない場合、スクリプトを終了します。
アンインストール処理
if ($remove)
{
$productId32 = (Get-ChildItem -Path “Registry::HKLM\SOFTWARE\Microsoft\Windows\CurrentVersion\Uninstall” | Get-ItemProperty | Where-Object DisplayName -eq $appName | Select-Object -ExpandProperty PSChildName)
$productId64 = (Get-ChildItem -Path “Registry::HKLM\SOFTWARE\WOW6432Node\Microsoft\Windows\CurrentVersion\Uninstall” | Get-ItemProperty | Where-Object DisplayName -eq $appName | Select-Object -ExpandProperty PSChildName)if ($productId32 -eq “” -and $productId64 -eq “”){
exit 1
}$productId = “”
if (!($productId32 -ne “” -or $productId64 -ne “”)){
$productId = $productId64
}else{
$productId = (echo $productId32$productId64)
}Start-Process -NoNewWindow -PassThru -Wait -FilePath “msiexec” -ArgumentList “/x”, $productId, “/qn”
Start-Sleep -Seconds 30
exit 0
}
- $remove: が指定されている場合、以下の処理を行います。
- レジストリから32ビットおよび64ビットの製品IDを取得します。
- 製品IDが見つからない場合、スクリプトを終了します。
- 両方の製品IDが見つかった場合、64ビットの製品IDを優先します。
- msiexec を使用してアプリケーションをサイレントモードでアンインストールします。
- アンインストールが完了するまで30秒間待機します。
インストール処理
if ($downloadUrl -eq “”) {
exit 1
}$appLabel = $appName.replace(” “,””)
$installerFile = “$appLabel.msi”Invoke-WebRequest -UseBasicParsing -Uri $downloadUrl -OutFile $installerFile
Start-Process -NoNewWindow -PassThru -Wait -FilePath “msiexec” -ArgumentList “/i”, $installerFile, “/qn”
Start-Sleep -Seconds 30
exit 0
- $downloadUrl が指定されていない場合、スクリプトを終了します。 これは、インストーラーをダウンロードするURLが指定されていないとインストールができないためです。
$downloadUrl が指定されている場合、以下の処理を行います。
- $appLabel: アプリケーション名のスペースを削除して
$installerFile: msi拡張子を付けたインストーラーファイル名を作成します。 - 指定されたURLからインストーラーをダウンロードします。
- msiexec を使用してアプリケーションをサイレントモードでインストールします。
- インストールが完了するまで30秒間待機します。
その他お困りごとも動画で解説!
data:image/s3,"s3://crabby-images/73146/73146eaf9fc827f1292d425702578ebe32dab2b8" alt=""