Android调用asp.net编写的*.ashx(一般处理程序)获取数据

简介: 第一步: asp.net 编写ssjc.ashxusing System;using System.
第一步: asp.net 编写ssjc.ashx
<%@ WebHandler Language="C#" Class="ssjc" %>

using System;
using System.Web;
using System.Text;
using Syit.Common;
using System.Data;

public class ssjc : IHttpHandler {

    //Oracle数据库连接类
    OracleDM dm = new OracleDM();
    
    public void ProcessRequest(HttpContext context)
    {
        context.Response.ContentType = "text/plain";
        StringBuilder jsonBuilder = new StringBuilder();
        jsonBuilder.Append("{\"parent\":");
        jsonBuilder.Append("{\"children\":");
        jsonBuilder.Append("[");
        string strSQL = @"select t1.ID,t1.STCD,t1.NAME,t1.LGTD,t1.LTTD,t2.WATERLEVEL,t2.TIME from ST_CROSS_BRIDGE t1  left join
            (
            SELECT * FROM (SELECT ROW_NUMBER() OVER(PARTITION BY BRIDGEID ORDER BY TIME DESC ) lev,t.* from st_bridge_waterlevel t)
                               WHERE lev = 1 ORDER BY TIME DESC
            ) t2 on t1.stcd=t2.bridgeid";
        DataSet ds = dm.getsql(strSQL);
        foreach (DataRowView drv in ds.Tables[0].DefaultView)
        {
            jsonBuilder.Append("{\"id\":\"" + drv["ID"].ToString().Trim() + "\",\"depth\":\"" + (string.IsNullOrEmpty(drv["WATERLEVEL"].ToString().Trim())?"0" : drv["WATERLEVEL"].ToString().Trim()) + "\",\"name\":\"" + drv["NAME"].ToString().Trim() + "\",\"lgtd\":\"" + drv["LGTD"].ToString().Trim() + "\",\"lttd\":\"" + drv["LTTD"].ToString().Trim() + "\"},");
        }
        string jsonString = jsonBuilder.ToString().TrimEnd(',');
        jsonString+="]}}";
        context.Response.Write(jsonString);
    }

    public bool IsReusable
    {
        get
        {
            return true;
        }
    }

}




第二步:编写SYIT_SSJC.java文件继承自Activity类

package cn.superyouth.www;


import java.io.IOException;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;


import org.apache.http.HttpResponse;
import org.apache.http.HttpStatus;
import org.apache.http.client.ClientProtocolException;
import org.apache.http.client.HttpClient;
import org.apache.http.client.methods.HttpGet;
import org.apache.http.impl.client.DefaultHttpClient;
import org.apache.http.util.EntityUtils;
import org.json.JSONArray;
import org.json.JSONException;
import org.json.JSONObject;



import android.app.Activity;
import android.app.AlertDialog;
import android.app.Dialog;
import android.content.Context;
import android.content.Intent;
import android.graphics.Bitmap;
import android.graphics.drawable.Drawable;
import android.os.AsyncTask;
import android.os.Bundle;
import android.os.Handler;
import android.os.Message;
import android.util.Log;
import android.view.View;
import android.webkit.WebSettings;
import android.webkit.WebView;
import android.webkit.WebViewClient;
import android.widget.Button;
import android.widget.ImageView;
import android.widget.LinearLayout;
import android.widget.TextView;
import android.widget.Toast;


public class SYIT_SSJC extends Activity implements MKGeneralListener {

	private Toast mToast;
	boolean isError = false;
	List<Map<String,Object>> curData = new ArrayList<Map<String, Object>>(5);				// 当前页面使用数据


	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.syit_ssjc);

	     // 开启线程
	 		new Thread() {
	 			@Override
	 			public void run() {
	 				try {
	 					
	 				} catch (Exception e) {
	 					isError = true;
	 					System.out.println(e.toString());
	 				}
	 				handler.sendEmptyMessage(0); 				
	 			}
	 		}.start();
	}
	
	/**
	 * 用Handler来更新UI
	 */
	private Handler handler = new Handler() {
		public void handleMessage(Message msg) {
			if(isError){
				 //创建提示
				Dialog alertDialog = new AlertDialog.Builder(SYIT_SSJC.this). 
		                setTitle("提示"). 
		                setMessage("服务器无响应,请稍候再试!"). 
		                setIcon(R.drawable.ic_launcher). 
		                create(); 
		        alertDialog.show();
			}else{
				new ReadHttpGet().execute("http://61.190.32.10/CityLowerRoadSys/ashx/ssjc.ashx");  //这里是核心代码部分
			}
		}
	};
	
	// * 显示Toast消息
	private void showToast(String msg) {
		if (mToast == null) {
			mToast = Toast.makeText(this, msg, Toast.LENGTH_SHORT);
		} else {
			mToast.setText(msg);
			mToast.setDuration(Toast.LENGTH_SHORT);
		}
		mToast.show();
	}


	class ReadHttpGet extends AsyncTask<Object, Object, Object> {
		@Override
		protected Object doInBackground(Object... params) {
			HttpGet httpRequest = new HttpGet(params[0].toString());
			try {
				HttpClient httpClient = new DefaultHttpClient();
				HttpResponse httpResponse = httpClient.execute(httpRequest);
				if (httpResponse.getStatusLine().getStatusCode() == HttpStatus.SC_OK) {
					String strResult = EntityUtils.toString(httpResponse
							.getEntity());
					return strResult;
				} else {
					return "请求出错";
				}
			} catch (ClientProtocolException e) {
			} catch (IOException e) {
				e.printStackTrace();
			}
			return null;
		}


		protected void onCancelled(Object result) {
			super.onCancelled();
		}

                 //取得的数据保存在集合List<Map<String,Object>> curData 中,然后怎么使用都可以了
		@Override
		protected void onPostExecute(Object result) {
			super.onPostExecute(result);
			try {
				// 创建一个JSON对象
				JSONObject jsonObject = new JSONObject(result.toString())
						.getJSONObject("parent");
				// 获取某个对象的JSON数组
				JSONArray jsonArray = jsonObject.getJSONArray("children");
				StringBuilder builder = new StringBuilder();
				for (int i = 0; i < jsonArray.length(); i++) {
					// 新建一个JSON对象,该对象是某个数组里的其中一个对象
					JSONObject jsonObject2 = (JSONObject) jsonArray.opt(i);
					Map<String, Object> map = new HashMap<String, Object>();
					map.put("id", jsonObject2.getString("id"));
					map.put("name", jsonObject2.getString("name"));
					map.put("depth", jsonObject2.getString("depth"));
					map.put("lgtd", jsonObject2.getString("lgtd"));
					map.put("lttd", jsonObject2.getString("lttd"));
					curData.add(map);
				}
				
			} catch (JSONException e) {
				e.printStackTrace();
			}
		}


		protected void onPreExecute() {
			Toast.makeText(getApplicationContext(), "开始HTTP GET请求",
					Toast.LENGTH_LONG).show();
		}


		protected void onProgressUpdate(Object... values) {
			super.onProgressUpdate(values);
		}
	}
}


