在SenseNet设置中使用JSON数组

Eli*_*olt 5 json odata sensenet

如果在SenseNet设置对象中使用JSON数组,则无法通过OData API访问它们.

例如,请考虑以下SenseNet设置对象,Root/System/Settings/Portal.settings默认情况下安装该对象:

{
    ClientCacheHeaders: [
        { ContentType: "PreviewImage", MaxAge: 1 },
        { Extension: "jpeg", MaxAge: 604800 },
        { Extension: "gif", MaxAge: 604800 },
        { Extension: "jpg", MaxAge: 604800 },
        { Extension: "png", MaxAge: 604800 },
        { Extension: "swf", MaxAge: 604800 },
        { Extension: "css", MaxAge: 600 },
        { Extension: "js", MaxAge: 600 }
    ],
    UploadFileExtensions: {
        "jpg": "Image",
        "jpeg": "Image",
        "gif": "Image",
        "png": "Image",
        "bmp": "Image",
        "svg": "Image",
        "svgz": "Image",
        "tif": "Image",
        "tiff": "Image",
        "xaml": "WorkflowDefinition",
        "DefaultContentType": "File"
    },
    BinaryHandlerClientCacheMaxAge: 600,
    PermittedAppsWithoutOpenPermission: "Details"
}
Run Code Online (Sandbox Code Playgroud)

通过OData API查看此对象时,不包括ClientCacheHeaders字段:

{
    "d": {
        "UploadFileExtensions.jpg": "Image",
        "UploadFileExtensions.jpeg": "Image",
        "UploadFileExtensions.gif": "Image",
        "UploadFileExtensions.png": "Image",
        "UploadFileExtensions.bmp": "Image",
        "UploadFileExtensions.svg": "Image",
        "UploadFileExtensions.svgz": "Image",
        "UploadFileExtensions.tif": "Image",
        "UploadFileExtensions.tiff": "Image",
        "UploadFileExtensions.xaml": "WorkflowDefinition",
        "UploadFileExtensions.DefaultContentType": "File",
        "BinaryHandlerClientCacheMaxAge": 600,
        "PermittedAppsWithoutOpenPermission": "Details",
    }
}
Run Code Online (Sandbox Code Playgroud)

如果使用以下查询专门搜索ClientCacheHeaders字段:

Odata.svc/Root/System/Settings('Portal.settings')?&metadata=no&$select=ClientCacheHeaders
Run Code Online (Sandbox Code Playgroud)

API返回null:

{
    "d": {
        "ClientCacheHeaders": null
    }
}
Run Code Online (Sandbox Code Playgroud)

我知道设置文件中允许使用JSON数组,因为上面的示例在描述设置用法的SenseNet wiki页面中引用.

我是否错误地执行了我的OData查询,或者这是SenseNet API中的某种解析错误?

Tha*_*mer 3

以下是 Miklos 建议的自定义 OData 函数的实现。完成此操作后,您必须按照此处所述注册 OData 调用。

public static class OData
{
    [ODataFunction]
    public static string GetMySettings(Content content)
    {
        var retstr = "";
        try
        {
            var settingsFile = Settings.GetSettingsByName<Settings>("MySettings", content.Path);
            var node = Node.LoadNode(settingsFile.Path) as Settings;
            var bindata = node.GetBinary("Binary");

            using (var sr = bindata.GetStream())
            using (var tr = new System.IO.StreamReader(sr))
                retstr = tr.ReadToEnd();
        }
        catch (Exception e)
        {
            SnLog.WriteException(e);
        }

        return retstr; 
    }
}
Run Code Online (Sandbox Code Playgroud)