首页 > 解决方案 > ASP.NET Base64 图像源无法正确显示。

问题描述

我通过 Lambda 函数从 Azure 活动目录获取 Base64 字符串。这代表用户的个人资料图片。然后我试图在 ASP.NET 页面中显示它。它不工作。

这是 ASP.NET(引用的 HTML 对象是 ASP 文字)

            using (var client = new AmazonLambdaClient(Amazon.RegionEndpoint.APSoutheast2))
            {
                var request = new InvokeRequest
                {
                    FunctionName = ConfigurationManager.AppSettings["lambdaArnPrefix"] + "lambda-wlyw-GetAzureAdUserThumbnail",
                    Payload = "\"" + Context.User.Identity.Name.ToString() + "\"",
                    InvocationType = InvocationType.RequestResponse

                };
                var response = client.Invoke(request);

                string result;
                using (var sr = new StreamReader(response.Payload))
                {
                    result = sr.ReadToEnd();
                }

                dynamic userThumbnail = JsonConvert.DeserializeObject(result);
                photo.Text = "<img src='data:image/jpg;base64," + userThumbnail.base64Image + "' width='100' height='100'/>";

但是,该页面显示损坏的图像图标。如果我查看源代码,我觉得还可以吗?如果我使用在线转换器,base64 字符串会解码为图像:

  <div class="panel-group">
                                            <div class="panel panel-primary">
                                                <div class="panel-heading">James Matson - Excellence<i class="fa fa-certificate pull-right"></i></div>
                                                <img src='' width='100' height='100'/>

标签: htmlasp.netimagebase64

解决方案


找出问题所在 - 向所有人道歉。事实证明,我的缓存凭据不存在,这意味着从 Lambda 函数返回的 Base64 字符串实际上不是图像,而是来自 Azure AD 的错误代码,即:

{"odata.error":{"code":"Request_ResourceNotFound","message":{"lang":"en","value":"Resource 'thumbnailPhoto' does not exist or one of its queried reference-property objects are not present."}}}

一旦我正确登录,图像就会工作 - 所以如果有人想要一个如何实现这一点的工作示例,请使用上面的:)


推荐阅读