.Net Core 2.0 Process.Start throws "The specified executable is not a valid application for this OS platform"
Asked Answered
E

6

114

I need to let a .reg file and a .msi file execute automatically using whatever executables these two file types associated with on user's Windows.

.NET Core 2.0 Process.Start(string fileName) docs says: "the file name does not need to represent an executable file. It can be of any file type for which the extension has been associated with an application installed on the system."

However

using(var proc = Process.Start(@"C:\Users\user2\Desktop\XXXX.reg")) { } //.msi also

gives me

System.ComponentModel.Win32Exception (0x80004005): The specified executable is not a valid application for this OS platform.
   at System.Diagnostics.Process.StartWithCreateProcess(ProcessStartInfo startInfo)
   at System.Diagnostics.Process.Start()
   at System.Diagnostics.Process.Start(ProcessStartInfo startInfo)
   at System.Diagnostics.Process.Start(String fileName)

with ErrorCode and HResult -2147467259, and NativeErrorCode 193.

The same code did work in .Net Framework 3.5 or 4 console app.

I can't specify exact exe file paths as the method's parameter since users' environments are variant (including Windows versions) and out of my control. That's also why I need to port the program to .Net Core, trying to make it work as SCD console app so that installation of specific .Net Framework or .NET Core version is not required.

The exception is thrown both in Visual Studio debugging run and when published as win-x86 SCD. My PC is Win7 64bit and I'm sure .reg and .msi are associated with regular programs as usual Windows PC does.

Is there solution for this? Any help is appreciated.

Eastward answered 18/10, 2017 at 10:42 Comment(0)
E
215

You can also set the UseShellExecute property of ProcessStartInfo to true

var p = new Process();
p.StartInfo = new ProcessStartInfo(@"C:\Users\user2\Desktop\XXXX.reg")
{ 
    UseShellExecute = true 
};
p.Start();

Seems to be a change in .net Core, as documented here.

See also breaking changes.

Eipper answered 2/11, 2017 at 1:32 Comment(4)
Changing UseShellExecute from false to true works for me :-)Rutland
See Microsoft breaking changes doc hereCrary
I was driving myself crazy wondering why calling Process.Start() on local HTML files didn't work even though everybody claimed it worked. This solves the issue.Uhl
This work for me, but why does it work with "Open width" ? The "OLD WAY" System.Diagnostics.Process.Start("rundll32.exe", "shell32.dll, OpenAs_RunDLL " + item.FileName);Dissect
G
56

You can set UseShellExecute to true and include this and your path in a ProcessStartInfo object:

Process.Start(new ProcessStartInfo(@"C:\Users\user2\Desktop\XXXX.reg") { UseShellExecute = true });
Gennie answered 22/7, 2019 at 13:18 Comment(2)
converted an app from net48 to netcoreapp3.1, "UseShellExecute = true" was needed on dotnetcore (running on windows)Moschatel
I used .msg file didn't open. i am getting this error "System.ComponentModel.Win32Exception: 'The system cannot find the file specified.' ".Deathless
R
25

In case this bothers you as well:

For those of us that are used to simply calling Process.Start(fileName); the above syntax may give us anxiety... So may I add that you can write it in a single line of code?

new Process { StartInfo = new ProcessStartInfo(fileName) { UseShellExecute = true } }.Start();
Resurrection answered 15/7, 2020 at 16:14 Comment(2)
This should be the accepted answer works greatHovis
I concur with @Hovis that this should be the accepted answer because this answer suppresses the command window while the accepted answer does not (and the command window displays while the application is open).Alec
B
20

You have to execute cmd.exe

var proc = Process.Start(@"cmd.exe ",@"/c C:\Users\user2\Desktop\XXXX.reg")

don't forget the /c

Bankhead answered 18/10, 2017 at 10:52 Comment(2)
This works, but keeps open a cmd window until de opened application is close. For example, if I want to open a doc file, the cmd window keeps opened until I close Word. It is better if use another solution with UseShellExecute.Matelda
This should not be the accepted answer. The use of ProcessStartInfo with UseShellExecute = true is better.Druce
K
0
            string itemseleccionado = lbdatos.SelectedItem.ToString();
            var p = new Process();
            p.StartInfo = new ProcessStartInfo(itemseleccionado)
            {
                UseShellExecute = true
            };
            p.Start();
Kutchins answered 12/8, 2022 at 17:47 Comment(2)
Remember that Stack Overflow isn't just intended to solve the immediate problem, but also to help future readers find solutions to similar problems, which requires understanding the underlying code. This is especially important for members of our community who are beginners, and not familiar with the syntax. Given that, can you edit your answer to include an explanation of what you're doing and why you believe it is the best approach?Brigitta
No explanation + anwser already given = downvoteSharlenesharline
I
-1

use this to open a file

new ProcessStartInfo(@"C:\Temp\1.txt").StartProcess();

need this extension method

public static class UT
{
    public static Process StartProcess(this ProcessStartInfo psi, bool useShellExecute = true)
    {
        psi.UseShellExecute = useShellExecute;
        return Process.Start(psi);
    }
}
Intersect answered 6/12, 2019 at 22:42 Comment(0)

© 2022 - 2024 — McMap. All rights reserved.