React Native
...
Users
리액트 네이티브: Parse 사용자 비밀번호 재설정 구현 방법
9 분
리액트 네이티브 사용자 비밀번호 재설정 소개 시스템에 비밀번호를 도입하면 사용자가 비밀번호를 잊어버리는 것은 사실입니다 이러한 경우, parse 라이브러리는 사용자가 안전하게 비밀번호를 재설정할 수 있는 방법을 제공합니다 이메일 인증과 마찬가지로, parse는 이미 이를 위한 구현을 준비해 두었습니다, parse user requestpasswordemail parse user requestpasswordemail 이 방법을 사용하면 parse가 비밀번호 재설정의 모든 측면을 원활하게 처리합니다 전제 조건 이 튜토리얼을 완료하려면 다음이 필요합니다 리액트 네이티브 앱이 생성되고 https //www back4app com/docs/react native/parse sdk/react native sdk 이전 가이드를 완료하여 https //www back4app com/docs/react native/parse sdk/working with users/react native login 목표 react native 앱에 parse를 사용하여 사용자 비밀번호 재설정 기능을 추가합니다 1 비밀번호 재설정 이메일 사용자 정의 “ parse user requestpasswordemail parse user requestpasswordemail ” 메서드를 호출하기 전에 비밀번호 재설정을 요청한 후 사용자가 받을 메시지를 사용자 정의할 수 있습니다 앱 대시보드에 로그인하고 설정 >검증 이메일로 이동하여 비밀번호 재설정 이메일 제목이나 메시지를 변경하세요 사용자가 명확한 지침이 포함된 이메일을 받고, 그것이 실제로 귀하의 애플리케이션에서 온 것임을 나타내는지 확인하세요 2 requestpasswordemail 사용하기 “ parse user requestpasswordemail parse user requestpasswordemail ” 메서드를 호출하는 데는 사용자 계정 이메일만 매개변수로 필요하므로 비밀번호 재설정 화면에 다음 함수를 추가하세요 사용자 이메일을 위한 텍스트 입력을 화면에 추가하는 것을 잊지 마세요 javascript 1 const douserpasswordreset = async function () { 2 // note that this value come from state variables linked to your text input 3 const emailvalue = email; 4 return await parse user requestpasswordreset(emailvalue) 5 then(() => { 6 // login returns the corresponding parseuser object 7 alert alert( 8 'success!', 9 `please check ${email} to proceed with password reset `, 10 ); 11 return true; 12 }) 13 catch((error) => { 14 // error can be caused by lack of internet connection 15 alert alert('error!', error message); 16 return false; 17 }); 18 };1 const douserpasswordreset = async function () promise\<boolean> { 2 // note that this value come from state variables linked to your text input 3 const emailvalue string = email; 4 return await parse user requestpasswordreset(emailvalue) 5 then(() => { 6 // login returns the corresponding parseuser object 7 alert alert( 8 'success!', 9 `please check ${email} to proceed with password reset `, 10 ); 11 return true; 12 }) 13 catch((error object) => { 14 // error can be caused by lack of internet connection 15 alert alert('error!', error message); 16 return false; 17 }); 18 }; 계속 진행하여 화면과 구성 요소를 테스트하세요 비밀번호 재설정 이메일 요청 후에는 다음과 같은 메시지가 표시됩니다 이메일을 받았어야 하므로, 계속 진행하여 받은 편지함을 확인하세요 메시지에는 이전에 parse 대시보드에서 설정한 변경 사항이 포함될 것입니다 비밀번호 재설정 양식은 다음과 같이 보일 것입니다 그게 전부입니다 이 양식에서 비밀번호를 변경한 후, 사용자는 다시 애플리케이션에 로그인할 수 있습니다 3 비밀번호 요청 컴포넌트 만들기 앞서 언급했듯이, 비밀번호 재설정을 가능하게 하기 위해 사용자 계정 이메일을 위한 텍스트 입력 필드와 함께 2단계에서 보여준 기능을 포함하는 컴포넌트를 만들어야 합니다 다음은 이 컴포넌트의 완전한 예입니다 원하신다면 이전 가이드의 사용자 로그인 프로젝트에 연결할 수 있습니다 userresetpassword js 1 import react, {fc, reactelement, usestate} from 'react'; 2 import {alert, text, textinput, touchableopacity, view} from 'react native'; 3 import parse from 'parse/react native'; 4 import {usenavigation} from '@react navigation/native'; 5 import styles from ' /styles'; 6	 7 export const userresetpassword = () => { 8 const navigation = usenavigation(); 9	 10 // your state variable 11 const \[email, setemail] = usestate(''); 12	 13 const douserpasswordreset = async function () promise\<boolean> { 14 // note that this value come from state variables linked to your text input 15 const emailvalue = email; 16 return await parse user requestpasswordreset(emailvalue) 17 then(() => { 18 // login returns the corresponding parseuser object 19 alert alert( 20 'success!', 21 `please check ${email} to proceed with password reset `, 22 ); 23 // redirect user to your login screen 24 navigation navigate('login'); 25 return true; 26 }) 27 catch((error) => { 28 // error can be caused by lack of internet connection 29 alert alert('error!', error message); 30 return false; 31 }); 32 }; 33	 34 return ( 35 \<view style={styles login wrapper}> 36 \<view style={styles form}> 37 \<text>{'please enter your account email to reset your password '}\</text> 38 \<textinput 39 style={styles form input} 40 value={email} 41 placeholder={'your account email'} 42 onchangetext={(text) => setemail(text)} 43 autocapitalize={'none'} 44 keyboardtype={'email address'} 45 /> 46 \<touchableopacity onpress={() => douserpasswordreset()}> 47 \<view style={styles button}> 48 \<text style={styles button label}>{'request password reset'}\</text> 49 \</view> 50 \</touchableopacity> 51 \</view> 52 \</view> 53 ); 54 }; userresetpassword tsx 1 import react, {fc, reactelement, usestate} from 'react'; 2 import {alert, text, textinput, touchableopacity, view} from 'react native'; 3 import parse from 'parse/react native'; 4 import {usenavigation} from '@react navigation/native'; 5 import styles from ' /styles'; 6	 7 export const userresetpassword fc<{}> = ({}) reactelement => { 8 const navigation = usenavigation(); 9	 10 // your state variable 11 const \[email, setemail] = usestate(''); 12	 13 const douserpasswordreset = async function () promise\<boolean> { 14 // note that this value come from state variables linked to your text input 15 const emailvalue string = email; 16 return await parse user requestpasswordreset(emailvalue) 17 then(() => { 18 // login returns the corresponding parseuser object 19 alert alert( 20 'success!', 21 `please check ${email} to proceed with password reset `, 22 ); 23 // redirect user to your login screen 24 navigation navigate('login'); 25 return true; 26 }) 27 catch((error object) => { 28 // error can be caused by lack of internet connection 29 alert alert('error!', error message); 30 return false; 31 }); 32 }; 33	 34 return ( 35 \<view style={styles login wrapper}> 36 \<view style={styles form}> 37 \<text>{'please enter your account email to reset your password '}\</text> 38 \<textinput 39 style={styles form input} 40 value={email} 41 placeholder={'your account email'} 42 onchangetext={(text) => setemail(text)} 43 autocapitalize={'none'} 44 keyboardtype={'email address'} 45 /> 46 \<touchableopacity onpress={() => douserpasswordreset()}> 47 \<view style={styles button}> 48 \<text style={styles button label}>{'request password reset'}\</text> 49 \</view> 50 \</touchableopacity> 51 \</view> 52 \</view> 53 ); 54 }; 이 구성 요소는 다음과 같은 화면에 렌더링되어야 합니다 결론 이 가이드의 끝에서, react native에서 parse 사용자가 비밀번호를 재설정할 수 있도록 하는 방법을 배웠습니다 다음 가이드에서는 유용한 사용자 쿼리를 수행하는 방법을 보여드리겠습니다