My application uses the .NET object Directory.GetFiles()
The actual overload I’m using is
var allFiles = Directory.GetFiles("C:\\Users\\Dave", "*.*", SearchOption.AllDirectories);
The issue is when the source folder is C:\Users\UserName as it then tries to look through application data folder.
When it tries to read from the application data folder, an exception is thrown:
“Access to the path ‘C:\Users\Dave\AppData\Local\Application
Data’ is denied.”
So, my question is does any one have an opinion as to my options? I would assume I have to either change the way I collect all the files or, there may be a built in overload or method which will allow me to continue this (which I clearly don’t know about).
If it helps, the goal of this is to take all the files retrieved by Directory.GetFiles() and ‘paste’ them else where (a glorified copy and paste/back up). I’m actually not too worried about system files, just ‘user files’.
The directory
%AppData%is a system-protected directory. Windows will try to block any access to this directory as soon as the access was not authorized (An access from another user than the Administrator).Only the Administrator by default has privileges to read and write from/to this directory.
Alternatively, you can catch the exception and see if the result is
Access Denied. Then, you may prompt the user to run as an Administrator to complete this step. Here’s a simple example to prompt the user to run as AdministratorHowever, you may always prompt the user to authorize when your application launches which is NOT always RECOMMENDED. To do this, you’ll have to edit your project
app.manifestfileLocate and change the following line
to
Thanks,
I hope you find this helpful 🙂