본문 바로가기

개발

RxSwift로 회원가입 로직 만들기

728x90

RxSwift를 사용한 간단한 회원가입 로직 구현

RxSwift를 사용하여 간단한 회원가입 시스템을 구현하는 방법은 다음과 같습니다.

1. UI 요소와 ViewModel 설정

  • ViewController에서 이름, 이메일, 비밀번호 입력 필드와 회원가입 버튼을 설정합니다.
  • ViewModel클래스를 만들고 회원가입 로직을 담당할 속성과 메서드를 정의합니다.
import UIKit

import RxSwift



class SignUpViewController: UIViewController {



    @IBOutlet weak var nameTextField: UITextField!

    @IBOutlet weak var emailTextField: UITextField!

    @IBOutlet weak var passwordTextField: UITextField!

    @IBOutlet weak var signUpButton: UIButton!



    private let viewModel = SignUpViewModel()

    private let disposeBag = DisposeBag()



    override func viewDidLoad() {

        super.viewDidLoad()



        setupBindings()

    }



    private func setupBindings() {

        nameTextField.rx.text

            .bind(to: viewModel.nameText)

            .disposed(by: disposeBag)



        emailTextField.rx.text

            .bind(to: viewModel.emailText)

            .disposed(by: disposeBag)



        passwordTextField.rx.text

            .bind(to: viewModel.passwordText)

            .disposed(by: disposeBag)



        signUpButton.rx.tap

            .bind(to: viewModel.signUpTap)

            .disposed(by: disposeBag)



        viewModel.isSigningUp

            .bind(to: signUpButton.rx.isEnabled)

            .disposed(by: disposeBag)



        viewModel.signUpResult

            .subscribe(onNext: { [weak self] result in

                self?.handleSignUpResult(result)

            })

            .disposed(by: disposeBag)

    }



    private func handleSignUpResult(_ result: SignUpResult) {

        switch result {

        case .success:

            print("회원가입 성공!")

            // 화면 전환 또는 다른 작업 수행

        case .failure(let error):

            print("회원가입 실패: \(error.localizedDescription)")

            // 오류 메시지 표시 또는 처리

        }

    }

}



enum SignUpResult {

    case success

    case failure(Error)

}



class SignUpViewModel {

    let nameText = BehaviorSubject<String>(value: "")

    let emailText = BehaviorSubject<String>(value: "")

    let passwordText = BehaviorSubject<String>(value: "")

    let signUpTap = PublishSubject<Void>()

    let isSigningUp = BehaviorSubject<Bool>(value: false)

    let signUpResult = PublishSubject<SignUpResult>()



    func signUp() {

        isSigningUp.onNext(true)



        // 실제 회원가입 API 호출 및 처리

        // 예시:

        DispatchQueue.main.asyncAfter(deadline: .now() + 2) { [weak self] in

            if self?.emailText.value == "user@example.com" && self?.passwordText.value == "password" {

                self?.signUpResult.onNext(.success)

            } else {

                self?.signUpResult.onNext(.failure(NSError(domain: "SignUpError", code: 101, userInfo: nil)))

            }

            self?.isSigningUp.onNext(false)

        }

    }

}

 

2. 회원가입 로직 구현

  • ViewModel의 signUp 메서드에서 실제 회원가입 API 호출 및 처리를 수행합니다.
  • API 호출 후 성공 여부에 따라 signUpResult PublishSubject에 .success 또는 .failure 이벤트를 전달합니다.

3. UI 업데이트 및 이벤트 처리

  • ViewController에서 ViewModel의 signUpResult Observable을 구독하고 회원가입 결과에 따라 UI를 업데이트하거나 오류 메시지를 표시합니다.

참고:

  • 이 코드는 기본적인 예시이며 실제 구현에서는 API 호출, 에러 처리, UI 디자인 등을 추가적으로 구현해야 합니다.
  • RxSwift의 다양한 연산자와 API를 활용하여 더욱 복잡하고 효율적인 회원가입 로직을 구현할 수 있습니다.

추가 기능 구현:

  • 이메일 및 비밀번호 유효성 검사
  • 중복 이메일 체크
  • 개인정보 처리 동의 확인
  • 회원가입 후 로그인 자동 진행