场景

h5页面要从cookie里面取数据,所以需要在flutter webview的cookie里面塞一些数据,设置的数据多达十几条;按照网上查的使用方式来设置,通过fiddler抓包发现,只能生效一条,来来回回试了很多次都只有一条,心态崩了

后来看到cookie设置数据也是类似键值对里面套键值对,灵机一动,变换下后就成功了,记录下正确的写法吧

正确姿势

引入

  • 使用的是flutter官方维护的webview插件
webview_flutter: ^0.3.22+1

错误示例

  • 这是最坑的一个,widget都都没写全,就写了俩个回调,这么写只会生效一条
WebViewController _controller;
onWebViewCreated: (WebViewController wvc) {
_controller = wvc;
} onPageFinished: (String value) {
_controller.evaluateJavascript( 'document.cookie = "SESSIONID=612bc4822b6996d6f335a963c20eb541fba72985; path=/"')
}
  • 这个只写了一条cookie,这个是没问题的,和上面的区别就是,这个使用双引号包住单引号,只写了一条的使用也是让人肝痛
setSessionID() async {
String sessionID = await LocalStorage.get("sessionID");
if (Platform.isIOS) {
_controller.evaluateJavascript("document.cookie = 'sessionID=${sessionID}'").then<String>((res) {
print("webViewController.evaluateJavascript========>${res}");
_onListCookies(_controller, context);
});
} else {
_controller.evaluateJavascript('document.cookie = "sessionID=${sessionID};"').then<String>((res) {
print("webViewController.evaluateJavascript========>${res}");
_onListCookies(_controller, context);
});
}
}

多条cookie添加正确写法

  • 琢磨半天试出来的正确写法,cookie的设置需要在页面加载完之后设置
///webview控制器
WebViewController _controller;
String _url = "写入你的链接"; WebView(
initialUrl: _url,
javascriptMode: JavascriptMode.unrestricted,
onWebViewCreated: (controller) {
_controller = controller;
},
onPageFinished: (url) {
//页面加载结束
String cookie =
"document.cookie = 'name=IAmDaShuaiBi';document.cookie = 'id=233'";
_controller.evaluateJavascript(cookie);
},
userAgent: "test;app/1.0.0",
)
  • 最重要的变化就是每条cookie都要用document.cookie作为key,这是最最最关键的

优化写法

  • 上面的写法是写成一行,写成一行是很致命的操作,让赋值操作会变得很迷惑,优化下
///webview控制器
WebViewController _controller;
String _url = "写入你的链接"; WebView(
initialUrl: _url,
javascriptMode: JavascriptMode.unrestricted,
onWebViewCreated: (controller) {
_controller = controller;
},
onPageFinished: (url) {
//页面加载结束
String cookie = '''
document.cookie = 'nameOne=IAmDaShuaiBi';
document.cookie = 'idOne=233';
document.cookie = 'nameTwo=IAmDaShuaiBi';
document.cookie = 'idTwo=233';
document.cookie = 'nameThree=IAmDaShuaiBi';
document.cookie = 'idThree=233';
''';
_controller.evaluateJavascript(cookie);
},
userAgent: "test;app/1.0.0",
)
  • ok,搞定

补充

  • 就这么点内容就水了一片文章,显得我是个水笔,为了证明我不是个水笔,再补充个开发小技巧

弹窗封装,优化列表数据源

说明

底部单列表弹窗是非常实用的弹窗,但是可能大家经常有这样的一种使用体验,传数据源,一般都是传一个List类型,内部的泛型最最最常见的就是:String和固定的实体;说下这俩种情况的问题所在

  • String:显然该泛型,内部处理处理起来非常简单,直接拿String值展示就行,回调直接把选择的String返回;这种String类型存在一个非常致命的的问题,在使用前后都存在问题

    • 使用前:我们必须把数据类型转换成List类型,我们数据源一般都是通过接口获取,接口里面List数据源里面的泛型五花八门的,往往需要做循环转化成List类型去使用
    • 使用后:点击选择后,拿到我们选择的展示名,接口提交往往是需要该种选择类型的id,一般来说还需要去做遍历拿出选择名称对应的id,然后保存做提交操作
  • 规定实体:使用规定的泛型实体,有一个好处,可以避免在使用后去遍历对比,然后去取id的操作,所以他只存在使用前的麻烦
    • 使用前:这里我们必须把拿到的数据源转换符合要求的List规定实体泛型,这步操作就可以把id等信息一起放在规定的实体里面,选择之后也可以直接从实体里面拿了

