简体   繁体   English

react-native:共享 api 将 base64 字符串而不是图像传递给 WhatsApp

[英]react-native: share api passing base64 string instead of image to WhatsApp

Hey i am struggling with sharing an base64 image via WhatsApp.嘿,我正在努力通过 WhatsApp 共享 base64 图像。 In iOS also Android the actual base 64 is been shared instead of the image.在 iOS 和 Android 中,实际的 base 64 被共享而不是图像。

If I use iMessage or Email (iOS) the base64 images is been converted and displayed as expected.如果我使用 iMessage 或电子邮件 (iOS),base64 图像将按预期进行转换和显示。 In Android using Email for sharing displays just the base64 string.在 Android 中,使用电子邮件进行共享仅显示 base64 字符串。 Did anyone else face the same issue?有没有其他人遇到同样的问题?

I am using react-native ~0.55.2我正在使用 react-native ~0.55.2

react-native Share API react-native Share 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

I am not sure how it will work with inbuilt Share functionality added by react-native.我不确定它如何与 react-native 添加的内置共享功能一起使用。 But using react-native-share worked for me.但是使用react-native-share对我有用。

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.您可以在按下按钮时直接即插即用以下 onClick 功能。

RNFS.downloadFile , downloads the remote image using URL and save it to a path. RNFS.downloadFile ,使用 URL 下载远程图像并将其保存到路径。 RNFS.readFile , converts the locally saved file data to base64 which is supported directly by Whatsapp and other applications. RNFS.readFile ,将本地保存的文件数据转换为 base64格式Whatsapp和其他应用程序直接支持。

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 is the image remote URL and id is some unique identifier for that image. Url是图像远程 URL, id是该图像的唯一标识符。

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

相关问题 React-Native:将图像 url 转换为 base64 字符串 - React-Native: Convert image url to base64 string React-Native:下载映像并将其转换为Base64映像 - React-Native: Download Image and convert it to Base64 Image 在Laravel API中从React-Native应用调整Base64图像的大小? - Resizing a base64 image from react-native app in laravel api? 将base64字符串转换为本机中的图像 - Convert base64 string to image in react native 如何在 React-Native 中将 base64 url 转换为图像(png/jpg)文件? - How can I convert a base64 url to an image(png/jpg) file, in React-Native? 将图像转换为 expo 中的 base64 react-native(仅在前端):PayloadTooLargeError:请求实体太大 - convert image to base64 in expo react-native(only in the frontend): PayloadTooLargeError: request entity too large React-Native(或JS)解码Base64为ZIP文件 - React-Native (or JS) Decode Base64 to ZIP File 在 React-Native(Expo 托管)中给定 base64 字符串,如何在图像/位图的特定坐标处获取像素的颜色? - How can I get a pixel's color at a specific coordinate of an Image/Bitmap given a base64 string in React-Native (Expo managed)? react-native-camera 将图片 base64 转换为 jpeg - react-native-camera convert Image base64 to jpeg 将 base64 图像上传到 Firebase React Native - Upload base64 Image to Firebase React native
 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM