Jér*_*VEL 8 c# base64 image asp.net-core asp.net-core-webapi
我正在尝试从API控制器返回表示jpeg图像的base64字符串,并将其设置为src,<img>
但我的所有尝试都失败了.
这是非常简单的HTML:
<img src="/api/TestBase64Image" alt="image test" />
Run Code Online (Sandbox Code Playgroud)
而我的控制器:
[Route("api/[controller]")]
public class TestBase64ImageController : Controller
{
private const string _base64Image = "data:image/jpeg;base64,/9j/4AAQSkZJRgABAQEBLAEsAAD/7Sfg.....";
private const string _base64Image2 = "/9j/4AAQSkZJRgABAQEBLAEsAAD/7Sfg.....
[HttpGet]
public async Task Get()
{
Response.ContentType = "image/jpeg";
//Response.ContentType = "text/plain";
//Response.ContentType = new MediaTypeHeaderValue("image/jpeg").ToString();
//Response.ContentType = new MediaTypeHeaderValue("text/plain").ToString();
//Response.Headers.Add("Content-Length", _base64Image.Length.ToString());
//HttpContext.Response.ContentLength = _base64Image.Length;
await Response.Body.WriteAsync(Encoding.UTF8.GetBytes(_base64Image), 0, _base64Image.Length);
//await Response.Body.FlushAsync();
}
}
Run Code Online (Sandbox Code Playgroud)
我尝试了几件事,比如删除FlushAsync()
,改变了在字符串中定义ContentType
,包含的方式data:image/jpeg;base64
,但没有任何工作.
我在这里和这里看到,在Response体流中写作是可行的,所以我认为我的方法很好(我之前尝试过返回一个简单的字符串但不能正常工作).
是的,我的base64字符串是正确的,因为我还试图将它直接包含在HTML中,图像显示正确.
我确切地说我不想使用任何JavaScript或Razor视图来实现这一点,只有纯HTML和我的控制器.
另请注意我在API控制器中.我不能像我们在一个空的ASP.NET Core项目Configure
的Startup
类中看到的那样做:
app.Run(async (context) =>
{
await context.Response.WriteAsync("Hello World!");
});
Run Code Online (Sandbox Code Playgroud)
虽然这两种响应类型HttpResponse
,一个在我的控制器没有任何Response.WriteAsync
但Response.Body.WriteAsync
感谢您的帮助,我正在搜索几个小时,但对于ASP.NET Core几乎没有相关的资源
Jon*_*eet 12
您仍然将数据作为base64文本返回,基本上 - 您将获得UTF-8编码形式,但这就是全部.
如果你真的只有图像的base64版本,你只需要解码:
byte[] image = Convert.FromBase64String(_base64Image2);
await Response.Body.WriteAsync(image, 0, image.Length);
Run Code Online (Sandbox Code Playgroud)
(请注意,它只需要您转换的base64 - 而不是数据URI.)
归档时间: |
|
查看次数: |
14355 次 |
最近记录: |