Ajax 提交POST后,后台php 无法获取$POST值

当 contentType 为 application/x-www-form-urlencoded 时(默认值)
才能用 $_POST 得到传入的数据。但是使用 application/json;charset=utf-8
不是 php 所能识别的类型声明,不能替你解析。所以只能用 php://input 取得,并用 parse_str 自行解析

而形如 a=1&b=2&c=3 这样的数据,分明就不是 json 格式。即便 php 能识别 application/json 类型,也不能解析你这样的数据。

当然还有一种方式:

前台(部分):

$.ajax({
url:’http://127.0.0.1/dist/example/qian.php’,
type:’POST’,
contentType:’application/json;charset=utf-8′,
dataType:’json’,
data: JSON.stringify({images:”dadad”}),

 

后台(部分):

header(‘Content-type: application/json’);

$data = json_decode(file_get_contents(“php://input”), true);
$user = $data[“images”];

安装和激活谷歌访问助手

  1. 下载访问助手
  2. 下载谷歌浏览器Chrome
  3. 打开谷歌浏览器,点击右上角设置,然后打开更多工具,找到并点击打开扩展程序
  4. 打开刚才下载的.rar的文件,解压。打开Chrome浏览器的扩展程序管理界面,勾选开发者模式,点击“加载已解压的扩展程序”按钮,选择已解压的Chrome插件文件夹。
  5. 点击确认,Chrome插件便成功加载到Google Chrome中啦。

flutter findAncestorStateOfType错误

The method ‘findAncestorStateOfType’ was called on null. Receiver: null Tried calling: findAncestorStateOfType<NavigatorState>()

出现上述错误的情况是由一个对话框需要导航到另外一个页面出现的,最后修复了,是没有导入BuildContext所致。

Flutter List.map()时获取索引值index

list =
List songListByUser = [
  {“score”: “A-“, “歌名”: “童年”, ‘id’: 1},
  {“score”: “C+”, “歌名”: “之乎者也”, ‘id’: 2},
  {“score”: “B+”, “歌名”: “野百合春天”, ‘id’: 3},
  {“score”: “D+”, “歌名”: “恋曲1990”, ‘id’: 4},
  {“score”: “D+”, “歌名”: “恋曲”, ‘id’: 5},
  {“score”: “B-“, “歌名”: “歌”, ‘id’: 6},
];
    return list
        .asMap()
        .keys
        .map((value) => ListTile(
              leading: Icon(
                Icons.music_note,
                color: Colors.green,
              ),
              trailing: Icon(Icons.keyboard_arrow_right),
              title: Text(list[value][‘歌名’].toString()),
              onTap: () {
                var mapstr = json.encode(list[value]).toString();
              },
            ))
        .toList();

Flutter 动态更新CircleAvatar的图片

CircleAvatar有一个参数是 backgroundImage, 它是一个Imageprovider. 通过选择手机图片或者拍照后,获取到的是一个PickedFile , 我用的是
image_picker: ^0.6.7+17插件
PickedFile _imageFile;
    ImagePicker imagePicker = ImagePicker();
    var image = await imagePicker.getImage(source: imageSource);
    setState(() {
      _imageFile = image;
      _avatarImage = File(image.path);
    });
定义一个文件类型的变量_avatarImage, 然后通过Image.file(_avatarImage).image 赋值给backgroundImage就行了。AssetImage(“assets/images/cat.jpg”)是默认值。
File _avatarImage;
backgroundImage: _avatarImage == null
                      ? AssetImage(“assets/images/cat.jpg”)
                      : Image.file(_avatarImage).image,

Flutter 如何将方法当做一个变量传递

如下所示,其中action 就是函数,写成void Function() action, 其它地方调用的时候就 tapBlueText(“文本”, action), action这里不用括号 action().

Widget tapBlueText(String text, void Function() action) {
    return GestureDetector(
      onTap: action,
      child: Text(
        text
      ),
    );
  }

Flutter List 或Map数据转ListView

数据清单如下:
List songListByUser = [
  {“score”: “A-“, “歌名”: “童年”, ‘id’: 1},
  {“score”: “C+”, “歌名”: “之乎者也”, ‘id’: 2},
  {“score”: “B+”, “歌名”: “野百合春天”, ‘id’: 3},
  {“score”: “D+”, “歌名”: “恋曲1990”, ‘id’: 4},
  {“score”: “D+”, “歌名”: “恋曲”, ‘id’: 5},
  {“score”: “B-“, “歌名”: “歌”, ‘id’: 6},
];
返回为List<Widget>
List<Widget> _listViewByUser() {
  return songListByUser
      .map((f) => ListTile(
            leading: Icon(
              Icons.music_note,
              color: Colors.green,
            ),
            trailing: Icon(Icons.keyboard_arrow_right),
            title: Text(f[‘歌名’].toString() + ‘(‘ + f[‘score’].toString() + ‘)’),
            onTap: () => print(f[‘id’].toString()),
          ))
      .toList();
}
在需要使用的地方
 children: _listViewByUser(),

Win10 下ogg文件改名很卡的解决办法

用dos命令来改名或者删除即可。

1. CMD 命令打开Dos窗口,

2. cd 到该文件的目录,例如到c:\music

cd c:\music

3. 删除文件就是 del 文件名称,比如删除1.ogg的文件就是

del 1.ogg

4. 如果想把1.ogg改成2.ogg 就是这样

rename 1.ogg 2.ogg 就行了

Flutter 播放本地音乐并实现暂停,停止功能

用audioplayers插件播放本地音乐总是出错,查到可以使用AudioCache播放,但是又没有了停止和暂停功能,尝试了一下,用以下办法实现

AudioPlayer _audioPlayer;
AudioCache _audioCache;
    mode = PlayerMode.MEDIA_PLAYER;
    _audioPlayer = AudioPlayer(mode: mode);
    _audioCache = AudioCache(prefix: ‘audio/’);
//关键的一句在这里
_audioCache.fixedPlayer = _audioPlayer;
//播放的时候用_audioCache.play.
void _cacheplay() async {
    final result = await _audioCache.play(‘pfzl.mp3’, isNotification: true);
    if (result == 1) {
      print(‘succes’);
    }
  }
//暂停和停止是用_audioPlayer来实现
//暂停
  void _pause() async {
    final result = await _audioPlayer.pause();
    if (result == 1) {
      print(‘succes’);
    }
  }
  //停止播放
  _stop() async {
    final result = await _audioPlayer.stop();
    if (result == 1) {
      setState(() {
        _position = Duration();
      });
    }
  }

Flutter 如何读取原生的SharePreferences

Flutter 有个插件可以进行这个操作,插件地址,但是有两个地方需要注意:

  1. Android 代码写SharePreferences的时候是需要定义文件名称的。比如下面代码就是保存一个布尔值,而对于Flutter的这个插件,名称必须是FlutterSharedPreferences
    SharedPreferences sharedPreferences= mContext.getSharedPreferences("FlutterSharedPreferences",Context.MODE_PRIVATE);
    //步骤2: 实例化SharedPreferences.Editor对象
    SharedPreferences.Editor editor = sharedPreferences.edit();
    //步骤3:将获取过来的值放入文
    editor.putBoolean("flutter.connected",isON);
    //步骤4:提交
    editor.commit();

    2. 在Android 的代码里面,如果要写入键值,名称的前面必须加上”flutter.”,比如键值是connected,就需要写成flutter.connected.

在Android的原生代码里面进行如上操作后,flutter里面就可以正常的进行读取和保存了。第一,不需要文件名称,第二不需要再加flutter.