相关文章
|
4月前
|
开发工具 Android开发 开发者
Android平台如何不推RTMP|不发布RTSP流|不实时录像|不回传GB28181数据时实时快照?
本文介绍了一种在Android平台上实现实时截图快照的方法,尤其适用于无需依赖系统接口的情况,如在RTMP推送、RTSP服务或GB28181设备接入等场景下进行截图。通过底层模块(libSmartPublisher.so)实现了截图功能,封装了`SnapShotImpl.java`类来管理截图流程。此外,提供了关键代码片段展示初始化SDK实例、执行截图、以及在Activity销毁时释放资源的过程。此方案还考虑到了快照数据的灵活处理需求,符合GB/T28181-2022的技术规范。对于寻求更灵活快照机制的开发者来说,这是一个值得参考的设计思路。
|
2月前
|
安全 Java 网络安全
Android远程连接和登录FTPS服务代码(commons.net库)
Android远程连接和登录FTPS服务代码(commons.net库)
24 1
|
2月前
|
存储 大数据 数据库
Android经典面试题之Intent传递数据大小为什么限制是1M?
在 Android 中,使用 Intent 传递数据时存在约 1MB 的大小限制,这是由于 Binder 机制的事务缓冲区限制、Intent 的设计初衷以及内存消耗和性能问题所致。推荐使用文件存储、SharedPreferences、数据库存储或 ContentProvider 等方式传递大数据。
77 0
|
2月前
|
XML 存储 安全
C#开发的程序如何良好的防止反编译被破解?ConfuserEx .NET混淆工具使用介绍
C#开发的程序如何良好的防止反编译被破解?ConfuserEx .NET混淆工具使用介绍
69 0
|
3月前
|
Ubuntu 持续交付 API
如何使用 dotnet pack 打包 .NET 跨平台程序集?
`dotnet pack` 是 .NET Core 的 NuGet 包打包工具,用于将代码打包成 NuGet 包。通过命令 `dotnet pack` 可生成 `.nupkg` 文件。使用 `--include-symbols` 和 `--include-source` 选项可分别创建包含调试符号和源文件的包。默认情况下,`dotnet pack` 会先构建项目,可通过 `--no-build` 跳过构建。此外,还可以使用 `--output` 指定输出目录、`-c` 设置配置等。示例展示了创建类库项目并打包的过程。更多详情及命令选项,请参考官方文档。
208 11
|
3月前
|
存储 运维
.NET开发必备技巧:使用Visual Studio分析.NET Dump,快速查找程序内存泄漏问题!
.NET开发必备技巧:使用Visual Studio分析.NET Dump,快速查找程序内存泄漏问题!
|
3月前
|
自然语言处理 C# 图形学
使用dnSpyEx对.NET Core程序集进行反编译、编辑和调试
使用dnSpyEx对.NET Core程序集进行反编译、编辑和调试
|
4月前
|
JSON Java Android开发
Android 开发者必备秘籍:轻松攻克 JSON 格式数据解析难题,让你的应用更出色!
【8月更文挑战第18天】在Android开发中,解析JSON数据至关重要。JSON以其简洁和易读成为首选的数据交换格式。开发者可通过多种途径解析JSON,如使用内置的`JSONObject`和`JSONArray`类直接操作数据,或借助Google提供的Gson库将JSON自动映射为Java对象。无论哪种方法,正确解析JSON都是实现高效应用的关键,能帮助开发者处理网络请求返回的数据,并将其展示给用户,从而提升应用的功能性和用户体验。
102 1
|
4月前
|
缓存 API Android开发
Android经典实战之Kotlin Flow中的3个数据相关的操作符:debounce、buffer和conflate
本文介绍了Kotlin中`Flow`的`debounce`、`buffer`及`conflate`三个操作符。`debounce`过滤快速连续数据,仅保留指定时间内的最后一个;`buffer`引入缓存减轻背压;`conflate`仅保留最新数据。通过示例展示了如何在搜索输入和数据流处理中应用这些操作符以提高程序效率和用户体验。
54 6
|
4月前
|
开发框架 .NET 数据库连接
闲话 Asp.Net Core 数据校验(三)EF Core 集成 FluentValidation 校验数据例子
闲话 Asp.Net Core 数据校验(三)EF Core 集成 FluentValidation 校验数据例子