모바일 앱은 순수 네이티브 기반의 네이티브 앱과 웹기반의 하이브리드 앱으로 나누어 볼 수 있으며, 초창기에는 네이티브 기반이 주를 이루었지만 몇년전부터는 하이브리드 앱과 웹앱 방식이 주로 사용되고 있습니다.
하이브리드 앱과 웹앱의 차이점은 컨텐츠(html, js, image등) 접속차이이며 웹앱은 컨텐츠가 원격 서버에 있으며 url로 접속하는 방식입니다. 공통점은 하이브리드 방식이나 웹앱 방식인 경우에는 스마트폰의 하드웨어 기능을 사용하기 위하여 네이티브와 Javascript로 통신을 한다는 것입니다.
리액트-네이티브 환경에서는 네이티브(Android, iOS)와의 인터페이스를 위하여 브릿지(Bridge) 역활을 하는 네이티브 모듈(NativeModules)을 사용하며, 네이티브에서는 호출된 함수를 수행한 후 콜백으로 결과를 전송합니다.
네이티브 함수를 호출하는 예제
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 |
import { NativeModules } from 'react-native'; const AesCipher = NativeModules.Aes const SHA = NativeModules.Sha const MD = NativeModules.Md const generateKey = (password: string, salt: string, cost: number, length: number) => AesCipher.pbkdf2(password, salt, cost, length) const encryptData = (text: string, key: any) => { return AesCipher.randomKey(16).then((iv: any) => { return AesCipher.encrypt(text, key, iv).then((cipher: any) => ({ cipher, iv, })) }) } const encryptDataIV = (text: string, key: any, iv:any) => { return AesCipher.encrypt(text, key, iv).then((cipher: any) => ({ cipher, iv, })) } const decryptData = (encryptedData: { cipher: any; iv: any; }, key: any) => AesCipher.decrypt(encryptedData.cipher, key, encryptedData.iv) const iv_string = '0123456789abcdef0123456789abcdef'; |
리액트-네이티브로 개발된 대표적인 모바일 앱