AndroidStudio安装了flutter插件,但是flutter doctor识别不到的问题解决

Stella981
• 阅读 1427

最近在配置flutter开发环境的时候,出现了很多问题。

我是下载的 flutter源码 ,切换到了stable 分支,当前版本号为 1.22.6Android Studio 版本为最新的稳定版 4.1.2

问题1

明明安装了android studio,但是 flutter doctor 一直显示 Android Studio 没有安装

[!] Android Studio (not installed)

使用如下命令设置一下即可解决

flutter config --android-studio-dir=$your-android-studio-directory

通过后文的分析,发现flutterlinux环境下默认搜索如下路径

  • ~/AndroidStudio{major.minor}/system/.home (major.minor表示版本号,例如4.1, 3.3等)
  • /opt/android-studio
  • ~/android-studio

如果不是这几个默认安装路径,那就需要手动设置 android-studio-dir

问题2

明明安装了 flutter和dart 插件,但是 flutter doctor 命令一直提示检测不到这两个插件,google搜了一下,没有任何能解决这个问题的方案,好在有源码,那我们就能自己解决了。

[!] Android Studio
    ✗ Flutter plugin not installed; this adds Flutter specific functionality.
    ✗ Dart plugin not installed; this adds Dart specific functionality.

以前从来没看过flutter的代码,我们如何开始呢?先看错误提示,于是我们可以根据错误提示的字符串来进行搜索,根据编程经验插件名称肯定是动态写入的,于是我们试试搜索 plugin not installed

@debian-ts:~/tools/flutter$ rg 'plugin not installed'
packages/flutter_tools/lib/src/intellij/intellij.dart
44:        '$title plugin not installed; this adds $title specific functionality.'));

packages/flutter_tools/test/general.shard/intellij/intellij_test.dart
88:        expect(message.message, contains('Dart plugin not installed'));
92:        expect(message.message, contains('Flutter plugin not installed'));

搜到了两个文件,很明显逻辑应该是在 packages/flutter_tools/lib/src/intellij/intellij.dart 这个文件中,我们打开看一下,发现 validatePackage 函数是用来做插件检测的

void validatePackage(
  List<ValidationMessage> messages,
  List<String> packageNames,
  String title, {
  Version minVersion,
})

搜一下谁调用了这个函数

