图片需要调用接口获取,如何将返回的图片乱码转为真实图片

输出返回的图片数据,显示乱码(ArrayBuffer 二进制流)
在这里插入图片描述
在这里插入图片描述
若要正常展示图片,需要对其进行转换:

// 请求拦截器
request.interceptors.request.use(
  (config) => {
    config.headers.token = store.state.user.userInfo.authorization || "";

    config.responseType = "arraybuffer";

    return config;
  },
  (err) => {
    // do something with request err
    return Promise.reject(err);
  }
);
  methods: {
    getUrl(imageName) {
      return getPictureUrl(customerId, imageName).then(response => {
        console.log("response.data",response.data)

        const arrayBufferView = new Uint8Array(response.data);
        const blob = new Blob([arrayBufferView], { type: "image/jpeg" });
        const urlCreator = window.URL || window.webkitURL;
        const imageUrl = urlCreator.createObjectURL(blob);
        console.log("imageUrl",imageUrl);
        return imageUrl;
      })
    }
  },

在这里插入图片描述
参考地址:https://gist.github.com/candycode/f18ae1767b2b0aba568e

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
这取决于你要调用接口所期望的请求参数格式。一般来说,有两种常见的方式来向接口传输图片: 1. Base64 编码:将图片的二进制数据编码为 Base64 格式字符串,并在请求的 body 中传输。这种方式适用于一些支持 Base64 编码方式的接口。示例代码如下: ```python import base64 import requests # 读取图片文件,转换为 Base64 格式字符串 with open('image.jpg', 'rb') as f: img_bytes = f.read() img_base64 = base64.b64encode(img_bytes).decode('utf-8') # 发送 POST 请求,将 Base64 格式字符串作为请求体传输 url = 'https://example.com/api/upload-image' data = {'image': img_base64} response = requests.post(url, data=data) # 处理响应 print(response.status_code) print(response.text) ``` 2. Multipart/form-data 格式:将图片作为二进制文件直接传输到请求体中,并使用 multipart/form-data 格式提交。这种方式适用于一些常规的文件上传接口。示例代码如下: ```python import requests # 发送 POST 请求,将图片作为二进制文件传输 url = 'https://example.com/api/upload-image' files = {'image': ('image.jpg', open('image.jpg', 'rb'), 'image/jpg')} response = requests.post(url, files=files) # 处理响应 print(response.status_code) print(response.text) ``` 需要注意的是,具体的实现可能还有一些细节需要考虑,例如请求头的设置、文件名的指定等等。建议先查看接口文档,了解接口的具体要求。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值