如何解决从UWP的Downloads文件夹中读取文件时,出现UnauthorizedAccessException
var path = @"C:\Users\Admin\Downloads\JsonData.json";
var rootObj = JsonConvert.DeserializeObject<Rootobject>(
File.ReadAllText(path)
);
当我在控制台应用程序上执行此操作时,一切正常,但是在uwp上,它将引发以下异常:
System.UnauthorizedAccessException: "Access to the path 'C:\Users\Admin\Downloads\JsonData.json' is denied."
解决方法
这里有两个问题,一个是安全性(与沙箱相关),另一个是更重要的,在UWP中,您需要使用Windows.Storage Namespace中的实用程序,对访问文件系统的支持已经被抽象化以支持不同的运行时环境,以促进运行时的容器化和沙箱化。
因此,即使正确设置了所有权限,代码也可以正常工作,但是您应该使用StorageFile
界面访问文件,因为这可以指导您编写更稳定,更稳定的代码与所有UWP运行时兼容。
忽略事物的安全性,您可以使用 Storage 实用程序访问相同的路径:
已阅读Create,write,and read a file
var path = @"C:\Users\Admin\Downloads\JsonData.json";
var folder = await Windows.Storage.StorageFolder.GetFolderFromPathAsync(System.IO.Path.GetDirectoryName(path));
var file = await folder.GetFileAsync(System.IO.Path.GetFileName(path));
var rootObj = JsonConvert.DeserializeObject<Rootobject>(
await Windows.Storage.FileIO.ReadTextAsync(file)
);
关于安全性和应用程序权限
Locations that UWP apps can access
默认情况下,通用Windows平台(UWP)应用程序可以访问某些文件系统位置。应用程序还可以通过文件选择器或声明功能来访问其他位置。默认情况下,您的应用只能访问应用创建的用户的“下载”文件夹中的文件和文件夹。但是,您可以通过调用文件选择器(FileOpenPicker或FolderPicker)来访问用户的“下载”文件夹中的文件和文件夹,以便用户可以导航和选择文件或文件夹以供您的应用访问。
文件选择器方法
文件选择器之所以起作用,是因为您的应用程序不直接访问任何特定的文件路径,而是用户可以浏览到用户有权访问的任何位置,并且在需要应用程序权限或特权时,将显示用户相关的用户界面提示供用户响应。选择器使用此信息来为您检索对文件的访问,而不必对上述所有代码进行编码。
var picker = new Windows.Storage.Pickers.FileOpenPicker();
picker.ViewMode = Windows.Storage.Pickers.PickerViewMode.Thumbnail;
picker.SuggestedStartLocation = Windows.Storage.Pickers.PickerLocationId.Downloads;
picker.FileTypeFilter.Add(".json");
Windows.Storage.StorageFile file = await picker.PickSingleFileAsync();
if (file != null)
{
var rootObj = JsonConvert.DeserializeObject<Rootobject>(
await Windows.Storage.FileIO.ReadTextAsync(file)
);
}
声明能力
UWP中的Downloads文件夹本身就是特殊的界面,如上所列。默认情况下,您的应用只能访问您在应用中创建的用户的Downloads文件夹中的文件和文件夹。当我们需要专门与用户的下载文件夹进行交互时,请使用DownloadsFolder Class。
- 当您的应用在该文件夹中创建文件时,此概念非常有用,并且您希望用户能够访问应用程序域之外的文件,并且可以轻松访问它们。
这篇文章值得一读:UWP access denied
访问此文件夹的简单方法是启用BroadFileSystemAccess,但是某些用户的安全策略可能不允许执行具有这种级别的文件系统访问权限的应用程序。
基于这个原因,我强烈建议 反对 即使在开发环境中也要使用它,您会变得自满(读 Lazy ),不会为在发布之前可能需要对代码进行的其他基本更改做准备。
这还将使批准程序复杂化,从而使您的应用可以通过商店...
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。