Необработанное исключение Flutter device_info device_info: исключение MissingPluginException

#android #flutter #package

#Android #сбой #пакет

Вопрос:

Я пытаюсь получить доступ к информации об устройстве в приложении Flutter. На iOS но есть ошибка на Android .

Я добавил его в pubspec.yaml файл в разделе зависимости:

 device_info: ^0.4.2 6
  

и это код:

 var deviceInfo = DeviceInfoPlugin();
if (Platform.isIOS) {
  IosDeviceInfo iosDeviceInfo = await deviceInfo.iosInfo;
} else {
  AndroidDeviceInfo androidDeviceInfo = await deviceInfo.androidInfo;
}
  

При вызове возникает исключение deviceInfo.androidInfo :

 Unhandled Exception: MissingPluginException(No implementation found for method getAndroidDeviceInfo on channel plugins.flutter.io/device_info)
  

Я попытался запустить flutter clean и удалить приложение с устройства и установить его снова, но оно по-прежнему не работает.

Результат выполнения flutter doctor :

 Flutter (Channel master, 1.21.0-10.0.pre.115)
  

Я переключился на стабильный канал:

 Flutter (Channel stable, 1.20.2, ... )
  

но ошибка все еще происходит!!

Есть предложения?!

Комментарии:

1. Можете ли вы запустить flutter doctor?

2. @LapaNyAinaTanjonaRAZAFINAH Я запускаю его, и, кажется, все правильно!!

3. Вы использовали стабильный канал?

4. @LapaNyAinaTanjonaRAZAFINAH какой канал является стабильным? Извините, но я новичок в flutter

5. Можете ли вы отредактировать свой вопрос и отобразить выходные данные flutter doctor? Я имею в виду, является ли flutter стабильным каналом или нет.

Ответ №1:

Попробуйте приведенный ниже пример для справки.

Перед этим используйте device_info: пакет ^ 0.4.0 4 в файле pubspec.yaml.

 import 'dart:async';

import 'dart:io';
import 'package:flutter/material.dart';
import 'package:flutter/services.dart';
import 'package:device_info/device_info.dart';

void main() {
  runZoned(() {
    runApp(MyApp());
  }, onError: (dynamic error, dynamic stack) {
    print(error);
    print(stack);
  });
}

class MyApp extends StatefulWidget {
  @override
  _MyAppState createState() => _MyAppState();
}

class _MyAppState extends State<MyApp> {
  static final DeviceInfoPlugin deviceInfoPlugin = DeviceInfoPlugin();
  Map<String, dynamic> _deviceData = <String, dynamic>{};

  @override
  void initState() {
    super.initState();
    initPlatformState();
  }

  Future<void> initPlatformState() async {
    Map<String, dynamic> deviceData;

    try {
      if (Platform.isAndroid) {
        deviceData = _readAndroidBuildData(await deviceInfoPlugin.androidInfo);
      } else if (Platform.isIOS) {
        deviceData = _readIosDeviceInfo(await deviceInfoPlugin.iosInfo);
      }
    } on PlatformException {
      deviceData = <String, dynamic>{
        'Error:': 'Failed to get platform version.'
      };
    }

    if (!mounted) return;

    setState(() {
      _deviceData = deviceData;
    });
  }

  Map<String, dynamic> _readAndroidBuildData(AndroidDeviceInfo build) {
    return <String, dynamic>{
      'version.securityPatch': build.version.securityPatch,
      'version.sdkInt': build.version.sdkInt,
      'version.release': build.version.release,
      'version.previewSdkInt': build.version.previewSdkInt,
      'version.incremental': build.version.incremental,
      'version.codename': build.version.codename,
      'version.baseOS': build.version.baseOS,
      'board': build.board,
      'bootloader': build.bootloader,
      'brand': build.brand,
      'device': build.device,
      'display': build.display,
      'fingerprint': build.fingerprint,
      'hardware': build.hardware,
      'host': build.host,
      'id': build.id,
      'manufacturer': build.manufacturer,
      'model': build.model,
      'product': build.product,
      'supported32BitAbis': build.supported32BitAbis,
      'supported64BitAbis': build.supported64BitAbis,
      'supportedAbis': build.supportedAbis,
      'tags': build.tags,
      'type': build.type,
      'isPhysicalDevice': build.isPhysicalDevice,
      'androidId': build.androidId,
      //'systemFeatures': build.systemFeatures,
    };
  }

