inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

[코드팩토리] [중급] Flutter 진짜 실전! 상태관리, 캐시관리, Code Generation, GoRouter, 인증로직 등 중수가 되기 위한 필수 스킬들!

Redirect와 Refresh 로직

redirect: authStateProvider._redirectLogic 빨간줄

513

dlckdals9467

작성한 질문수 30

-1

아래와 같은 코드인데 redirect부분에서 빨간줄이 나는데 뭐가 문제일까요

 

import 'package:flutter/material.dart';
import 'package:go_router/go_router.dart';
import 'package:gorouter_practice/model/user_model.dart';
import 'package:gorouter_practice/screen/login_screen.dart';
import 'package:riverpod/riverpod.dart';

import '../screen/1_screen.dart';
import '../screen/2_screen.dart';
import '../screen/3_screen.dart';
import '../screen/error_screen.dart';
import '../screen/home_screen.dart';

final routerProvider = Provider<GoRouter>((ref){
  final authStateProvider = AuthNotifier(
    ref: ref
  );

  return GoRouter(
      initialLocation: '/',
      errorBuilder: (context,state){
        return ErrorScreen(
            error: state.error.toString());
      },
      // redirect 주소가 잘못됐을때 올바른 주소로 연결
      redirect: authStateProvider._redirectLogic,
      // refresh 새로고침, 상태가 변경할 때마다 redirect실행
      refreshListenable: authStateProvider,
      routes: authStateProvider._routes
  );
});

class  AuthNotifier extends ChangeNotifier{
  final Ref ref;

  AuthNotifier({
    required this.ref,
  }){
   ref.listen<UserModel?>(
       userProvider, (previous, next) {
         if(previous!=next){
           notifyListeners();
         }

   }
   );
  }
  
  String? _redirectLogic(GoRouterState state){
    //UserModel의 인스턴스 or null
    final user = ref.read(userProvider);
    
    //로그인을 하려는 상태인지(location은 현재 위치를 가져옴)
    final logginIn = state.location == '/login';

    //유저 정보가 없다 - 로그인한 상태가 아니다
    //
    //유저 정보가 없고
    //로그인하려는 중이 아니라면
    //로그인 페이지로 이동한다.
    if(user == null){
      //로그인을 시도하려는 상태면 null 반환 로그인페이지 위에 로그인페이지가 쌓이는걸 방지하기 위해
      return logginIn ? null : '/login';
    }

    //유저 정보가 있는데
    //로그인 페이지라면
    //홈으로 이동
    if(logginIn){
      return '/';
    }

    //가려는 페이지로 보내줌 위의 로직은 일종의 필터 역할
    return null;
  }

  List<GoRoute> get _routes => [
    GoRoute(
        path: '/',
        builder: (_,state) => HomeScreen(),
        routes: [
          GoRoute(
            //라우트안에 라우트를 넣으면 슬래시를 안넣어도됨
              path: 'one',
              builder:(_,state) => OneScreen(),
              routes: [
                GoRoute(
                  //http://....../one/two 위의 페이지들이 다 깔림
                  //라우트안에 라우트를 넣으면 슬래시를 안넣어도됨
                    path: 'two',
                    builder:(_,state) => TwoScreen(),
                    routes: [
                      GoRoute(
                        //http://....../one/two/three 위의 페이지들이 다 깔림
                        //라우트안에 라우트를 넣으면 슬래시를 안넣어도됨
                        //name으로 이름으로 이동 가능 중복x
                        name: ThreeScreen.routename,
                        path: 'three',
                        builder:(_,state) => ThreeScreen(),
                      )
                    ]
                )
              ]
          ),
          GoRoute(path: '/login',builder: (_,state)=>LoginScreen())
        ]
    ),
    //http://...../three -> 깔리지 않고 독립적으로 존재
    GoRoute(
      path: '/three',
      builder:(_,state) => ThreeScreen(),
    )
  ];
}

final userProvider = StateNotifierProvider<UserStateNotifier,UserModel?>(
        (ref) => UserStateNotifier()
);

//로그인한 상태면 UserModel 인스턴스 상태로 넣어주기
//로그아웃 상태면 null 상태로 넣어주기
class UserStateNotifier extends StateNotifier<UserModel?>{
  UserStateNotifier(): super(null);

  login({
    required String name
  }){
    state = UserModel(name: name);
  }

  logout(){
    state = null;
  }
}

flutter 하이브리드-앱

답변 1

0

코드팩토리

안녕하세요!

에러를 함께 첨부해주시면 감사하겠습니다!

Isar 마지막 업데이트는 2년전입니다.

0

31

0

FlutterSecureStorage 질문

0

32

0

Dio onError Interceptor 만드는 부분에 질문이 있습니다.

0

80

2

관리자 기능에 대한 질문

0

100

2

part 'restaurant_model.g.dart';

0

92

1

36강. dio 인터셉터에 storage를 전달하는 코드가 이해 안되는데요. 도움 부탁드립니다.

0

56

2

2번 반환 상황 관련 질문

0

61

2

riverpod 3.0

0

140

2

Asset folder??

0

83

2

디자이너와 협업 시 프레임 크기 설정 관련 질문

0

114

2

FutureProvider, StateNotifierProvider 선택 기준

0

70

2

컴포넌트 모델화

0

64

2

쿼리 파라미터

0

84

2

화면 안보임

0

68

2

PaginationListView

0

54

1

강의중 37.Dio onErrorInterceptor 작업하기 dio 관련 질문입니다.

0

103

2

프로토타입이미지

0

62

2

여러 객체를 상태 관리하는 방법에 대한 질문

0

85

2

장바구니 결제하기 응답이 500이 옵니다.

0

105

2

removeFromBasket에서 await patchBasket()을 마지막에 하면 에러나는거 아닌가요?

0

67

2

이 두가지는 완전히 동일한 기능인가요?

0

106

3

내부 코드를 작성하지 않은 CursorPaginationLoading가 어떻게 로딩상태를 갖는지 잘 모르겠습니다...

0

77

2

_SplashScreenState에서 storage를 late로 호출해서 한번만 불러와도 되나요?

0

86

2

코딩 작성 순서 관련 질문

0

88

2