xUtils简介
xUtils 包含了很多实用的android工具。目前xUtils主要有四大模块: DbUtils模块:
xUtils 源于Afinal框架,对Afinal进行了大量重构,使得xUtils支持大文件上传,更全面的http请求协议支持,拥有更加灵活的ORM,更多的事件注解支持且不受混淆影响…
xUitls最低兼容android 2.2 (api level 8)
android中的orm框架,一行代码就可以进行增删改查;ViewUtils模块:
支持事务,默认关闭;
可通过注解自定义表名,列名,外键,唯一性约束,NOT NULL约束,CHECK约束等(需要混淆的时候请注解表名和列名);
支持绑定外键,保存实体时外键关联实体自动保存或更新;
自动加载外键关联实体,支持延时加载;
支持链式表达查询,更直观的查询语义,参考下面的介绍或sample中的例子。
android中的ioc框架,完全注解方式就可以进行UI绑定和事件绑定;HttpUtils模块:
新的事件绑定方式,使用混淆工具混淆后仍可正常工作;
目前支持常用的11种事件绑定,参见ViewCommonEventListener类和包com.lidroid.xutils.view.annotation.event。
【Xutils|Xutils 框架】支持同步,异步方式的请求;BitmapUtils模块:
支持大文件上传,上传大文件不会oom;
支持GET,POST,PUT,MOVE,COPY,DELETE,HEAD请求;
下载支持301/302重定向,支持设置是否根据Content-Disposition重命名下载的文件;
返回文本内容的GET请求支持缓存,可设置默认过期时间和针对当前请求的过期时间。
>加载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();
}
}