flutter 访问网页+http请求

本文介绍了如何在Flutter应用中实现网页访问及HTTP请求功能,包括GET和POST请求的使用方法,以及通过HttpClient获取天气数据的具体步骤。

一、目录

1、访问网页

2、http请求

-----------------------------这是分割线-----------------------------

1、访问网页

 基于url_launcher库实现,最新版本号 5.0.2,没有的话需要添加到pubspec.yaml中

然后get 该package

只要引入不报错就ok了。

ex.dart

/*
  time: 2019-4-3
 */

// 引入资源包
import 'package:flutter/material.dart';
import 'package:url_launcher/url_launcher.dart';

// main fun
void main() => runApp(new MyApp());

class MyApp extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    // TODO: implement build
    return new MaterialApp(
        title: 'url请求',
        home: new Scaffold(
          appBar: new AppBar(
            title: new Text('Example of packages'),
          ),
          body: new Center(
            child: new RaisedButton(
              onPressed: () {
                print(1);
                // url
                const url = "https://www.baidu.com";
                launch(url); // 打开浏览器跳转至百度网页
              },
              child: new Text('baidu'),
            ),
          ),
        ));
  }
}

运行效果如下

点击baidu按钮,打开网页

 

 

 

 

2、http请求

2.1、Http请求

下载Http库 版本号 0.12.0+2

ex.dart

/*
  time: 2019-4-3
  title: htttp请求
 */

// 引入资源包
import 'package:flutter/material.dart';
//import 'package:url_launcher/url_launcher.dart';
import 'package:http/http.dart' as http;

// main fun
void main () => runApp(new MyApp());

class MyApp extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    // TODO: implement build
    return new MaterialApp(
        title: 'Http 请求示例',
        home: new Scaffold(
          appBar: new AppBar(
            title:  new Text('Http 请求示例'),
          ),
          body: new Center(
            child: new RaisedButton(
              onPressed: () {
                print(1);
                var url = 'http://www.cnblogs.com/';

                // get
                http.get(url).then((response) {
                  print("Response status: ${response.statusCode}");
                  print("Response body: ${response.body[10]}");
                });

                // post
                http.post(url,body: {"key": "value"}).then((response) {
                  print('this is post');
                  print("Response status: ${response.statusCode}");
                  print("Response body: ${response.body}");
                });
              },
              child: new Text('发送请求'),
            ),
          ),
        )
    );
  }
}

运行效果

我点击发送请求之后,控制台输出

请求成功,并返回了内容。

2.1、HttpClient请求

 ex.dart

/*
  time: 2019-4-3
  title: htttpClient请求
 */

// 引入资源包
import 'package:flutter/material.dart';
import 'dart:convert';
import 'dart:io';

// main fun
void main () => runApp(new MyApp());

class MyApp extends StatelessWidget {
  // 获取天气数据
  void getWeatherData() async {
    try {
      // 实例化一个HttpCLient对象
      HttpClient  httpClient = new HttpClient();

      // 发起请求
      HttpClientRequest request = await httpClient.getUrl(
          Uri.parse("http://wthrcdn.etouch.cn/weather_mini?city=重庆市")
      );
      // 等待服务器返回数据
      HttpClientResponse response = await request.close();
      // 使用utf-8.decoder从response解析数据
      var result = await response.transform(utf8.decoder).join();
      // 输出
      print(result);
      // 关闭
      httpClient.close();

    } catch (e) {
      print("请求失败:$e");
    }
  }
  @override
  Widget build(BuildContext context) {
    // TODO: implement build
    return new MaterialApp(
      title: 'HttpClient 请求示例',
      home: new Scaffold(
        appBar: new AppBar(
          title:  new Text('HttpClient 请求示例'),
        ),
        body: new Center(
          child: new RaisedButton(
              onPressed: getWeatherData,
              child: new Text('获取天气数据'),
          ),
        ),
      )
    );
  }
}

运行效果如下:

点击按钮之后,控制台输出:

