利Android AQuery中ajax访问SSH搭建的后台Java Web服务器

2022-11-30 10:08:10 浏览数 (1)

以前要访问网络或者下载图片什么之类的一般用AsyncTask来完成,可是大家会发现用起来非常不方便,所以今天我要讲的是Android AQuery中ajax来代替AsyncTask。Android AQuery中ajax对AsyncTask进行很好的封装,我们可以很简单进行网络访问。

讲概念很难理解其中的要点,今天讲一个例子,这个例子是利Android AQuery中ajax访问SSH搭建的后台Java Web服务器。

Android端:

在开始写代码之前要导入一些jar包,因为我代码中有用到Gson和Json所以导入的jar包比较多。

Activity:

代码语言:javascript复制
package com.example.test.aquery_test_2;
import android.app.Activity;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import android.widget.Toast;
import com.androidquery.AQuery;
import com.androidquery.callback.AjaxCallback;
import com.androidquery.callback.AjaxStatus;
import com.example.test.aquery_test_2.entity.JsonEntity;
import com.example.test.aquery_test_2.entity.User;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
public class MainActivity extends Activity {
    private Button button,button2;
    private EditText edittext,edittext2;
    private String str2="";
    private String name,pwd;
    private AQuery mAQuery;//Android Query简化了附加事件处理程序的过程。
    // 它不会构建出接口或者匿名类,我们只需要确保它们不会把事件处理程序的方法名拼写错。
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        button=(Button)findViewById(R.id.button);//确定按钮
        button2=(Button)findViewById(R.id.button2);//取消按钮
        edittext=(EditText)findViewById(R.id.editText);//账号输入框
        edittext2=(EditText)findViewById(R.id.editText2);//密码输入框
        button.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                String url = "http://localhost:8080/YX_2015_9_9_SSH_Test_1/login.action";//Java后台的URL
localhost必须改为能上网的ip地址,可以在黑框框中输入ipconfig来查询。
                List<User> list=new ArrayList<User>();
                User user=new User(edittext.getText().toString().trim(),edittext2.getText().toString().trim());
                list.add(user);
                Map<String, String> params = new HashMap<String, String>();
                JsonEntity jsonEntity=new JsonEntity(list);
                String jsonStr=jsonEntity.createJSONObject();
                params.put("json",jsonStr);
                //利用AQuery中的ajax实现异步加载的功能,其中URL为访问路劲,params为传入的数据,String.class为返回数据的格式
                final AQuery aq=new AQuery(MainActivity.this);
                aq.ajax(url,params,String.class, new AjaxCallback<String>() {
                    @Override
                    public void callback(String url, String json, AjaxStatus status) {
                        if(json != null){
                            //successful ajax call, show status code and json content
                            Toast.makeText(aq.getContext(), status.getCode()   ":"   json.toString(), Toast.LENGTH_LONG).show();

                        }else{
                            //ajax error, show error code
                            Toast.makeText(aq.getContext(), "Error:"   status.getCode(), Toast.LENGTH_LONG).show();
                        }
                    }
                });
            }
        });
    }
}

布局文件:

代码语言:javascript复制
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent"
    android:layout_height="match_parent" android:paddingLeft="@dimen/activity_horizontal_margin"
    android:paddingRight="@dimen/activity_horizontal_margin"
    android:paddingTop="@dimen/activity_vertical_margin"
    android:paddingBottom="@dimen/activity_vertical_margin" tools:context=".MainActivity">
    <EditText
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:inputType="textPersonName"
        android:ems="10"
        android:id="@ id/editText"
        android:layout_alignParentTop="true"
        android:layout_centerHorizontal="true" />

    <EditText
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:inputType="textPassword"
        android:ems="10"
        android:id="@ id/editText2"
        android:layout_below="@ id/editText"
        android:layout_alignStart="@ id/editText" />

    <Button
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="确定"
        android:id="@ id/button"
        android:layout_below="@ id/editText2"
        android:layout_toEndOf="@ id/textView2" />

    <Button
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="取消"
        android:id="@ id/button2"
        android:layout_alignTop="@ id/button"
        android:layout_alignEnd="@ id/editText2" />

    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="账号"
        android:id="@ id/textView"
        android:layout_above="@ id/editText2"
        android:layout_toStartOf="@ id/editText" />

    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="密码"
        android:id="@ id/textView2"
        android:layout_alignBottom="@ id/editText2"
        android:layout_toStartOf="@ id/editText2" />
</RelativeLayout>

