Xutils|Xutils 框架

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模块:
【Xutils|Xutils 框架】支持同步,异步方式的请求;
支持大文件上传,上传大文件不会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() { @Override public void onSuccess(ResponseInfo 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() { @Override public void onSuccess(ResponseInfo 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 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(); } }

    推荐阅读