博客
关于我
Android 在Service服务中上传数据到服务器
阅读量:138 次
发布时间:2019-02-28

本文共 2605 字,大约阅读时间需要 8 分钟。

前言:根据自己的项目去总结的一个思路,和具体实现方法。

思路:在项目中创建一个服务类UserlogService 继承自Service

之后根据Service的生命周期。
Service的生命周期这一块,可以看我的这篇博文,,就不在本篇文章中讲解了。
根据Service生命周期,把具体操作写在onStartCommand()中。
onStartCommand()的代码如下:
定期触发3秒上传一次

@Override    public int onStartCommand(Intent intent, int flags, int startId) {        mHelper = UserLogDBHelper.getInstance(this, 1);        mHelper.openReadLink();        myhandler.sendMessageDelayed(Message.obtain(myhandler, 1), 3000);        return  START_STICKY;    }

1.查询本地没有上传的数据。

//查询本地未上传数据ArrayList
arrayListlog = readSQLite();

调用readSQLite方法:

//查询本地数据    private ArrayList
readSQLite() { ArrayList
arrayList = mHelper.query("1=1"); return arrayList; }

2.调用API,上传数据,这一步才是核心。

这里面用的是Post异步请求

/**调用API,上传数据     * @param userLog     */    private void setUploaddata(final UserLog userLog) {        try {        String userlogjson = new Gson().toJson(userLog);        //定义OKhttp        OkHttpClient okHttpClient = new OkHttpClient();        MediaType JSON = MediaType.parse("application/json");        //定义请求体        RequestBody body = RequestBody.create(JSON, userlogjson);            Request request = new Request.Builder()                    .post(body)                    .url("http://v.juhe.cn/toutiao/index")                    .build();                    //异步请求            okHttpClient.newCall(request).enqueue(new Callback() {                @Override                public void onFailure(Call call, IOException e) {                }                @Override                public void onResponse(Call call, Response response) throws IOException {                    String ss = response.body().string();                    ResultMsg resultMsg = new Gson().fromJson(ss, ResultMsg.class);                    if (resultMsg.Result.equals("1")) {                        Log.d(TAG, "run: 上传成功");                        Looper.prepare();                        //上传成功的数据从本地删除                        Delete(userLog.UserLogID);                        Looper.loop();                    } else {                    }                }            });        } catch (Exception e) {            e.printStackTrace();        }    }

3.上传数据之后,从本地删除已经上传的数据,上面代码已经写出

这是Delete()的具体方法。

//删除本地数据    private void  Delete(String UserLogID)    {        try {            mHelper.delete("UserLogID='" + UserLogID+"'");        }catch (Exception ex)        {            Log.d(TAG, "Delete: "+ex.toString());        }    }

最后一步,在MainActivity中,启动服务。

//开启日志上传服务Intent intent=new Intent(this,UserLogService.class);startService(intent);

以上就是上传到服务器的一个基本思路,仅做记录参考,有需要的可以参考学习!

转载地址:http://tsed.baihongyu.com/

你可能感兴趣的文章
multiprocessing.pool.map 和带有两个参数的函数
查看>>
MYSQL CONCAT函数
查看>>
multiprocessing.Pool:map_async 和 imap 有什么区别?
查看>>
MySQL Connector/Net 句柄泄露
查看>>
multiprocessor(中)
查看>>
mysql CPU使用率过高的一次处理经历
查看>>
Multisim中555定时器使用技巧
查看>>
MySQL CRUD 数据表基础操作实战
查看>>
multisim变压器反馈式_穿过隔离栅供电:认识隔离式直流/ 直流偏置电源
查看>>
mysql csv import meets charset
查看>>
multivariate_normal TypeError: ufunc ‘add‘ output (typecode ‘O‘) could not be coerced to provided……
查看>>
MySQL DBA 数据库优化策略
查看>>
multi_index_container
查看>>
mutiplemap 总结
查看>>
MySQL Error Handling in Stored Procedures---转载
查看>>
MVC 区域功能
查看>>
MySQL FEDERATED 提示
查看>>
mysql generic安装_MySQL 5.6 Generic Binary安装与配置_MySQL
查看>>
Mysql group by
查看>>
MySQL I 有福啦,窗口函数大大提高了取数的效率!
查看>>