博客
关于我
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/

你可能感兴趣的文章
mysql 更新子表_mysql 在update中实现子查询的方式
查看>>
MySQL 有什么优点?
查看>>
mysql 权限整理记录
查看>>
mysql 权限登录问题:ERROR 1045 (28000): Access denied for user ‘root‘@‘localhost‘ (using password: YES)
查看>>
MYSQL 查看最大连接数和修改最大连接数
查看>>
MySQL 查看有哪些表
查看>>
mysql 查看锁_阿里/美团/字节面试官必问的Mysql锁机制,你真的明白吗
查看>>
MySql 查询以逗号分隔的字符串的方法(正则)
查看>>
MySQL 查询优化:提速查询效率的13大秘籍(避免使用SELECT 、分页查询的优化、合理使用连接、子查询的优化)(上)
查看>>
mysql 查询,正数降序排序,负数升序排序
查看>>
MySQL 树形结构 根据指定节点 获取其下属的所有子节点(包含路径上的枝干节点和叶子节点)...
查看>>
mysql 死锁 Deadlock found when trying to get lock; try restarting transaction
查看>>
mysql 死锁(先delete 后insert)日志分析
查看>>
MySQL 死锁了,怎么办?
查看>>
MySQL 深度分页性能急剧下降,该如何优化?
查看>>
MySQL 深度分页性能急剧下降,该如何优化?
查看>>
MySQL 添加列,修改列,删除列
查看>>
mysql 添加索引
查看>>
MySQL 添加索引,删除索引及其用法
查看>>
MySQL 用 limit 为什么会影响性能?
查看>>