Xutils 框架

来源:互联网 发布:网络感叹号是什么原因 编辑:程序博客网 时间:2024/06/07 21:22

xUtils简介

xUtils 包含了很多实用的android工具。
xUtils 源于Afinal框架,对Afinal进行了大量重构,使得xUtils支持大文件上传,更全面的http请求协议支持,拥有更加灵活的ORM,更多的事件注解支持且不受混淆影响…
xUitls最低兼容android 2.2 (api level 8)

目前xUtils主要有四大模块:

DbUtils模块:

android中的orm框架,一行代码就可以进行增删改查;
支持事务,默认关闭;
可通过注解自定义表名,列名,外键,唯一性约束,NOT NULL约束,CHECK约束等(需要混淆的时候请注解表名和列名);
支持绑定外键,保存实体时外键关联实体自动保存或更新;
自动加载外键关联实体,支持延时加载;
支持链式表达查询,更直观的查询语义,参考下面的介绍或sample中的例子。

ViewUtils模块:

android中的ioc框架,完全注解方式就可以进行UI绑定和事件绑定;
新的事件绑定方式,使用混淆工具混淆后仍可正常工作;
目前支持常用的11种事件绑定,参见ViewCommonEventListener类和包com.lidroid.xutils.view.annotation.event。

HttpUtils模块:

支持同步,异步方式的请求;
支持大文件上传,上传大文件不会oom;
支持GET,POST,PUT,MOVE,COPY,DELETE,HEAD请求;
下载支持301/302重定向,支持设置是否根据Content-Disposition重命名下载的文件;
返回文本内容的GET请求支持缓存,可设置默认过期时间和针对当前请求的过期时间。

BitmapUtils模块:

        >加载bitmap的时候无需考虑bitmap加载过程中出现的oom和android容器快速滑动时候出现的图片错位等现象;        支持加载网络图片和本地图片;        内存管理使用lru算法,更好的管理bitmap内存;        可配置线程加载线程数量,缓存大小,缓存路径,加载显示动画等...

首先这里介绍用 HttpUtils来进行网络连接,在知名各控件地址的时候使用ViewUtils

package com.example.administrator.myutiles;import android.app.Activity;import android.os.Bundle;import android.view.View;import android.widget.Button;import android.widget.TextView;import android.widget.Toast;import com.lidroid.xutils.HttpUtils;import com.lidroid.xutils.ViewUtils;import com.lidroid.xutils.exception.HttpException;import com.lidroid.xutils.http.RequestParams;import com.lidroid.xutils.http.ResponseInfo;import com.lidroid.xutils.http.callback.RequestCallBack;import com.lidroid.xutils.http.client.HttpRequest;import com.lidroid.xutils.view.annotation.ViewInject;import com.lidroid.xutils.view.annotation.event.OnClick;public class MainActivity extends Activity implements View.OnClickListener{    @ViewInject(R.id.button_xutils_get)    private Button mButtonXutilsGet;    @ViewInject(R.id.button_xutils_post)    private Button mButtonXutilsPost;    @ViewInject(R.id.text_xutils)    private TextView mTextXutils;    @Override    protected void onCreate(Bundle savedInstanceState) {        super.onCreate(savedInstanceState);        setContentView(R.layout.activity_main);        ViewUtils.inject(this);    //使用ViewUtils来找到各个控件    }    @OnClick({R.id.button_xutils_get,R.id.button_xutils_post})    //用该注解代替mButtonXutilsGet.setOnClickListener(this);    @Override    public void onClick(View v) {        switch (v.getId()){            case R.id.button_xutils_get:                utilsGet();                break;            case R.id.button_xutils_post:                utilsPost();                break;        }    }    private void utilsPost() {        HttpUtils client=new HttpUtils();        //使用HttpUtils 来进行网络连接和网络通信        RequestParams params=new RequestParams();        params.addBodyParameter("username","zhangshisan");        client.send(HttpRequest.HttpMethod.POST, "http://192.168.0.30:8080/MyWebTest/MyTestServerlet", params, new RequestCallBack<String>() {            @Override            public void onSuccess(ResponseInfo<String> responseInfo) {                mTextXutils.setText(responseInfo.result);            }            @Override            public void onFailure(HttpException e, String s) {                Toast.makeText(getApplicationContext(), "网络连接失败", Toast.LENGTH_LONG).show();            }        });    }    private void utilsGet() {        HttpUtils client = new HttpUtils();        client.send(HttpRequest.HttpMethod.GET, "http://www.360.com", new RequestCallBack<String>() {            @Override            public void onSuccess(ResponseInfo<String> responseInfo) {                mTextXutils.setText(responseInfo.result);            }            @Override            public void onFailure(HttpException e, String s) {                Toast.makeText(getApplicationContext(), "网络连接失败", Toast.LENGTH_LONG).show();            }        });    }}

由以上代码可以看出,通过使用Xutils使得程序变得更加简洁和有条理。
下边在数据库中来介绍一下DbUtils
首先创建一个关于数据库表中各列属性的一个类,这里用的是User类来表示创建的表user中的数据

@Table(name="user")//说明表名public class User {    @Column(column = "id")    //id列    private String id;    private String name;    private String age;    private String sex;    public String getId() {        return id;    }    public void setId(String id) {        this.id = id;    }    public String getAge() {        return age;    }    public void setAge(String age) {        this.age = age;    }    public String getName() {        return name;    }    public void setName(String name) {        this.name = name;    }    public String getSex() {        return sex;    }    public void setSex(String sex) {        this.sex = sex;    }}

其中每一个属性都是表中的列名,然后得到每个属性的set 和get 方法,最重要的是要要说明所要操作的表名和id列。
然后在创建好的数据库的类中通过查找数据库中的数据来对DbUtils做一个具体的说明

   private void select() {        DbUtils dbUtils=DbUtils.create(this,"firstDatabase");        //这里要说明操作的数据库的名字,而不是表名        try {            List <User> users=dbUtils.findAll(Selector.from(User.class));            //将查找的内容放到List集合中            for (User user:users){                Log.d("00000000", "id"+user.getId()+"姓名 :"+user.getName() +" 性别:"+user.getSex()+" 年龄:"+user.getAge());            }            //利用for循环对查找到的数据进行log输出        } catch (DbException e) {            e.printStackTrace();        }    }
1 0
原创粉丝点击