Flutter开发 网络请求

HttpClient(dart自有)

1.get

点击请求按钮获取数据,解析数据获取单词展示到屏幕上。

dart 复制代码
class MyState extends State {
  String info = "暂无数据";

  List<Widget> texts = [];

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

  @override
  Widget build(BuildContext context) {

    void parseJson(var body) {

      List<Widget> wList = [];
      List data = jsonDecode(body)["data"];
      for (int i = 0; i < data.length; i++) {
        print(data[i]["word"]);
        Text text = Text(data[i]["word"]);
        wList.add(text);
      }
      setState(() {
        texts = wList;
      });
    }

    void getData() async {

      String url =
          "https://7a6396f8-09a1-4ade-b42a-f6db7776fb31.mock.pstmn.io/flutter";
      var httpClient = HttpClient();
      var request = await httpClient.getUrl(Uri.parse(url));
      var response = await request.close();

      var body = await response.transform(utf8.decoder).join();
      if (response.statusCode == 200) {
        setState(() {
          info = body;
        });
        parseJson(body);
      }
    }

    return Scaffold(
      appBar: AppBar(
        title: Text("登录"),
        centerTitle: true,
        backgroundColor: Colors.blue,
        foregroundColor: Colors.white,
      ),
      body: ListView(children: texts),
      floatingActionButton: FloatingActionButton(
        onPressed: () {
          getData();
        },
        child: Text("请求"),
      ),
    );
  }
}

2.post

dart 复制代码
  void postData() async {
    String url = "https://7a6396f8-09a1-4ade-b42a-f6db7776fb31.mock.pstmn.io/q";
    HttpClient httpClient = HttpClient();
    HttpClientRequest request = await httpClient.postUrl(Uri.parse(url));
    // 设置请求头
    request.headers.set('Content-Type', 'application/json; charset=UTF-8');
    Map<String, dynamic> pMap = {"random:": "q"};
    request.write(jsonEncode(pMap));
    HttpClientResponse response = await request.close();
    // 检查响应状态码
    if (response.statusCode == HttpStatus.ok) {
      // 读取响应内容
      final String responseBody = await response.transform(utf8.decoder).join();
      print('POST 响应数据: $responseBody');
    } else {
      print('请求失败,状态码: ${response.statusCode}');
    }
  }

原生http请求库(插件)

导入依赖

yaml 复制代码
dependencies:
  http: ^1.4.0

代码

dart 复制代码
import 'package:http/http.dart' as http;

  void httpGet() async {
    String url =
        "https://7a6396f8-09a1-4ade-b42a-f6db7776fb31.mock.pstmn.io/flutter";
    var result = await http.get(Uri.parse(url));
    if (result.statusCode == HttpStatus.ok) {
      print(result.body.toString());
    }
  }

  //post
  void httpPost(var body) async {
    String url = "https://7a6396f8-09a1-4ade-b42a-f6db7776fb31.mock.pstmn.io/q";
    var result = await http.post(Uri.parse(url), body: body);
    if (result.statusCode == HttpStatus.ok) {
      print(result.body.toString());
    }else{
      print(result.statusCode);
    }
  }

解析xml

xml 复制代码
<books>
    <book id="101">
        <title>XML入门指南</title>
        <author>李四</author>
        <price>39.90</price>
        <publisher>科技出版社</publisher>
    </book>
    <book id="102">
        <title>Web开发实战</title>
        <author>王五</author>
        <price>59.00</price>
        <publisher>电子工业出版社</publisher>
    </book>
</books>
dart 复制代码
      xml.XmlDocument xmlDocument = xml.XmlDocument.parse(result.body);
      Iterable<xml.XmlElement> xmlElement = xmlDocument.findElements("books");

      Iterable<xml.XmlElement> books = xmlElement.single.findAllElements("book");
      books.forEach((element) {

        print(element.findElements("id").single.innerText);
        print(element.findElements("title").single.innerText);
      },);

I/flutter ( 3477): 101
I/flutter ( 3477): XML入门指南
I/flutter ( 3477): 102
I/flutter ( 3477): Web开发实战
相关推荐
新镜2 小时前
【Flutter】RefreshIndicator 无法下拉刷新问题
flutter
星秋Eliot2 小时前
Flutter的三棵树
前端·flutter
用户0273851840265 小时前
[Android]RecycleView的item用法
android
humiaor6 小时前
Flutter之riverpod状态管理Widget UI详解
flutter·consumer·widget·hooks·provider·riverpod·hookwidget
农夫三拳_有点甜6 小时前
Flutter Stack 组件总结
flutter
前行的小黑炭6 小时前
Android :为APK注入“脂肪”,论Android垃圾代码在安全加固中的作用
android·kotlin
帅得不敢出门7 小时前
Docker安装Ubuntu搭建Android SDK编译环境
android·ubuntu·docker
MaoJiu7 小时前
Flutter混合开发:在iOS工程中嵌入Flutter Module
flutter·ios
tangweiguo030519877 小时前
Android Kotlin 动态注册 Broadcast 的完整封装方案
android·kotlin
fatiaozhang95277 小时前
浪潮CD1000-移动云电脑-RK3528芯片-2+32G-安卓9-2种开启ADB ROOT刷机教程方法
android·网络·adb·电脑·电视盒子·刷机固件·机顶盒刷机