React Native: Ошибка аутентификации клерка: недопустимая длина строки в кодировке Base64

Я не знаю, почему я получаю эту ошибку, когда открываю свое собственное выставочное приложение, оно выдавало ошибку типа: Ошибка: недопустимая длина строки в кодировке Base64.

Эта ошибка находится по адресу: в ClerkProvider (созданный RootLayout) в РутЛайауте...

мой _layout.js для настройки клерка:

import React, { useEffect } from "react";
import { SplashScreen, Stack, useRouter, useSegments } from "expo-router";
import { useFonts } from "expo-font";
import { ClerkProvider, useAuth } from "@clerk/clerk-expo";
import * as SecureStore from "expo-secure-store";
import Toast from "react-native-toast-message";
import { TouchableOpacity } from "react-native";
import { Ionicons } from "@expo/vector-icons";
SplashScreen.preventAutoHideAsync();
const RootLayout = () => {
  const [fontsLoaded, error] = useFonts({
    "Poppins-Black": require("../assets/fonts/Poppins-Black.ttf"),
    "Poppins-Bold": require("../assets/fonts/Poppins-Bold.ttf"),
    "Poppins-ExtraBold": require("../assets/fonts/Poppins-ExtraBold.ttf"),
    "Poppins-ExtraLight": require("../assets/fonts/Poppins-ExtraLight.ttf"),
    "Poppins-Light": require("../assets/fonts/Poppins-Light.ttf"),
    "Poppins-Medium": require("../assets/fonts/Poppins-Medium.ttf"),
    "Poppins-Regular": require("../assets/fonts/Poppins-Regular.ttf"),
    "Poppins-SemiBold": require("../assets/fonts/Poppins-SemiBold.ttf"),
    "Poppins-Thin": require("../assets/fonts/Poppins-Thin.ttf"),
  });
  useEffect(() => {
    if (error) throw error;

    if (fontsLoaded) {
      SplashScreen.hideAsync();
    }
  }, [fontsLoaded, error]);

  if (!fontsLoaded && !error) {
    return null;
  }
  const tokenCache = {
    async getToken(key) {
      try {
        return SecureStore.getItemAsync(key);
      } catch (err) {
        return null;
      }
    },
    async saveToken(key, value) {
      try {
        return SecureStore.setItemAsync(key, value);
      } catch (err) {
        return;
      }
    },
  };
  const EXPO_PUBLIC_CLERK_PUBLISHABLE_KEY =
    process.env.EXPO_PUBLIC_CLERK_PUBLISHABLE_KEY;
  const InitialLayout = () => {
    const { isLoaded, isSignedIn } = useAuth();
    const segments = useSegments();
    const router = useRouter();

    useEffect(() => {
      console.info("IsSignedIn", isSignedIn);

      if (isLoaded && !isSignedIn) {
        router.push("/(modals)/login");
      }
    }, [isLoaded]);
    return (
      <Stack>
        <Stack.Screen name = "index" options = {{ headerShown: false }} />
        <Stack.Screen name = "(tabs)" options = {{ headerShown: false }} />
        <Stack.Screen
          name = "(modals)/login"
          options = {{
            presentation: "modal",
            title: "Log in or Sign up",
            headerTitleAlign: "center",
            headerTitleStyle: {
              fontFamily: "Poppins-Bold",
            },

            headerLeft: () => (
              <TouchableOpacity
                onPress = {() => {
                  router.back();
                }}
              >
                <Ionicons name = "close-outline" size = {28} />
              </TouchableOpacity>
            ),
          }}
        />
        <Stack.Screen
          name = "(modals)/search"
          options = {{
            presentation: "modal",
            title: "Search input goes here...",
            headerTitleAlign: "center",
            headerTitleStyle: {
              fontFamily: "Poppins-Bold",
            },
            headerLeft: () => (
              <TouchableOpacity
                onPress = {() => {
                  router.back();
                }}
              >
                <Ionicons name = "close-outline" size = {28} />
              </TouchableOpacity>
            ),
          }}
        />
      </Stack>
    );
  };
  return (
    <ClerkProvider
      publishableKey = {EXPO_PUBLIC_CLERK_PUBLISHABLE_KEY}
      tokenCache = {tokenCache}
    >
      <InitialLayout />
      <Toast />
    </ClerkProvider>
  );
};

export default RootLayout;
 

мой пакет.json:

{
  "name": "hair-oil-app",
  "version": "1.0.0",
  "main": "expo-router/entry",
  "scripts": {
    "start": "expo start",
    "android": "expo start --android",
    "ios": "expo start --ios",
    "web": "expo start --web"
  },
  "dependencies": {
    "@clerk/clerk-expo": "^1.0.0",
    "@types/react": "~18.2.45",
    "axios": "^1.7.2",
    "date-fns": "^3.6.0",
    "expo": "^51.0.7",
    "expo-constants": "^16.0.1",
    "expo-linking": "^6.3.1",
    "expo-router": "^3.5.14",
    "expo-secure-store": "^13.0.1",
    "expo-status-bar": "^1.12.1",
    "mongoose": "^8.3.2",
    "nativewind": "^2.0.11",
    "prop-types": "^15.8.1",
    "react": "18.2.0",
    "react-dom": "18.2.0",
    "react-native": "^0.74.1",
    "react-native-element-dropdown": "^2.12.0",
    "react-native-gesture-handler": "^2.16.2",
    "react-native-loading-spinner-overlay": "^3.0.1",
    "react-native-pager-view": "^6.3.0",
    "react-native-ratings": "^8.1.0",
    "react-native-reanimated": "^3.10.1",
    "react-native-safe-area-context": "^4.10.1",
    "react-native-screens": "^3.31.1",
    "react-native-snap-carousel": "^3.9.1",
    "react-native-star-rating-widget": "^1.7.3",
    "react-native-toast-message": "^2.2.0",
    "react-native-web": "~0.19.6",
    "tailwind-rn": "^4.2.0",
    "zustand": "^4.5.2"
  },
  "devDependencies": {
    "@babel/core": "^7.20.0",
    "tailwindcss": "^3.3.2"
  },
  "private": true
}

ПОСКОЛЬКУ Я НОВИЧОК, ЕСЛИ ВЫ СЧИТАЕТЕ ЭТО ТУПОЙ, ПОЖАЛУЙСТА, ОСТАВЬТЕ ЭТО И СПАСИБО.

Хочу избавиться от этой глупой ошибки, так как занимаюсь ею уже 1 неделю. пожалуйста.

🤔 А знаете ли вы, что...
React DevTools - это расширение для браузера, облегчающее отладку приложений React.


140
2

Ответы:

Решено

Решение — перейти на более новую версию Clerk. Это то, что сработало для меня.


Судя по предоставленному вами сообщению об ошибке и трассировке стека, похоже, что вы столкнулись с проблемой интеграции Clerk в ваше приложение React Native с использованием Expo. Эта ошибка конкретно связана с компонентом ClerkProvider. Установите [email protected].