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开发实战
相关推荐
xiaoyan201520 小时前
2026爆肝!Flutter3.41纯手撸微信聊天APP原生应用
android·flutter·dart
程序员老刘20 小时前
当全网都在喊“程序员要被AI取代了”,Flutter给了另一种答案
flutter·ai编程·客户端
国医中兴21 小时前
Flutter 三方库 nhost_graphql_adapter 的鸿蒙化适配指南 - 云端数据实时对齐、GraphQL 架构实战、鸿蒙级全栈交互专家
flutter·harmonyos·graphql
jinanwuhuaguo21 小时前
OpenClaw协议霸权——从 MCP 标准到意图封建化的政治经济学(第十八篇)
android·人工智能·kotlin·拓扑学·openclaw
撩得Android一次心动21 小时前
Android Room 数据库详解【源码篇】
android·数据库·android jetpack·room
TO_ZRG1 天前
Android WorkManager 完全入门指南
android
a8a3021 天前
Laravel 6.x新特性全解析
android
IntMainJhy1 天前
Flutter 三方库 get_it + flutter_bloc 的鸿蒙化适配与实战指南
flutter·华为·harmonyos
用户游民1 天前
Android 腾讯X5WebView如何禁止系统自带剪切板和自定义剪切板视图
android·java
Lyyaoo.1 天前
TreadLocal和TreadLocalMap
android·java·redis