  Map<String, dynamic> _readIosDeviceInfo(IosDeviceInfo data) {
    return <String, dynamic>{
      'name': data.name,
      'systemName': data.systemName,
      'systemVersion': data.systemVersion,
      'model': data.model,
      'localizedModel': data.localizedModel,
      'identifierForVendor': data.identifierForVendor,
      'isPhysicalDevice': data.isPhysicalDevice,
      'utsname.sysname:': data.utsname.sysname,
      'utsname.nodename:': data.utsname.nodename,
      'utsname.release:': data.utsname.release,
      'utsname.version:': data.utsname.version,
      'utsname.machine:': data.utsname.machine,
    };
  }

  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      home: Scaffold(
        appBar: AppBar(
          title: Text(
              Platform.isAndroid ? 'Android Device Info' : 'iOS Device Info'),
        ),
        body: ListView(
          children: _deviceData.keys.map((String property) {
            return Row(
              children: <Widget>[
                Container(
                  padding: const EdgeInsets.all(10.0),
                  child: Text(
                    property,
                    style: const TextStyle(
                      fontWeight: FontWeight.bold,
                    ),
                  ),
                ),
                Expanded(
                    child: Container(
                      padding: const EdgeInsets.fromLTRB(0.0, 10.0, 0.0, 10.0),
                      child: Text(
                        '${_deviceData[property]}',
                        maxLines: 10,
                        overflow: TextOverflow.ellipsis,
                      ),
                    )),
              ],
            );
          }).toList(),
        ),
      ),
    );
  }
}
  

Ответ №2:

Я исправил это, приведя пример ниже

 flutter clean
flutter pub get
flutter run
  

Ответ №3:

Вам нужно оценить устройство.

 DeviceInfoPlugin deviceInfo = DeviceInfoPlugin();
if (Platform.isAndroid) {
  AndroidDeviceInfo androidInfo = await deviceInfo.androidInfo;
} else if (Platform.isIOS) {
  IosDeviceInfo iosInfo = await deviceInfo.iosInfo;
}
  

Комментарии:

1. Я уже это делаю. Я просто удалил его в вопросе для простоты.

Ответ №4:

Не могли бы вы, пожалуйста, ввести весь исходный код, который вы используете? Потому что я протестировал библиотеку на своем Android 9, и она работает просто отлично.

Попробуйте этот исходный код, и он должен работать.

 DeviceInfoPlugin deviceInfo = DeviceInfoPlugin();
if (Platform.isAndroid) {
    AndroidDeviceInfo androidInfo = await deviceInfo.androidInfo;
    print('Running on ${androidInfo.model}'); // e.g. "Moto G (4)"
} else {
    IosDeviceInfo iosInfo = await deviceInfo.iosInfo;
    print('Running on ${iosInfo.utsname.machine}'); // e.g. "iPod7,1"
}
  

Я должен также указать, что если у вас возникли какие-либо проблемы с любыми плагинами flutter или с самим flutter, лучше всего создать проблему в их репозитории:

https://github.com/flutter/plugins

Ответ №5:

После некоторой борьбы я обнаружил, что причина этой проблемы была из MethodChannel . В MainActivity.java файле я определяю канал метода:

 _methodChannel = new MethodChannel(getFlutterView(), "myChannelName");
  

После замены getFlutterView() на getFlutterEngine().getDartExecutor().getBinaryMessenger() все работает нормально.

На самом деле я не знаю связи между ними, но это то, что произошло.