@debian-ts:~/tools/flutter$ rg validatePackage
packages/flutter_tools/lib/src/doctor.dart
749:      plugins.validatePackage(messages, <String>['flutter-intellij', 'flutter-intellij.jar'],
751:      plugins.validatePackage(messages, <String>['Dart'], 'Dart');

packages/flutter_tools/lib/src/android/android_studio_validator.dart
45:    plugins.validatePackage(
51:    plugins.validatePackage(messages, <String>['Dart'], 'Dart');

packages/flutter_tools/test/general.shard/intellij/intellij_test.dart
59:        plugins.validatePackage(messages, <String>['Dart'], 'Dart');
60:        plugins.validatePackage(messages,
81:        plugins.validatePackage(messages, <String>['Dart'], 'Dart');
82:        plugins.validatePackage(messages,

packages/flutter_tools/lib/src/intellij/intellij.dart
19:  void validatePackage(

很明显 packages/flutter_tools/lib/src/android/android_studio_validator.dart 这个文件中有相应的逻辑,打开文件一看发现逻辑非常清晰

final IntelliJPlugins plugins = IntelliJPlugins(_studio.pluginsPath);
  plugins.validatePackage(
  messages,
  <String>['flutter-intellij', 'flutter-intellij.jar'],
  'Flutter',
  minVersion: IntelliJPlugins.kMinFlutterPluginVersion,
);  
plugins.validatePackage(messages, <String>['Dart'], 'Dart');

插件的目录是 _studio.pluginsPath,我们先来调试一下,在上述部分代码前加入一行调试代码

print("****** ${_studio.pluginsPath}");

现在我们要重新编译flutter tool,然后看看这个 _studio.pluginsPath 到底是什么值,如何重新编译呢?只要删除 $flutter_sdk/bin/cache/flutter_tools.stamp 文件,再执行 flutter doctor 命令就能自动触发重新编译了。

@debian-ts:~/tools/flutter$ rm bin/cache/flutter_tools.stamp 
@debian-ts:~/tools/flutter$ flutter doctor
Building flutter tool...
Doctor summary (to see all details, run flutter doctor -v):
******~/.AndroidStudio0.0/config/plugins
[✓] Flutter (Channel stable, 1.22.6, on Linux, locale en_US.UTF-8)
[✓] Android toolchain - develop for Android devices (Android SDK version 30.0.3)
[!] Android Studio
    ✗ Flutter plugin not installed; this adds Flutter specific functionality.
    ✗ Dart plugin not installed; this adds Dart specific functionality.

看到结果真是大吃一惊,竟然是 ~/.AndroidStudio0.0/config/plugins,什么鬼!

既然知道了路径,那么第一种解决办法就产生了,在我使用的 debian buster 系统上,Android Studio 4.1.2 的插件安装目录为 ~/.local/share/Google/AndroidStudio4.1,我们创建一个指向这个地方的软链接即可。

解决方案1

@debian-ts:~/tools/flutter$ mkdir -p ~/.AndroidStudio0.0/config
@debian-ts:~/tools/flutter$ ln -s ~/.local/share/Google/AndroidStudio4.1 ~/.AndroidStudio0.0/config/plugins

创建软链接之后,执行 flutter doctor,果然没问题了。

很明显我们不能止步于此,这个方案是能解决问题,但是有点太奇怪了。那么我们继续分析,看样子是 flutter 没有识别到 android studio,跟第一个问题很像,第一个问题中我们必须用参数 --android-studio-dir 手动指定 android studio 的目录。 即使我们手动指定了安装目录,flutter知道android studio安装了,但是识别出来的版本号仍然是0.0,那是为什么呢?

还是老样子,从 --android-stdio-dir 选项来入手分析,我们搜索 android-studio-dir,查看读取的这个选项在哪个地方用到了,具体过程就不详述了。我们发现检测 android studio 的逻辑在 packages/flutter_tools/lib/src/android/android_studio.dart 文件中,

static List<AndroidStudio> allInstalled() =>
      globals.platform.isMacOS ? _allMacOS() : _allLinuxOrWindows();

检测插件的逻辑在 packages/flutter_tools/lib/src/intellij/intellij.dart 文件的 _hasPackage 方法中

bool _hasPackage(String packageName) {
  final String packagePath = globals.fs.path.join(pluginsPath, packageName);
  if (packageName.endsWith('.jar')) {
    return globals.fs.isFileSync(packagePath);
  }   
  return globals.fs.isDirectorySync(packagePath);
}

pluginsPath 的获取在 packages/flutter_tools/lib/src/android/android_studio.dart 中,最终发现,总之这个插件路径的判断逻辑漏洞很多。再查看一下 master 上的最新代码,看看官方是否有改进,发现没什么改进,但是官方改变了 flutter doctor的输出,在 master 的版本上,根本就不会提示插件未安装的警告。所以我们得到第二个解决办法

解决方案2

直接忽略 flutter doctor 的未安装flutterdart插件的警告,没什么用,只要你的 Android Studio确实安装了能正常开发即可。

问题3

正常创建了flutter application,在命令行执行 flutter run 没有任何问题, Android Studio 能看到手机设备已经连接,但是选择不了。

AndroidStudio安装了flutter插件,但是flutter doctor识别不到的问题解决

这个问题就没有办法解决了,很愁人,有知道的大佬望不吝赐教。照理说都是稳定版,不应该这么多坑呀。

点赞
收藏
评论区
推荐文章
blmius blmius
2年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
Jacquelyn38 Jacquelyn38
2年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
Stella981 Stella981
2年前
KVM调整cpu和内存
一.修改kvm虚拟机的配置1、virsheditcentos7找到“memory”和“vcpu”标签,将<namecentos7</name<uuid2220a6d1a36a4fbb8523e078b3dfe795</uuid
Wesley13 Wesley13
2年前
mysql设置时区
mysql设置时区mysql\_query("SETtime\_zone'8:00'")ordie('时区设置失败,请联系管理员!');中国在东8区所以加8方法二:selectcount(user\_id)asdevice,CONVERT\_TZ(FROM\_UNIXTIME(reg\_time),'08:00','0
Wesley13 Wesley13
2年前
Java日期时间API系列36
  十二时辰,古代劳动人民把一昼夜划分成十二个时段,每一个时段叫一个时辰。二十四小时和十二时辰对照表:时辰时间24时制子时深夜11:00凌晨01:0023:0001:00丑时上午01:00上午03:0001:0003:00寅时上午03:00上午0
Wesley13 Wesley13
2年前
00:Java简单了解
浅谈Java之概述Java是SUN(StanfordUniversityNetwork),斯坦福大学网络公司)1995年推出的一门高级编程语言。Java是一种面向Internet的编程语言。随着Java技术在web方面的不断成熟,已经成为Web应用程序的首选开发语言。Java是简单易学,完全面向对象,安全可靠,与平台无关的编程语言。
Stella981 Stella981
2年前
Django中Admin中的一些参数配置
设置在列表中显示的字段,id为django模型默认的主键list_display('id','name','sex','profession','email','qq','phone','status','create_time')设置在列表可编辑字段list_editable
Wesley13 Wesley13
2年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
Python进阶者 Python进阶者
3个月前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这