react-native:共享 api 将 base64 字符串而不是图像传递给 WhatsApp [英] react-native: share api passing base64 string instead of image to WhatsApp

查看:42
本文介绍了react-native:共享 api 将 base64 字符串而不是图像传递给 WhatsApp的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

嘿,我正在努力通过 WhatsApp 共享 base64 图像.在 iOS 和 Android 中,实际的 base 64 被共享而不是图像.

Hey i am struggling with sharing an base64 image via WhatsApp. In iOS also Android the actual base 64 is been shared instead of the image.

如果我使用 iMessage 或电子邮件 (iOS),base64 图像将按预期进行转换和显示.在 Android 中,使用电子邮件进行共享仅显示 base64 字符串.有没有其他人遇到过同样的问题?

If I use iMessage or Email (iOS) the base64 images is been converted and displayed as expected. In Android using Email for sharing displays just the base64 string. Did anyone else face the same issue?

我正在使用 react-native ~0.55.2

react-native 共享 API

import React, { Component } from 'react';
import {Image, Text, StyleSheet, View, Share, Button} from 'react-native';

class ShareClass extends Component {

  onClick() {
    Share.share({
      message: REACT_ICON, //for whats app
      url: REACT_ICON, // for other applications
       title: 'Wow, did you see that?'
    }, {
      // Android only:
      dialogTitle: 'Share BAM goodness',
    })
  }

  render() {
    return (
      <View style={styles.container}>

          <Button 
          title ="Testing the Share Button"
          onPress = {this.onClick}> 
          </Button>

          <Text>Testing the display of base64 image</Text>
          <Image source = {{uri:REACT_ICON, width:100, height: 100}} />

      </View>
    );
  }
}

const styles = StyleSheet.create({
  container: {
    flex: 1,
    justifyContent: 'center',
    alignItems: 'center',
    backgroundColor: '#F5FCFF',
  }
});


const REACT_ICON = '';

export default ShareClass

推荐答案

我不确定它如何与 react-native 添加的内置共享功能一起工作.但是使用 react-native-share 对我有用.

I am not sure how it will work with inbuilt Share functionality added by react-native. But using react-native-share worked for me.

我找到了解决此问题的可行方法.目前,我也在我的一个应用程序中使用它.您可以通过按下按钮直接即插即用以下 onClick 功能.

I have found a working workaround for this problem. Currently, I also use it in one of my applications. You can directly plug and play the below onClick function on a button press.

RNFS.downloadFile,使用 URL 下载远程图像并将其保存到路径.RNFS.readFile,将本地保存的文件数据转为 base64 格式,Whatsapp 等应用直接支持.

RNFS.downloadFile, downloads the remote image using URL and save it to a path. RNFS.readFile, converts the locally saved file data to base64 which is supported directly by Whatsapp and other applications.

import Share from 'react-native-share';
import RNFS from 'react-native-fs';

async onClick(url, id){
        const path = `${RNFS.DocumentDirectoryPath}/${id}.jpg`;
        await RNFS.downloadFile({ fromUrl: url, toFile: `file://${path}` }).promise
            .then((res) => {
                return res;
            })
            .catch((err) => {
                return err;
            });
        RNFS.readFile(`file://${path}`, 'base64').then((res) => {
            let shareOptionsUrl = {
                title: 'My Application',
                message: 'Use my application',
                url: `data:image/jpeg;base64,${res}`, // use image/jpeg instead of image/jpg
                subject: 'Share information from your application'
            };
            Share.open(shareOptionsUrl);
        })
    }

Url 是图像远程 URL,id 是该图像的唯一标识符.

Url is the image remote URL and id is some unique identifier for that image.

这篇关于react-native:共享 api 将 base64 字符串而不是图像传递给 WhatsApp的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