Android动态创建表格

本文介绍了在Android开发中如何动态创建表格。首先,Android通过http请求获取服务器端以json格式返回的结果集。接着,详细讲解了json的封装和解析过程,包括如何将数据库结果集转化为jsonArray,并在Android端使用JSONArray进行解析。最后,展示了如何利用解析后的数据动态生成表格,包括创建TableRow和TableCell的代码,以及使用BaseAdapter将数据添加到ListView中。
摘要由CSDN通过智能技术生成

一、摘要

     最近接触到Android开发,由于涉及到Android和服务器端要发送http请求,服务器端通过查表,可以得到结果集(ResultSet),在服务器端,将结果集封装成json对象,以字符串的形式响应给Android端。Android端则需要将对应的字符串再进行一次解析,形成json字符串。然后利用json字符串再在页面动态生成一张表格。这就是大致需要完成的项目中一个环节,下面将上述自己做的过程详细写出来。

    

二、Android发送http请求封装

    这里,我借用网友的代码,他的post请求参数封装非常完善,以servlet为服务器语言为例,发送http请求源代码如下:

String uri = "http://192.168.191.1:8080/LYunMIS/servlet/ProcessStorageList";
		Map<String, String> params = new HashMap<String, String>();
		params.put("operator", "select");
		params.put("tablename", Constant.Tbl_ProductStorage);//表名
		params.put("NowAdmStatus", "0");//查询条件
		String responseStr = URLUtil.submitPostData(params, Constant.UTF8, uri);
URLUtil.java
public class URLUtil {

	public static HttpURLConnection createConn(String uri,String type,String charset) {
		URL url = null;
		HttpURLConnection urlConn = null;
		try {
			url = new URL(uri);
			urlConn = (HttpURLConnection) url.openConnection();
			urlConn.setDoInput(true);//设置输入流采用字节流
			urlConn.setDoOutput(true);
			urlConn.setRequestMethod(type);//请求方式为POST
			urlConn.setUseCaches(false);//不起用缓存
			urlConn.setRequestProperty("Content-Type", "application/x-www-form-urlencoded");//设置meta参数
			urlConn.setRequestProperty("Charset", charset);
			
		} catch (MalformedURLException e) {
			e.printStackTrace();
		} catch (ProtocolException e) {
			e.printStackTrace();
		} catch (IOException e) {
			e.printStackTrace();
		}
		return urlConn;
		
	}
	
    public static String submitPostData(Map<String, String> params, String encode, String uri) {
        byte[] data = getRequestData(params, encode).toString().getBytes();//获得请求体
        try {            
            URL url = new URL(uri);
			HttpURLConnection httpURLConnection = (HttpURLConnection)url.openConnection();
            httpURLConnection.setConnectTimeout(3000);        	//设置连接超时时间
            httpURLConnection.setDoInput(true);                  //打开输入流,以便从服务器获取数据
            httpURLConnection.setDoOutput(true);                 //打开输出流,以便向服务器提交数据
            httpURLConnection.setRequestMethod("POST");    	//设置以Post方式提交数据
            httpURLConnection.setUseCaches(false);               //使用Post方式不能使用缓存
            //设置请求体的类型是文本类型
            httpURLConnection.setRequestProperty("Content-Type", "application/x-www-form-urlencoded");
            //设置请求体的长度
            httpURLConnection.setRequestProperty("Content-Length", String.valueOf(data.length));
            //获得输出流,向服务器写入数据
            OutputStream outputStream = httpURL
评论 13
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值