I/flutter (15353): {"data":{"yesterday":{"date":"6日星期六","high":"高温 30℃","fx":"无持续风向","low":"低温 14℃","fl":"<![CDATA[<3级]]>","type":"晴"},"city":"重庆","forecast":[{"date":"7日星期天","high":"高温 32℃","fengli":"<![CDATA[<3级]]>","low":"低温 15℃","fengxiang":"无持续风向","type":"晴"},{"date":"8日星期一","high":"高温 32℃","fengli":"<![CDATA[<3级]]>","low":"低温 18℃","fengxiang":"无持续风向","type":"多云"},{"date":"9日星期二","high":"高温 29℃","fengli":"<![CDATA[<3级]]>","low":"低温 19℃","fengxiang":"无持续风向","type":"多云"},{"date":"10日星期三","high":"高温 24℃","fengli":"<![CDATA[<3级]]>","low":"低温 18℃","fengxiang":"无持续风向","type":"阴"},{"date":"11日星期四","high":"高温 25℃","fengli":"<![CDATA[<3级]]>","low":"低温 18℃","fengxiang":"无持续风向","type":"多云"}],"ganmao":"各项气象条件适宜,发生感冒机率较低。但请避免长期处于空调房间中,以防感冒。","wendu":"3}

 

转载于:https://www.cnblogs.com/shuangzikun/p/taotao_flutter_from_book_kangshaojun_01.html

### 在 Flutter 中使用 WebView 嵌入 H5 网页Flutter 应用中嵌入 H5 页面可以通过 `webview_flutter` 插件实现。以下是完整的配置教程以及示例代码。 #### 1. 添加依赖项 首先,在项目的 `pubspec.yaml` 文件中添加 `webview_flutter` 的依赖: ```yaml dependencies: flutter: sdk: flutter webview_flutter: ^4.0.2 ``` 运行命令以更新项目依赖: ```bash flutter pub get ``` --- #### 2. Android 配置 为了支持 HTTPS 和 HTTP 请求,需修改 `AndroidManifest.xml` 文件中的 `<application>` 节点,添加属性 `android:usesCleartextTraffic="true"`[^3]: ```xml <application android:name="io.flutter.app.FlutterApplication" android:label="flutter_test" android:usesCleartextTraffic="true" android:icon="@mipmap/ic_launcher"> </application> ``` 此设置允许应用访问未加密的网络资源(如果需要)。 --- #### 3. 实现代码示例 以下是一个完整的示例代码,展示如何通过 `WebView` 加载指定 URL 并传递自定义请求头参数[^1]: ```dart import 'package:flutter/material.dart'; import 'package:webview_flutter/webview_flutter.dart'; void main() { runApp(MyApp()); } class MyApp extends StatelessWidget { @override Widget build(BuildContext context) { return MaterialApp( home: Scaffold( appBar: AppBar(title: Text('Flutter WebView Example')), body: WebViewExample(), ), ); } } class WebViewExample extends StatefulWidget { @override _WebViewExampleState createState() => _WebViewExampleState(); } class _WebViewExampleState extends State<WebViewExample> { late WebViewController _controller; @override Widget build(BuildContext context) { return WebViewWidget( controller: WebViewController() ..setJavaScriptMode(JavaScriptMode.unrestricted) ..onWebViewCreated((WebViewController webViewController) { _controller = webViewController; final Map<String, String> headers = {}; headers['Authorization'] = 'Bearer your_token_here'; // 自定义请求头 headers['Custom-Key'] = 'Custom-Value'; // 可扩展更多头部字段 _controller.loadUrl('https://example.com', headers: headers); }) ..setNavigationDelegate(NavigationDelegate( onPageFinished: (String url) { print('Page finished loading: $url'); }, )), ); } } ``` --- #### 4. 使用 CookieManager 同步登录状态 如果需要同步用户的登录状态到 H5 页面,可以利用 `cookie_manager` 功能[^2]。例如,向特定域名注入 Cookie 数据: ```dart final cookieManager = WebKitCookieManager(); @override void initState() { super.initState(); setCookies(); } Future<void> setCookies() async { await cookieManager.setCookie( WebViewCookie( name: 'session_id', value: 'your_session_value_here', domain: '.example.com', // 注意前缀 . 表示子域共享 path: '/', ), ); } ``` 以上代码会在 WebView 初始化时自动将指定的 Cookie 注入目标网站。 --- ### 总结 上述方法展示了如何在 Flutter 中集成并定制化 WebView 组件的功能,包括加载外部链接、附加请求头参数以及管理 Cookies 来保持会话一致性。 ---
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符  | 博主筛选后可见
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值