使用Sitecore Item Web API时如何检索Image字段的替代文字?

ben*_*ski 5 sitecore sitecore6 sitecore-media-library

使用Sitecore Item Web API返回具有Image字段的项时,Sitecore Item Web API将返回一个JSON响应,其中包含Value,即图像标记,但没有任何alt文本.有没有办法让Sitecore Item Web API返回引用的媒体库项目的详细信息?

示例图像字段类型来自Sitecore Item Web API的响应:

                "{7EEA5007-E518-4E68-837B-51BEAB56230A}": {
                "Name": "Image",
                "Type": "Image",
                "Value": "\u003cimage mediaid=\"{E1F8CD6F-8276-4967-983C-C37E1481CDC0}\" mediapath=\"/Images/Fragrances/Collections/M039_img4\" src=\"~/media/E1F8CD6F82764967983CC37E1481CDC0.ashx\" /\u003e"
            }
Run Code Online (Sandbox Code Playgroud)

看来我可以为GUID解析值,然后使用Sitecore的项Web API查询的媒体库中的影像项目和检索GUID,但是这将是混乱的,当父母有多个孩子,因为我将不得不要求ALT标签每个人分开.

Kie*_*ies 3

Sitecore Item Web API 引入了一些在Sitecore.ItemWebAPI.config

您正在寻找的关键管道是itemWebApiReadSitecore.ItemWebApi.Pipelines.Read.GetResult, Sitecore.ItemWebApi这引用了执行该方法的类型GetFieldInfo。此方法实际上设置响应中每个字段的返回值。

由于方法是virtual我们可以简单地编写我们自己的类,继承Sitecore.ItemWebApi.Pipelines.Read.GetResult并实现我们自己的GetFieldInfo方法

执行

using Sitecore.Data.Fields;

namespace WebApi
{
    public class GetResult: Sitecore.ItemWebApi.Pipelines.Read.GetResult
    {
        protected override Sitecore.ItemWebApi.Dynamic GetFieldInfo(Field field)
        {
            var fieldInfo = base.GetFieldInfo(field);
            
            if (field.TypeKey == "image")
            {
                var imageField = (ImageField) field;
                fieldInfo.Add("Alt", imageField.Alt);
            }

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

如您所见,我们需要做的就是检查field.TypeKey它是否是图像。如果是这样,我们将转换为 andImageField然后将属性值添加Alt到我们的fieldInfo对象中。

结果

"{4A0E7425-5927-42D6-9438-A17E875DE50A}": {
    "Name": "Image",
    "Type": "Image",
    "Value": "<image mediaid=\"{00065A73-4859-4CF3-9F51-4D01D39CAD75}\" mediapath=\"/Images/128\" src=\"~/media/00065A7348594CF39F514D01D39CAD75.ashx\" />",
    "Alt": "sitecore logo"
}
Run Code Online (Sandbox Code Playgroud)

如果您需要为其他字段类型添加进一步的自定义,您可以随时添加基于TypeKey.