web-dev-qa-db-ja.com

C#/ WPFアプリからマシンを再起動する

マシンを再起動するボタンをWPFアプリに配置したいのですが。このアプリは常にVistaで実行されています。

クイック検索で何も見つからなかったという事実は、これが思っていたよりも難しいかもしれないと思います...何かアイデアはありますか?ありがとう!

28
Josh Santangelo

これを試して:

System.Diagnostics.Process.Start("shutdown.exe", "-r -t 0");

これにより、Windowsに組み込まれたshutdownツールが起動し、リモートまたはローカルマシンをシャットダウンまたはログオフすることもできます。

ss64.com の完全なオプションのリストを次に示します。

構文
 
 SHUTDOWN [logoff_option] [/ m \\ Computer] [options] 
 
 logoff_option:
/i Display GUI(最初のオプションでなければなりません)
/lログオフします。これは、/ mまたは/ dオプションとともに使用することはできません
/sシャットダウン
/rシャットダウンして再起動します
/aシステムシャットダウンを中止します。
(タイムアウト期間)
/pタイムアウトや警告なしでローカルコンピュータの電源を切ります
(/ dを使用した場合のみ)
/hローカルコンピュータを休止状態にします(/を使用した場合のみ) f)
/eコンピューターの予期しないシャットダウンの理由を文書化します
 
オプション:
 
/m \\コンピューター:リモートコンピューター
 
/t:xxx:システムがシャットダウンするまでの時間(秒)。 
有効な範囲はxxx = 0-600秒です。 [default = 30] 
/c "Msg":オプションのシャットダウンメッセージ[最大127文字] 
 
/f:実行中のアプリケーションを強制的に閉じます。
これ開いているすべてのアプリケーションでファイルの保存を求めるプロンプトは表示されません。
そのため、保存されていないデータはすべて失われます!!! 
 
/du:xx:yy:ユーザーをリストしますシャットダウンの理由コード。 
/d P:xx:yy:シャットダウンのPLANNED理由コードをリストします。
 xxメジャー理由コード(0-255)を指定します
 yyマイナー理由コード( 0-65536)

Linux/UNIXスタイルのコマンドライン引数を渡す( '-'を使用)記号を使用していることに気付くでしょう。 Windowsでは、規則は「/」を使用しています。これは問題ではありません-プログラムは関係ありません。

58
Lucas Jones

ExitWindowsEx AP​​Iを使用できます。から pinvoke.net

[Flags]
public enum ExitWindows : uint
{
   // ONE of the following five:
   LogOff = 0x00,
   ShutDown = 0x01,
   Reboot = 0x02,
   PowerOff = 0x08,
   RestartApps = 0x40,
   // plus AT MOST ONE of the following two:
   Force = 0x04,
   ForceIfHung = 0x10,
}

[Flags]
enum ShutdownReason : uint
{
    MajorApplication = 0x00040000,
    MajorHardware = 0x00010000,
    MajorLegacyApi = 0x00070000,
    MajorOperatingSystem = 0x00020000,
    MajorOther = 0x00000000,
    MajorPower = 0x00060000,
    MajorSoftware = 0x00030000,
    MajorSystem = 0x00050000,

    MinorBlueScreen = 0x0000000F,
    MinorCordUnplugged = 0x0000000b,
    MinorDisk = 0x00000007,
    MinorEnvironment = 0x0000000c,
    MinorHardwareDriver = 0x0000000d,
    MinorHotfix = 0x00000011,
    MinorHung = 0x00000005,
    MinorInstallation = 0x00000002,
    MinorMaintenance = 0x00000001,
    MinorMMC = 0x00000019,
    MinorNetworkConnectivity = 0x00000014,
    MinorNetworkCard = 0x00000009,
    MinorOther = 0x00000000,
    MinorOtherDriver = 0x0000000e,
    MinorPowerSupply = 0x0000000a,
    MinorProcessor = 0x00000008,
    MinorReconfig = 0x00000004,
    MinorSecurity = 0x00000013,
    MinorSecurityFix = 0x00000012,
    MinorSecurityFixUninstall = 0x00000018,
    MinorServicePack = 0x00000010,
    MinorServicePackUninstall = 0x00000016,
    MinorTermSrv = 0x00000020,
    MinorUnstable = 0x00000006,
    MinorUpgrade = 0x00000003,
    MinorWMI = 0x00000015,

    FlagUserDefined = 0x40000000,
    FlagPlanned = 0x80000000
}

[DllImport("user32.dll", SetLastError = true)]
[return: MarshalAs(UnmanagedType.Bool)]
static extern bool ExitWindowsEx(ExitWindows uFlags, ShutdownReason dwReason);

そしてそれを使うには:

ExitWindowsEx(
  ExitWindows.Reboot,
  ShutdownReason.MajorOther | ShutdownReason.MinorOther | ShutdownReason.FlagPlanned
); 
21

別の方法は、WMIを使用することです(つまり、System.Management名前空間); Googleはこのコードのバリエーションを提示します-

  ManagementClass W32_OS = new ManagementClass("Win32_OperatingSystem")
  ManagementBaseObject inParams, outParams;
  int result;
  W32_OS.Scope.Options.EnablePrivileges = true;

  foreach(ManagementObject obj in W32_OS.GetInstances())
  {
    inParams = obj.GetMethodParameters("Win32Shutdown");
    inParams["Flags"] = 6; //ForcedReboot; -- fixed to restart rather than shutdown
    inParams["Reserved"] = 0;

    outParams = obj.InvokeMethod("Win32Shutdown", inParams, null)
    result = Convert.ToInt32(outParams["returnValue"]);
    if (result !=0) throw new Win32Exception(result);
  }
9
Steve Gilham