.Net Core 应用程序无法将文件写入任何 OSX 文件夹

You*_*end 4 .net c# macos asp.net-core

我正在 OSX 中构建一个 .net core 2.0 应用程序,它是一个 WebAPI 应用程序,当 API 端点被命中时,它会创建一个带有虚拟数据的 .xlsx。当我尝试运行它(dotnet run)时,我得到

System.UnauthorizedAccessException: Access to the path '/Users/myuser/projects/myproject' is denied. ---> System.IO.IOException: Permission denied
Run Code Online (Sandbox Code Playgroud)

我尝试将它作为 sudo 运行并更改它正在写入的文件夹,但都没有帮助

// GET api/values/5
    [HttpGet("{id}")]
    public string Get(int id)
    {
        CreatePackage("./");
        return "value";
    }

    public void CreatePackage(string filePath)
    {
        using (SpreadsheetDocument package = SpreadsheetDocument.Create(filePath, SpreadsheetDocumentType.Workbook))
        {
            CreateParts(package);
        }
    }

    private void CreateParts(SpreadsheetDocument document)
    {
        WorkbookPart workbookPart = document.AddWorkbookPart();
        GenerateWorkbookPartContent(workbookPart);

        WorksheetPart worksheetPart = workbookPart.AddNewPart<WorksheetPart>("rId1");
        GenerateWorksheetPartContent(worksheetPart);
    }

    private void GenerateWorkbookPartContent(WorkbookPart workbookPart)
    {
        Workbook workbook = new Workbook();
        workbook.AddNamespaceDeclaration("r", "http://schemas.openxmlformats.org/officeDocument/2006/relationships");

        Sheets sheets = new Sheets();
        Sheet sheet = new Sheet() { Name = "Sheet", SheetId = (UInt32Value)1U, Id = "rId1" };
        sheets.Append(sheet);

        workbook.Append(sheets);
        workbookPart.Workbook = workbook;
    }

    private void GenerateWorksheetPartContent(WorksheetPart worksheetPart)
    {
        Worksheet worksheet = new Worksheet();
        SheetData sheetData = new SheetData();

        Row row = new Row();
        Cell cell = new Cell() { CellReference = "A1", DataType = CellValues.InlineString };
        InlineString inlineString = new InlineString();
        Text text = new Text();
        text.Text = "hello";
        inlineString.Append(text);
        cell.Append(inlineString);
        row.Append(cell);

        sheetData.Append(row);
        worksheet.Append(sheetData);
        worksheetPart.Worksheet = worksheet;
    }
Run Code Online (Sandbox Code Playgroud)

这是课程的主要部分,我正在项目文件夹中创建文件(目前)。我看到有关为 CLI 的所有文件授予读写权限的帖子,但这似乎并不理想。我还看到关于设置文件属性的内容,但这是 OpenXml 电子表格的创建方法,据我所知,它没有任何关于设置文件权限的内容(无论如何它都需要在文件夹中)

任何帮助将非常感激

You*_*end 5

我想通了,我发送的文件路径是文件夹路径而不是文件路径,问题已解决

[HttpGet("{id}")]
public string Get(int id)
{
    CreatePackage("./testfile.xlsx");
    return "value";
}
Run Code Online (Sandbox Code Playgroud)