使用package path_provider软件包后Flutter应用程序崩溃,如何在Flutter中修复它?

时间:2020-09-03 17:09:59

标签: flutter dart

我一直在尝试使用json制作一个离线应用程序,以便在本地存储。我使用了一个软件包path_provider来获取当前目录应用apk。这是代码:-

import 'package:flutter/cupertino.dart';
import 'package:flutter/material.dart';
import 'dart:io';
import 'dart:convert';

import 'package:path_provider/path_provider.dart';

class WorkersLog extends StatefulWidget {
  @override
  _WorkersLogState createState() => _WorkersLogState();
}

class _WorkersLogState extends State<WorkersLog> {
  @override
  Widget build(BuildContext context) {
    void _showSettingsPanel() {
      showModalBottomSheet(
          isScrollControlled: true,
          context: context,
          builder: (context) {
            return Container(
              height: MediaQuery.of(context).size.height * .90,
              padding: EdgeInsets.symmetric(vertical: 20.0, horizontal: 40.0),
              child: Center(child: WorkerCardData()),
            );
          });
    }

    return Container(
      child: Column(
        children: [
          SizedBox(height: 40),
          Text(
              "hello there"),
          Row(
            children: <Widget>[
              Center(
                child: Column(
                  children: [
                    SizedBox(height: 370),
                    Row(
                      children: [
                        SizedBox(width: 200),
                        FloatingActionButton.extended(
                          label: Text('add document'),
                          icon: Icon(Icons.save),
                          backgroundColor: Colors.greenAccent,
                          elevation: 5.0,
                          onPressed: () {
                            print('object');
                            _showSettingsPanel();
                          },
                        ),
                      ],
                    ),
                  ],
                ),
              ),
            ],
          ),
        ],
      ),
    );
  }
}

class WorkerCardData extends StatefulWidget {
  @override
  _WorkerCardDataState createState() => _WorkerCardDataState();
}

class _WorkerCardDataState extends State<WorkerCardData> {
  TextEditingController keyInputController = new TextEditingController();
  TextEditingController valueInputController = new TextEditingController();

  File jsonFile;
  Directory dir;
  String fileName = "myFile.json";
  bool fileExists = false;
  Map<String, dynamic> fileContent;

  @override
  void initState() {
    super.initState();
    getApplicationDocumentsDirectory().then((Directory directory) {
      dir = directory;
      jsonFile = new File(dir.path + "/" + fileName);
      fileExists = jsonFile.existsSync();
      if (fileExists)
        this.setState(
            () => fileContent = json.decode(jsonFile.readAsStringSync()));
    });
  }

  @override
  void dispose() {
    keyInputController.dispose();
    valueInputController.dispose();
    super.dispose();
  }

  void createFile(
      Map<String, dynamic> content, Directory dir, String fileName) {
    print("Creating file!");
    File file = new File(dir.path + "/" + fileName);
    file.createSync();
    fileExists = true;
    file.writeAsStringSync(json.encode(content));
  }

  void writeToFile(String key, dynamic value) {
    print("Writing to file!");
    Map<String, dynamic> content = {key: value};
    if (fileExists) {
      print("File exists");
      Map<String, dynamic> jsonFileContent =
          json.decode(jsonFile.readAsStringSync());
      jsonFileContent.addAll(content);
      jsonFile.writeAsStringSync(json.encode(jsonFileContent));
    } else {
      print("File does not exist!");
      createFile(content, dir, fileName);
    }
    this.setState(() => fileContent = json.decode(jsonFile.readAsStringSync()));
    print(fileContent);
  }

  @override
  Widget build(BuildContext context) {
    return Container(
      child: Column(
        children: [
          new Padding(padding: new EdgeInsets.only(top: 10.0)),
          new Text(
            "File content: ",
            style: new TextStyle(fontWeight: FontWeight.bold),
          ),
          new Text(fileContent.toString()),
          new Padding(padding: new EdgeInsets.only(top: 10.0)),
          new Text("Add to JSON file: "),
          new TextField(
            controller: keyInputController,
          ),
          new TextField(
            controller: valueInputController,
          ),
          new Padding(padding: new EdgeInsets.only(top: 20.0)),
          new RaisedButton(
            child: new Text("Add key, value pair"),
            onPressed: () =>
                writeToFile(keyInputController.text, valueInputController.text),
          )
        ],
      ),
    );
  }
}

但是该应用一旦启动就会崩溃。这是在调试控制台中编写的内容:-


registerResGeneratingTask is deprecated, use registerGeneratedResFolders(FileCollection)
registerResGeneratingTask is deprecated, use registerGeneratedResFolders(FileCollection)
registerResGeneratingTask is deprecated, use registerGeneratedResFolders(FileCollection)
✓ Built build\app\outputs\flutter-apk\app-debug.apk.
E/AndroidRuntime(10874): FATAL EXCEPTION: main
E/AndroidRuntime(10874): Process: com.illuminate.comcrop, PID: 10874
E/AndroidRuntime(10874): java.lang.NoClassDefFoundError: Failed resolution of: Lcom/google/android/gms/common/internal/Preconditions;
E/AndroidRuntime(10874):    at com.google.firebase.provider.FirebaseInitProvider.checkContentProviderAuthority(com.google.firebase:firebase-common@@19.3.0:64)
E/AndroidRuntime(10874):    at com.google.firebase.provider.FirebaseInitProvider.attachInfo(com.google.firebase:firebase-common@@19.3.0:44)
E/AndroidRuntime(10874):    at android.app.ActivityThread.installProvider(ActivityThread.java:7545)
E/AndroidRuntime(10874):    at android.app.ActivityThread.installContentProviders(ActivityThread.java:7090)
E/AndroidRuntime(10874):    at android.app.ActivityThread.handleBindApplication(ActivityThread.java:6978)
E/AndroidRuntime(10874):    at android.app.ActivityThread.access$1300(ActivityThread.java:270)
E/AndroidRuntime(10874):    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2051)

为什么会导致错误?如何解决?

我没有使用Java或android的经验,因此如果从Flutter编码的角度讲解答案,将会很有帮助。

0 个答案:

没有答案