吐槽:虽然上面俩种情况,第二种明显优于第一种,但是实际开发中,往往不假思索的用第一种,因为第一种不用去新建一个class啊!然后用起来就蛋痛了;有没有一种方法可以一劳永逸的方法呢,数据的list泛型随便用,只用指定泛型实体用于展示的key;然后在回调里面又能拿到我们传的实体呢?通过dart强大的动态类型,加一些巧妙转换是完全可以的

实现思路

java里可以通过泛型+反射;然后指定一个展示的key,理论上也是可以实现,我没试过,大家可以试试

实现思路

实现方法还是很简单的,这里说下思路就行了

实现步骤

  • 数据源定义为List类型,然后指定一个展示的key

    • 泛型不指定的话,会默认为动态类型,这样的话,便有了很大的操作空间
  • 遍历这个List,然后拿到遍历列表时的实体
  • 将实体转换成Map类型,通过指定的key,获取展示内容就行了
  • 回调时,传出来选的实体就ok,似不似很简单

举例

  • 引入:flutter_picker
flutter_picker: ^1.1.5
  • 实现
import 'dart:convert';
import 'package:flutter/material.dart';
import 'package:flutter_picker/Picker.dart'; typedef ParamSingleCallback<E> = Void Function(E data); void showBottomSingleDialog<E>(
BuildContext context, {
@required List<E> list,
@required ParamSingleCallback<E> callback,
String title = '请选择',
String showKey = '',
}) {
List<PickerItem<E>> pickList = [];
for (E item in list) {
String showContent;
if (showKey == '') {
//兼容泛型为String的情况
showContent = item as String;
} else {
//将实体转成map,通过设置的key指定展示的字段
var map = json.decode(jsonEncode(item));
showContent = map[showKey];
} pickList.add(
PickerItem(
text: Text(showContent),
value: item,
),
);
} Picker(
adapter: PickerDataAdapter<E>(data: pickList),
hideHeader: false,
title: Text(title),
cancelText: "取消",
confirmText: "确定",
onConfirm: (Picker picker, List value) async {
//必须做一个延时操作,先执行回调内部的pop,不然pop页面无法回传值
await Future.delayed(Duration(milliseconds: 10));
callback(picker.getSelectedValues()[0]);
},
).showModal(context);
}

使用

  • 数据源
class InfoBean {
String name;
int id; InfoBean({this.id, this.name}); /// jsonDecode(jsonStr) 方法中会调用实体类的这个方法。如果实体类中没有这个方法,会报错。
Map toJson() {
Map map = Map();
map["name"] = this.name;
map["id"] = this.id;
return map;
}
} ///创建数据源
List<InfoBean> list = [];
for (var i = 0; i < 10; i++) {
list.add(InfoBean(name: "姓名-$i", id: i));
}
  • 使用

    • 这地方指不指定泛型都是可以的,不指定泛型默认为动态类型,item点的时候没有提示,可以凭着自己的记忆写key值,只要是key是对,完全能拿到数据
///指定泛型
showBottomSingleDialog<InfoBean>(
context,
list: list,
showKey: 'name',
callback: (item) {
print(item.name);
print(item.id);
},
); ///不指定泛型
showBottomSingleDialog(
context,
list: list,
showKey: 'name',
callback: (item) {
print(item.name);
print(item.id);
},
);

最后

代码地址

