React Native开源封装AES,MD5加密模块(react-native-encryption-library)

本文主要是介绍React Native开源封装AES,MD5加密模块(react-native-encryption-library),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

本文来自:江清清的技术专栏(http://www.lcode.org)

开源项目地址:https://github.com/jiangqqlmj/react-native-encryption-library

项目介绍

昨天自己封装了常用的加密方式例如:MD5,AES加密,供React Native进行使用,不过当前项目适配Android平台。

刚创建的React Native交流5群:386216878,欢迎各位大牛,React Native技术爱好者加入交流!

安装配置
?
1
npm install react-native-encryption-library --save

In android/setting.gradle

?
1
2
3
...
include ':react-native-encryption-library'
project( ':react-native-encryption-library' ).projectDir = new File(rootProject.projectDir, '../node_modules/react-native-encryption-library/android' )

In android/app/build.gradle

?
1
2
3
4
5
...
dependencies {
     ...
     compile project( ':react-native-encryption-library' )
}

register module (in MainActivity.java)

On newer versions of React Native (0.18+):

?
1
2
3
4
5
6
7
8
9
10
11
import com.chinaztt.encapsulation.EncryptionReactPackager;;  // <--- import
public class MainActivity extends ReactActivity {
   ......
     @Override
     protected List<ReactPackage> getPackages() {
       return Arrays.<ReactPackage>asList(
          new EncryptionReactPackager(), // <------ add here
         new MainReactPackage());
     }
}

On older versions of React Native:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
import com.chinaztt.encapsulation.EncryptionReactPackager;;  // <--- import
public class MainActivity extends Activity implements DefaultHardwareBackBtnHandler {
   ......
   @Override
   protected void onCreate(Bundle savedInstanceState) {
     super .onCreate(savedInstanceState);
     mReactRootView = new ReactRootView( this );
     mReactInstanceManager = ReactInstanceManager.builder()
       .setApplication(getApplication())
       .setBundleAssetName( "index.android.bundle" )
       .setJSMainModuleName( "index.android" )
       .addPackage( new MainReactPackage())
       .addPackage( new EncryptionReactPackager())              // <------ add here
       .setUseDeveloperSupport(BuildConfig.DEBUG)
       .setInitialLifecycleState(LifecycleState.RESUMED)
       .build();
     mReactRootView.startReactApplication(mReactInstanceManager, "ExampleRN" , null );
     setContentView(mReactRootView);
   }
   ......
}
导入模块
?
1
2
import {NativeModules} from 'react-native' ;
var EncryptionModule=NativeModules.EncryptionModule
使用实例
?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
import React, { Component } from 'react' ;
import {
   AppRegistry,
   StyleSheet,
   Text,
   View,
   TouchableHighlight
} from 'react-native' ;
import {NativeModules} from 'react-native' ;
var EncryptionModule=NativeModules.EncryptionModule
//待加密的信息
var PASSWORD= '745r#x3g' ;
var KEY= 'wIEuw3kAGwVNl7BW' //16位AES加密私钥
class CustomButton extends React.Component {
   render() {
     return (
       <TouchableHighlight
         style={styles.button}
         underlayColor= "#a5a5a5"
         onPress={ this .props.onPress}>
         <Text style={styles.buttonText}>{ this .props.text}</Text>
       </TouchableHighlight>
     );
   }
}
class react_native_encryption_library extends Component {
   constructor(props){
      super (props);
      this .state={
         result: '' ,
         AES_Result: '' ,
      }
   }
   async _MD5ByPromise(){
      try {
         var result=await EncryptionModule.MD5ByPromise(PASSWORD);
         this .setState({result: 'Promise:' +result});
      } catch (e){
         this .setState({result: 'MD5加密失败-通过Promise回调' });
      }
   }
   async _AESEncryptByPromise(){
      try {
         var result=await EncryptionModule.AESEncryptByPromise(PASSWORD,KEY);
         this .setState({AES_Result:result});
      } catch (e){
         this .setState({AES_Result: 'AES加密失败-通过Promise回调' });
      }
   }
   async _AESDecryptByPromise(){
      try {
         var result=await EncryptionModule.AESDecryptByPromise( this .state.AES_Result,KEY);
         this .setState({AES_Result:result});
      } catch (e){
         this .setState({AES_Result: 'AES解密失败-通过Promise回调' });
      }
   }
   render() {
     return (
       <View style={styles.container}>
         <Text style={styles.welcome}>
            加密模块封装实例-Android端
         </Text>
         <Text style={{margin:10,fontSize:12}}>
            结果:{ this .state.result}
         </Text>
         <CustomButton
            text= "测试MD5加密封装-CallBack回调"
            onPress={()=>EncryptionModule.MD5ByCallBack(PASSWORD,(msg)=>{
                this .setState({result: 'CallBack:' +msg});
           },(error)=>{
                this .setState({result: 'MD5加密失败-通过Callback回调' });  
           })}
         />
         <CustomButton
            text= "测试MD5加密封装-Promise回调"
            onPress={()=> this ._MD5ByPromise()}
         />
          <Text style={{margin:10,fontSize:12}}>
            AES结果:{ this .state.AES_Result}
         </Text>
         <CustomButton
            text= "测试AES加密封装-CallBack回调"
            onPress={()=>EncryptionModule.AESEncryptByCallBack(PASSWORD,KEY,(msg)=>{
                this .setState({AES_Result:msg});
           },(error)=>{
                this .setState({AES_Result: 'AES加密失败-通过Callback回调' });  
           })}
         />
         <CustomButton
            text= "测试AES加密封装-Promise回调"
            onPress={()=> this ._AESEncryptByPromise()}
         />
         <CustomButton
            text= "测试AES解密封装-CallBack回调"
            onPress={()=>EncryptionModule.AESDecryptByCallBack( this .state.AES_Result,KEY,(msg)=>{
                this .setState({AES_Result:msg});
           },(error)=>{
                this .setState({AES_Result: 'AES解密失败-通过Callback回调' });  
           })}
         />
         <CustomButton
            text= "测试AES解密封装-Promise回调"
            onPress={()=> this ._AESDecryptByPromise()}
         />
       </View>
     );
   }
}
const styles = StyleSheet.create({
   welcome: {
     fontSize: 20,
     textAlign: 'center' ,
     margin: 10,
   },
   button: {
     margin:5,
     backgroundColor: 'white' ,
     padding: 15,
     borderBottomWidth: StyleSheet.hairlineWidth,
     borderBottomColor: '#cdcdcd' ,
   },
});
AppRegistry.registerComponent( 'encryption_library' , () => react_native_encryption_library);
运行效果

这篇关于React Native开源封装AES,MD5加密模块(react-native-encryption-library)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/510104

相关文章

Java实现Excel与HTML互转

《Java实现Excel与HTML互转》Excel是一种电子表格格式,而HTM则是一种用于创建网页的标记语言,虽然两者在用途上存在差异,但有时我们需要将数据从一种格式转换为另一种格式,下面我们就来看看... Excel是一种电子表格格式,广泛用于数据处理和分析,而HTM则是一种用于创建网页的标记语言。虽然两

vue解决子组件样式覆盖问题scoped deep

《vue解决子组件样式覆盖问题scopeddeep》文章主要介绍了在Vue项目中处理全局样式和局部样式的方法,包括使用scoped属性和深度选择器(/deep/)来覆盖子组件的样式,作者建议所有组件... 目录前言scoped分析deep分析使用总结所有组件必须加scoped父组件覆盖子组件使用deep前言

VUE动态绑定class类的三种常用方式及适用场景详解

《VUE动态绑定class类的三种常用方式及适用场景详解》文章介绍了在实际开发中动态绑定class的三种常见情况及其解决方案,包括根据不同的返回值渲染不同的class样式、给模块添加基础样式以及根据设... 目录前言1.动态选择class样式(对象添加:情景一)2.动态添加一个class样式(字符串添加:情

多模块的springboot项目发布指定模块的脚本方式

《多模块的springboot项目发布指定模块的脚本方式》该文章主要介绍了如何在多模块的SpringBoot项目中发布指定模块的脚本,作者原先的脚本会清理并编译所有模块,导致发布时间过长,通过简化脚本... 目录多模块的springboot项目发布指定模块的脚本1、不计成本地全部发布2、指定模块发布总结多模

Python中构建终端应用界面利器Blessed模块的使用

《Python中构建终端应用界面利器Blessed模块的使用》Blessed库作为一个轻量级且功能强大的解决方案,开始在开发者中赢得口碑,今天,我们就一起来探索一下它是如何让终端UI开发变得轻松而高... 目录一、安装与配置:简单、快速、无障碍二、基本功能:从彩色文本到动态交互1. 显示基本内容2. 创建链

Java中的密码加密方式

《Java中的密码加密方式》文章介绍了Java中使用MD5算法对密码进行加密的方法,以及如何通过加盐和多重加密来提高密码的安全性,MD5是一种不可逆的哈希算法,适合用于存储密码,因为其输出的摘要长度固... 目录Java的密码加密方式密码加密一般的应用方式是总结Java的密码加密方式密码加密【这里采用的

Node.js 中 http 模块的深度剖析与实战应用小结

《Node.js中http模块的深度剖析与实战应用小结》本文详细介绍了Node.js中的http模块,从创建HTTP服务器、处理请求与响应,到获取请求参数,每个环节都通过代码示例进行解析,旨在帮... 目录Node.js 中 http 模块的深度剖析与实战应用一、引言二、创建 HTTP 服务器:基石搭建(一

React实现原生APP切换效果

《React实现原生APP切换效果》最近需要使用Hybrid的方式开发一个APP,交互和原生APP相似并且需要IM通信,本文给大家介绍了使用React实现原生APP切换效果,文中通过代码示例讲解的非常... 目录背景需求概览技术栈实现步骤根据 react-router-dom 文档配置好路由添加过渡动画使用

使用Python制作一个PDF批量加密工具

《使用Python制作一个PDF批量加密工具》PDF批量加密‌是一种保护PDF文件安全性的方法,通过为多个PDF文件设置相同的密码,防止未经授权的用户访问这些文件,下面我们来看看如何使用Python制... 目录1.简介2.运行效果3.相关源码1.简介一个python写的PDF批量加密工具。PDF批量加密

python中的与时间相关的模块应用场景分析

《python中的与时间相关的模块应用场景分析》本文介绍了Python中与时间相关的几个重要模块:`time`、`datetime`、`calendar`、`timeit`、`pytz`和`dateu... 目录1. time 模块2. datetime 模块3. calendar 模块4. timeit