首页 > 代码库 > Hybrid Android App中通过js访问Shared Preferences的问题

Hybrid Android App中通过js访问Shared Preferences的问题

      昨天研究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读取数据,这种方法暂时还没有验证可行性。

Hybrid Android App中通过js访问Shared Preferences的问题