Flutter Webview添加Cookie的正确姿势的更多相关文章

  1. Sql动态添加字段的正确姿势

    如何给指定表动态添加字段? 一.创建一张表[Tbl_AutoFileds] (tableName表名,fieldName字段名,dataType数据类型,length长度  isnull 是否允许为n ...

  2. element动态添加表头的正确姿势

    1. 第一步循环 el-table-column <el-table-column v-if="item.show" v-for="(item, index) in ...

  3. GitHub 热点速览 Vol.18:刷 LeetCode 的正确姿势

    作者:HelloGitHub-小鱼干 摘要:找对路子,事半功倍,正如本周 GitHub Trending #刷 LeetCode# 主题想表达的那般,正确的学习姿势方能让人走得更远,走进大厂

  4. ios监听ScrollView/TableView滚动的正确姿势

    主要介绍 监测tableView垂直滚动的舒畅姿势 监测scrollView/collectionView横向滚动的正确姿势 1.监测tableView垂直滚动的舒畅姿势 通常我们用KVO或者在scr ...

  5. selenium3.7+ python3 添加cookie模拟登陆

    一.背景介绍 最近做一个爬虫项目,用selenium调用浏览器去获取渲染后的源码,但是每次登陆都需要手机验证,这真的是头痛啊,这种验证方式不要想着去破解,还是老老实实用手机收验证码去吧!反正我是不知道 ...

  6. 使用 win10 的正确姿势

    17年9月初,写了第一篇<使用 win10 的正确姿势>,而现在半年多过去,觉得文章得更新一些了,索性直接来个第二版吧. -----2018.3.24 写 一. 重新定义桌面 我的桌面: ...

  7. 使用 win10 的正确姿势 (第二版)

    文章为本人原创,转载请注明出处,谢谢. 17年9月初,写了第一篇<使用 win10 的正确姿势>,而现在半年多过去,文章更新了一些,主要是桌面的变化. 一. 重新定义桌面 我的桌面: 将桌 ...

  8. 开发函数计算的正确姿势 —— 使用 Fun Local 本地运行与调试

    前言 首先介绍下在本文出现的几个比较重要的概念: 函数计算(Function Compute): 函数计算是一个事件驱动的服务,通过函数计算,用户无需管理服务器等运行情况,只需编写代码并上传.函数计算 ...

  9. 【分布式缓存系列】Redis实现分布式锁的正确姿势

    一.前言 在我们日常工作中,除了Spring和Mybatis外,用到最多无外乎分布式缓存框架——Redis.但是很多工作很多年的朋友对Redis还处于一个最基础的使用和认识.所以我就像把自己对分布式缓 ...

随机推荐

  1. k8s数据管理(八)

    volume 我们经常会说:容器和 Pod 是短暂的.其含义是它们的生命周期可能很短,会被频繁地销毁和创建.容器销毁时,保存在容器内部文件系统中的数据都会被清除. 为了持久化保存容器的数据,可以使用 ...

  2. 数据库SQL调优的几种方式

    1.创建索引 (1) 要尽量避免全表扫描,首先应考虑在where 及order by涉及的列上建立索引 (2) 在经常需要进行检索的字段上创建索引,一个表中的索引最好不要超过6个 2.避免在索引上使用 ...

  3. python的循环结构

    遍历循环 计数循环(N次)/(特定次)/字符串遍历循环 列表遍历循环/文件遍历循环......字典遍历循环等等 例子--计数循环 输出从1到6的整数,以2为步长 字符串遍历循环 列表遍历循环 文件遍历 ...

  4. Mac使用Charles给iPhone抓包流程

    目录 需求 步骤 1. Mac打开共享Wifi 2. iPhone连接刚刚的WIFI 3. 找到Mac的局域网ip 4. 配置代理 需求 有时候手机接口出问题了,不知道从哪里下手,Charles就是非 ...

  5. php第五天-正则表达式,字符串的匹配与查找函数,数组切割

    在php中有两套正则表达式,两者功能相似,一套是由PCRE,使用"preg_"为前缀命名的函数,一套是由POSIX拓展提供的,使用以"ereg_"命名的函数 0 ...

  6. Docker 容器化部署 Python 应用

    Docker 是一个开源项目,为开发人员和系统管理员提供了一个开放平台,可以将应用程序构建.打包为一个轻量级容器,并在任何地方运行.Docker 会在软件容器中自动部署应用程序. 在本篇中,我将介绍如 ...

  7. ASP.NET实现企业微信接入应用实现身份认证

    目录 #需求场景 #参考 #具体步骤 1.获取access_token 2.构造网页授权链接 3.获取访问用户身份 #.Net具体代码 1.Web首页服务端代码 2.帮助类代码 #需求场景 一个.ne ...

  8. Tomcat 中 catalina.out、catalina.log、localhost.log 和 access_log 的区别

    打开 Tomcat 安装目录中的 log 文件夹,我们可以看到很多日志文件,这篇文章就来介绍下这些日记文件的具体区别. catalina.out 日志 catalina.out 日志文件是 Tomca ...

  9. Centos-删除文件或目录-rm

    rm 删除目录或者文件,如果是链接文件,则只删除这个链接文件而不是链接指向的文件 相关选项 -r 递归删除目录 -f 忽略不存在提示和确认提示,本身确认提示系统默认添加-i参数 -i 删除文件前提示, ...

  10. Mindmaster破解版与正版

    1 免费版与正版 MindMaster思维导图软件,免费版没有过期时间可以一直使用,导出或者保存的文件没有水印.免费版和专业版的不同之处在于,专业版可以享受全功能,比如导出为可编辑的PDF.Offic ...