小菜搭建了几个基本的小页面,现在需要添加其中的业务逻辑,这就必不可少的用到网络请求;Flutter 中提供了 dart.io 方式进行网络请求,不管是从请求方式还是实例都讲解的很清楚,使用方式也很简单。但是小菜在看大神们写的案例中很多直接用到了 Dart 中常用的原生 http 请求,小菜也尝试了一下。
集成应用
添加依赖,在 pubspec.yaml 中添加 http 依赖 http: ^0.11.3+17,之后 package get 同步;
在具体的 dart 文件中引入 http;import 'package:http/http.dart' as http; 这种写法很有意思,在 import 时直接定义为 as http,之后在文件中可以用 http 来操作,当然定义为其他名称也是可以的;
http 请求操作,日常应用最多的为 post/get 请求,post 请求中需要传参 url 和 body(键值对),通过 then 方式接收返回内容;get 请求中主要传入 url 参数,同时也可以传入请求头标题等 Accept,同样通过 then 方法接收返回内容;小菜测试 read 请求方式与 get 方式基本一致,只是对返回内容操作不同,get 的返回的全部内容包括状态值和数据内容,而 read 返回的内容直接为数据内容,小菜以为 read 方式更适合请求文件内容方式。
POST 请求
var url = "https://example.com/api/login?"; http.post(url, body: {'password':'e10adc3949ba59abbe56e057f20f883e', 'mobile':'13333333333'}) .then((response) { print("post方式->status: ${response.statusCode}"); print("post方式->body: ${response.body}"); } );
http -> post
GET 请求
http.get('https://example/getUserBaseInfo?sid=cs&user=13333333333') .then((onValue) { print("get方式->status: ${onValue.statusCode}"); print("get方式->body: ${onValue.body}"); } );
http -> get
READ 请求
http.read('https://example/getUserBaseInfo?sid=cs&user=13333333333'),headers: {"Accept": "application/json"}) .then((onValue) { print("read方式->$onValue"); });
http -> read
异步处理
涉及到网络请求,就必不可少的需要异步处理,Flutter 提供了便利的异步操作方法 async + await;将耗时的不需要长时运算的方法先执行,之后在执行 await 中耗时操作;小菜建议在使用 async 和 await 方式时,要成对出现,await 执行在 async 方法内。
login() async { await http.post(url, body: {'password':'e10adc3949ba59abbe56e057f20f883e', 'mobile':'13333333333'}) .then((response) { print("post方式->status: ${response.statusCode}"); print("post方式->body: ${response.body}"); } ); } // 调用登录方法 login();
测试源码
login() async { await http.post('https://example.com/api/login?', body: { 'password': 'e10adc3949ba59abbe56e057f20f883e', 'mobile': _phonecontroller.text }).then((response) { if (response.statusCode == 200) { router.navigateTo(context, '/home/${response.body}'); } else { showDialog<Null>( context: context, barrierDismissible: false, child: new AlertDialog( title: new Text( '温馨提示', style: new TextStyle( color: Colors.black54, fontSize: 18.0, ), ), content: new Text('您输入的用户名密码不存在!'), actions: <Widget>[ new FlatButton( onPressed: () { Navigator.pop(context); }, child: new Text('确定')), ], ), ); } }); } onTap() { login(); }
小菜刚接触 Flutter 时间不长,还有很多不清楚和不理解的地方,如果又不对的地方还希望多多指出。
作者:阿策神奇