工具类:

代码语言:javascript复制
package com.example.test.aquery_test_2.entity;
import com.google.gson.Gson;
import java.util.List;
/**
 * Created by Administrator on 2015/9/10.
 */
public class JsonEntity {
    //利用Gson进行json数据和对象之间的转换。
    private Gson gson;
    List<User> list;
    public JsonEntity(List<User> list){
        this.list=list;
        gson=new Gson();
    }
    public String createJSONObject() {
        //把User对象变为json的数据格式。
        String jsonString=gson.toJson(list);
        return jsonString;
    }
}

实体类:

代码语言:javascript复制
package com.example.test.aquery_test_2.entity;
/**
 * Created by Administrator on 2015/9/8.
 */
//实体User对象
public class User {
    private String username;
    private String password;
    public User(String username,String password){
        this.username=username;
        this.password=password;
    }
    public void setUsername(String username) {
        this.username = username;
    }

    public String getUsername() {
        return username;
    }

    public void setPassword(String password) {
        this.password = password;
    }

    public String getPassword() {
        return password;
    }

    @Override
    public String toString() {
        return username " " password;
    }
}

最后记得在配置文件中加入

代码语言:javascript复制
<uses-permission android:name="android.permission.INTERNET" />

不然会出错。Android端的就完了下面是SSH搭建的服务端,这里只给出关键代码。

服务端的action:

代码语言:javascript复制
package com.ge.action;
import java.io.IOException;
import java.io.PrintWriter;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import net.sf.json.JSONObject;

import org.apache.struts2.ServletActionContext;

import com.androidquery.AQuery;
import com.ge.dao.UsersDao;
import com.ge.entity.Users;
import com.google.gson.Gson;
import com.google.gson.reflect.TypeToken;
import com.opensymphony.xwork2.ActionContext;
public class LoginAction {
	private String username;
	private String password;
	private UsersDao usersdao;
	//利用spring进行依赖注入,不需要new 对象就可以实现数据的初始化。
	public void setUsersdao(UsersDao usersdao) {
		this.usersdao = usersdao;
	}
	
	public String getUsername() {
		return username;
	}

	public void setUsername(String username) {
		this.username = username;
	}

	public String getPassword() {
		return password;
	}

	public void setPassword(String password) {
		this.password = password;
	}

	public String execute() throws IOException{
		//获取Server中的request和response.
		HttpServletRequest request = ServletActionContext.getRequest();
		HttpServletResponse response = ServletActionContext.getResponse();
		response.setCharacterEncoding("utf-8");
	    request.setCharacterEncoding("utf-8");
	    //获取从客户端传送过来的json数据
		String json=request.getParameter("json");
		System.out.println("json1=" json);
		//利用Gson把json数据转换成Users对象,然后利用hibernate实现添加数据到数据库的功能
		Gson gson=new Gson();
		   List<Users>list=gson.fromJson(json,new TypeToken<List<Users>>(){}.getType());
		   for(int i=0;i<list.size();i  ){
			   usersdao.saveUsers(list.get(i));
		   }
		   PrintWriter writer=response.getWriter();
		   writer.println("添加成功!!!");
		   writer.flush();
		   writer.close(); 
		return "s";
	}
}

服务端的连接数据库并进行操作的代码:

代码语言:javascript复制
package com.ge.dao;

import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.Transaction;
import org.hibernate.cfg.Configuration;
import com.ge.entity.Users;
public class UsersDao {
	public void saveUsers(Users users){
		Configuration cfg = new Configuration().configure();
		SessionFactory sf = cfg.buildSessionFactory();
		Session s = sf.openSession();
		s.beginTransaction();
		//实现添加数据的功能
		s.save(users);
		Transaction t = s.getTransaction();
		t.commit();
	}
}

运行时后台得到的数据为:

代码语言:javascript复制
json1=[{"password":"eyuii","username":"12314"}]

数据库中相应的结果为:

有几点要注意

1.数据库中的字段是通过hibernate映射到代码中的并生成代码,所以数据库表不能随便写,要和代码相对应才行。

2.Android端URL中IP必须是联网时的IP,不能是localhost。

3.记得在Android端中配置文件处添加网络权限,否则会出错。

4.Aquery中的ajax最后返回的是json的字符串形式而不是JSONObject类型

5.数据库我是用sql server来建立的,这个表我也放在下载文件中了,大家直接导入就可以使用了。

下载地址为: http://download.csdn.net/detail/linzhiqiang0316/9097455

0 人点赞