昨天研究Hybrid Android App中js和java代码之间数据共享的问题,具体场景是用户登录是android java实现,但有些业务是使用html5开发的,因此登录后到主页后,调整到某些HTML5业务页面需要传递
昨天研究Hybrid Android App中js和java代码之间数据共享的问题,具体场景是用户登录是android java实现,但有些业务是使用html5开发的,因此登录后到主页后,调整到某些HTML5业务页面需要传递用户的access_token, 目前想到的办法是在js端通过cordova插件访问存在Shared Preferences中的数据,但由于数据是异步返回的,需要一定的时间,有时不能及时取得数据,所以问题不能完美的解决。
目前访问Shared Preferences的Cordova插件有2个,一个是
https://github.com/offbye/phonegap-sharedpreferences-save-retrieve, 这个插件只支持Android平台,好处是可以指定Shared Preferences文件的名字
另一个是在官方Cordova Plugin上的插件,https://github.com/apla/me.apla.cordova.app-preferences, 优点是支持Android,iOS,WP等多个平台,缺点是在android上,不能指定Shared Preferences文件的名字,只能访问默认的Shared Preferences文件,即通过
PreferenceManager.getDefaultSharedPreferences(this)创建的文件,文件名是packagename_preference.xml。
考虑到我这个应用是跨多个平台的,因此最终选择了me.apla.cordova.app-preferences。
注意代码需要加在 onDeviceReady里面,
document.addEventListener("deviceready", onDeviceReady, false); function onDeviceReady() { var appp = window.plugins.appPreferences; if (appp){ appp.fetch (function (access_token) { AppConfig.common.access_token = access_token; localStorage.setItem("access_token", access_token); console.error ('fetch value ok for access_token'); }, function (err) { console.error ('fetch value failed for access_token'); }, "access_token"); } }
由于取得 Shared Preferences中的数据是异步的,并且稍微有点慢,因此如果马上就使用取得的数据,可能会出现问题,目前还没有彻底解决。一直可行的思路是Android java直接把数据写入到webview的local Storage数据库,该数据库是sqlite的,然后js端通过Localstorage读取数据,这种方法暂时还没有验证可行性。