React Native - Как конвертировать изображения в Base64 и наоборот в Android - PullRequest
2 голосов
/ 14 марта 2019

Я создал приложение, которое делает фотографии и загружает их в AWS s3.После того как я их запечатлел, мне нужно их хэшироватьТам я использовал метод хеширования Base64, а полученные фотографии были зашифрованы.Но я не могу открыть это, и я не уверен, правильно ли я это сделал или нет.

Перед загрузкой я хочу снять их.То есть они должны храниться в виде хешированного изображения в галерее.Но я хочу преобразовать их в исходное изображение перед загрузкой.Таким образом, я могу хранить реальное изображение в облаке.

Мой код:

   import React, {Component} from 'react';
    import {Platform, StyleSheet,Alert, Text,TouchableOpacity, View,Picker,Animated,Easing,Image, NetInfo,
      Dimensions,Button,ScrollView } from 'react-native';
      import ImagePicker from 'react-native-image-picker';
    import RNFS from 'react-native-fs';

    class SecondScreen extends React.Component {

        takePic = () => {
           if(this.state.connection_Status==="Online"){
            this.getServerTime();
              try{
                  this.setState({capturedTime:this.state.serverTime.currentFileTime+'_'+time}, 
                    () => console.log(this.state.serverTime.currentFileTime)
                  ); 

              } catch (err) {
                  var date = new Date();
                  var time = date.getTime();
                  this.setState({capturedTime:time});
                  console.log("localtime")
                }
            }

            const options = {
              quality: 1.0,
              maxWidth: 75,
              maxHeight: 75,
              base64: true,
              skipProcessing: true
          }
            ImagePicker.launchCamera(options,(responce)=>{

                this.state.testImage.push({ uri: responce.uri });
                  const file ={
                    uri : responce.uri,
                    name :responce.fileName,
                    method: 'POST',
                    width : 50,
                    height : 50,
                    path : responce.path,
                    type :  responce.type,
                    notification: {
                        enabled: true
                      }
                  }

              this.setState(prevState => {
                // get the previous state values for the arrays
                let saveImages = prevState.saveImages;
                // add the values to the arrays like before
                saveImages.push(file);
                // return the new state
                return {
                 saveImages
                }
              });

              const base64 = RNFS.writeFile(responce.path, 'base64');
              return base64;

            })
        }

      _upload=()=>{
        if(this.state.connection_Status==="Online"){
          const config ={
              keyPrefix :aws_keyPrefix,
              bucket : aws_bucketName,
              region :aws_region,
              accessKey:aws_accessKey,
              secretKey :aws_secretKey,
              successActionStatus :201
            }
            //store captured images in an array
            this.state.saveImages.map((image) => {
                 RNS3.put(image,config)
                .then((responce) => {
                  console.log(image);
                });
            });

            if (this.state.saveImages && this.state.saveImages.length) {
              Alert.alert("Successfully, uploaded");
              //reset the arrays
              this.setState({saveImages:''});
              this.setState({testImage:''});
            } else {
              Alert.alert('No images captured');
            }
          } else {
            Alert.alert('Upload failed. User is in offline');
          }
      } 

      render() {
          return (
              <View style={styles.Camera}>
                <TouchableOpacity onPress={this.takePic.bind(this)}>
                  <Text>Take Picture</Text>
                </TouchableOpacity>

                <View style={styles.Send}>
                   <TouchableOpacity onPress={() => this._upload()}>
                      <Text>Send</Text>
                   </TouchableOpacity>
              </View>
              );
            }
          }

    const styles = StyleSheet.create({
      Camera :{
        justifyContent: 'center',
        alignItems: 'center',
        marginTop : 20,
        backgroundColor : '#48a4ff',
        alignItems : 'center',
        padding : 1,
        borderWidth : 1,
        borderColor : '#48a4ff',
      },
      Send :{
        justifyContent: 'center',
        alignItems: 'center',
        marginTop : 20,
        backgroundColor : '#48a4ff',
        alignItems : 'center',
        padding : 3,
        borderWidth : 1,
        borderColor : '#48a4ff',
      }
    });
export default SecondScreen;

Этот код, который я использую для хеширования изображения,

const base64 = RNFS.writeFile(responce.path, 'base64');
              return base64;

После хэширования свойства изображения будут такими, как показано ниже:

enter image description here

Как преобразовать его в реальное изображение перед загрузкой?

Может кто-нибудь помочья, так как день я пытаюсь.Я не сделал ни одного документа для реализации этой функции.

1 Ответ

0 голосов
/ 27 марта 2019

Я сделал это с помощью библиотекиact-native-fs.Хеширование изображений, которое я выполняю на стороне клиента, то есть в режиме реагирования, и хэширование, которое я делаю на стороне сервера (я храню изображения в Amezon s3, перед тем как их отключить, мы хешируем эти изображения с помощью python.)

Мой хэширующий код изображенияесть,

takePic = () => {
       /* other sets of codes
         .
         .*/

         const base64 = RNFS.writeFile(responce.uri, responce.data);
         return base64;
   }
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...