- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在使用 express 作为中间件 api。一个人点击我的中间件,它点击一些第三方 api 并返回结果。它适用于所有其他端点,期望有一个创建 png 并为其提供服务的 get 端点。所以在方法下返回响应
_execute = R.curry((reqFunction, req, res) => {
reqFunction(req, res).
then(r => {
res.status(r.status).header(r.headers).send(r.data)
}).
catch(err => {
res.status(err.response.status).header(err.headers).send(err.response.data)
})
});
和reqFunction
是这样的方法
modelDiagram = (req, res) => {
const headers = req.headers;
const modelName = req.params['modelName'];
const endPoint = this.modelDiagramEndPoint + '/' + modelName;
return this.httpRequests.get(endPoint, headers);
}
和httpRequests.get
方法是
get = (endPoint, headers) => {
let options = {
method: 'GET',
url: endPoint
}
options = this.addHeaders(headers, options);
return this._send(options);
}
这个._send就像
_send = (options) => {
return axios(options);
};
如果我直接从浏览器点击响应就像``` �PNG
IHDRn�7Q� IDATx����oHk����D��|!H��DD��^)"k"n��$H��V뒻��Vж"+��n-"��[��XL�� լ��[Z��^����lnK&K����=��9��9z��sʋs��~����g��g����gf��l��z��QIcc.dEE. <��?��\YY��վ}�R7!{������'O�T �C��x�B�fff��7UYYٿ 8��^�a� ������? ��92O��L2w������{����s�NXZ�k�N�r�\��<.�N������/_����尵������ϫ ����E ��['����"��x˞|f �� ��~��N��K��d������u����3j��u5������% p6 ����Sj����ꛎ3>��<)��M��M��y4����v������{�� N.gSpCw~ �� p��[Opr��Φ��F��M@pR8��[��z������ä'O.g����-+��I7.v�� ����oW ��<)�� �ɓ�|� p���2;<=�)�fF;Փ��4 4ò�����8 Qf�����V�,X�n���},4À����H� 8��n}}������ ��8"����À 7p��/]��j����h��0g�@Bfપ��Too/������z����mD� 8����Ḹ8��w��^������v��ڵ��v�������������������������� x@###:��N(�O?��o�6o�“YSS�n�|����Tcccx����P����::Z����h1� v��U~~����Q)))����9��V;��[��n.tAA����U����l+P$O��[��̙3��3Z [����|)��ϯ��WIII>>^|��7o��q��~�� R zY T��q��@��]7p2����ZZZ��Ç }v^TT��Feee<��0��;v��P�� ��o��U[[���� e�� ���Q������m]]��,//ϻ~EE��3"��ի���<h���[��� Έ����;��.Y^��SYY��
��l��'X��ն����j����4##C/��{��@u��.P{� �Ѹ ;7��
��9� a58����j[��u�� ����3�ş'��Zu~ 8��������{����ӧO��\��IWWW ��lc̃����6Z��sIo6Mϛ��p��rmӒ'��+��3P[��yH��|e��e����af������+鱱1UZZj����N���� �T}�577���r� ��F�A����1b�b����R��0�O�拓@e���-�C%&&�mUTTԚO��$e�H1��ӿ���A}A#?��������H�����#�&7bo�%z�̐3/77W�>��#/ 8�a�a�p�ÀÀ�8 8:�Hyz�x��[�].�L$|w <55����tvv����z=77���۸HhN��;�_�yV��!�@o�l��ߟ���Y!�!�ppp�C�C����888�!�!�!�pppp�C�C������8zppp��)�>w�����k��[V��N�S�\�W�X'�zzz/��X���ˇ�-��W"
��3��|��ƍ��zU\��.����y����z����W����+������ W�� Ѽ��v����RGJJ��ON N ����推����! ��H��GFF��YYY��.77W��t����d�aɼl�^ZZ�6"�XwϞ=:��@qYY�H��O������T�,��cLKKS ����A�
h���l�-�|w�v��������hy06���|�N1Կ�jDM/�����'�����/՝��5��w�[:���Hr�zc �����η�37��C��U����8�a�pNn�C�ƍ�M�ɣ�P����&��a�<�����|�ppp��0�8�a�a�.���xb;u���8���k��?�\EEE�t��I���*))I��ǫ��]6;;����Ull����Q���}���8pi���^xN�Gcݒ�������N���ѣ�u233u~SS�>y����d�?11���dx��9���V-,,�5栵:�#�d{{�NK���1J}:-s��˗��HZ�e~mnn^1?ÜX���9$=66�JKK}�d��tuuu䂓�]�P����VK�$J�l'��y����X�����6�?::��dH4G���P�������B��&s�� Nr���O�\���
� ```
8�0�0�8�a�a�p��8l'p��V^��t��5�w�ᩩ�/-w���sOWW�빹��t��E�@s:��Y�҇ȳ�n��|�fC,��,$h!�B!����?Ǔ�8���IEND�B
但是图片坏了。我试过很多东西,比如 req.end
并明确设置 header ,但我无法解决。请指导我
最佳答案
抱歉回答晚了,但也许有人觉得这种方法更可靠:
axios.get('/path/to/image.png', { responseType: 'arraybuffer' })
.then(response => {
let blob = new Blob(
[response.data],
{ type: response.headers['content-type'] }
)
let image = URL.createObjectURL(blob)
return image
})
我是怎么理解的:
{ responseType: 'arraybuffer' }
中指定时,axios 会将 response.data
设置为 ArrayBuffer
URL.createObjectURL(blob)
获取 blob 文件的 url,您可以在 img
标签的 src
属性中使用它<如本 article 中所述上面的方法应该更快。
这是 jsfiddle demo
更新:
只是发现您可以在选项中指定 responseType: 'blob'
所以您不需要自己创建 Blob
对象:
axios.get('https://picsum.photos/300/300', {responseType: 'blob'})
.then(response => {
let imageNode = document.getElementById('image');
let imgUrl = URL.createObjectURL(response.data)
imageNode.src = imgUrl
})
Jsfiddle demo
这里是 axios issue关于缺少二进制数据操作文档。在这个comment您可以找到我建议的相同方法。您也可以在 this 中使用 FileReader
API您可以在 stackoverflow 评论中找到这两种方法的优缺点。
关于javascript - 服务 png 图像的 Axios 图像损坏,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42785229/
我正在寻找一种经济合理的解决方案来长时间存储图片。我读到 PNG 文件格式,它与 JPEG 相比具有优越的特性,即在这些类别中: 无专利、无许可、无版税 无质量损失 尚未压缩 我有很多来自 Photo
关闭。这个问题是off-topic .它目前不接受答案。 想改善这个问题吗? Update the question所以它是 on-topic对于堆栈溢出。 9年前关闭。 Improve this q
我怎么能用 FFMEG 做到这一点? 输入 : 背景图片:background.png 图片帧列表:image_001.png,image_002.png ...(每张图片为一帧) 输出:所有帧都有背
$ cat png.ll ./packages/apps/Mms/res/mipmap-hdpi/ic_launcher_smsmms.png ./packages/apps/Mms/res/draw
这个问题在这里已经有了答案: Natural Sort Order in C# (18 个答案) 关闭 7 年前。 这是我的代码: private void Method1() { int
我一直在考虑用 Webp 图像替换我的 Android 应用程序中的 png 文件以减小 APK 大小。 虽然结果不错,但我想知道我是否使用了一些 png 转换器/压缩器,并且能够将尺寸减小到比我为
在 gnuplot-4.2.6 中,我可以使用 set term png medium x000000 xffffff set output 'file.png' plot x 这将生成一个带有黑色背
背景: 我正在努力使一堆 PNG 尽可能小。我正在使用诸如 PngOut、PngCrush 和 OptiPng 之类的工具。 问题: 我遇到了一个大小为 1434 KB 但只有 230 x 230 像
我正在使用 ImageMagick 调整图像大小。如果我传递 -resize WxH 选项,它会按预期运行。但是如果我通过 -resize WxH! (在调整大小时忽略纵横比),一些图像,尤其是 PN
如何访问/删除 PNG 元数据? 我正在寻找 Mac 应用程序或 PHP 代码段。 最佳答案 抱歉发布了一个 Windows 软件,但如果你没有找到任何对 MAC 有用的东西,那就是 TweakPNG
到目前为止似乎没有任何效果。我看到了 pnginfo以下消息: concept_Sjet_dream6.png... Image Width: 200 Image Length: 240 Bi
我有一个带有 Alpha channel (即透明度)的 PNG 图像,我需要创建将图像层合成到白色背景上的版本。我想使用可编写脚本的命令,使用 CLI 工具(例如 Image Magick)将 PN
我是初学者。我昨天问了一个类似的问题,但不知何故被否决了。所以这次我尽量简化问题。 带有 alpha png 的 24 位与 32 位 png 相同吗? 非常感谢您的一些提示。 最佳答案 没有“24
我有这个带点的荷兰 pdf 图像: pdf image of the netherlands with dots 当我尝试将此 pdf 转换为 png 图像时,使用 pdftools和 png像这样:
我在我的启动图像通用项目中添加了“Default.png,Default-568h@2x.png,Default@2x.png”这三个文件,我有三个不同的图像,分辨率与苹果中提到的完全相同文档,适用于
我在 Python 中使用 google app engine 并有几个静态 .png 图像文件,但它们都以“image/x-png”内容类型提供。这是一个问题,当我使用像 chrome 这样的浏览器
我做了一个 python 脚本,该脚本设法根据特定模式解散乱序(png)图像,该 python 脚本使用 ffmpeg 并进行 12 次编码来解乱它(通过裁剪特定部分并将其粘贴到现有图片上)。 因此,
我有一个 PNG 图像文件。我想将其转换为 GeoTiff。我安装了 QGIS 软件,但无法使用它,也不知道如何对图像进行地理配准。请帮我。有没有在线软件? 最佳答案 这是一个非常好的教程,其中包含有
我有一堆使用我编写的 Java 图表工具创建的图表 - 它们主要是黑白图表,带有浅绿色的块,偶尔还有其他颜色。它们当前被保存为 JPG 文件,我想将它们插入到我准备按需打印的书中。 这本书是一个 Op
关闭。这个问题不满足Stack Overflow guidelines .它目前不接受答案。 想改善这个问题吗?更新问题,使其成为 on-topic对于堆栈溢出。 7年前关闭。 Improve thi
我是一名优秀的程序员,十分优秀!