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

2024-03-17 12:32

本文主要是介绍Android调用asp.net编写的*.ashx(一般处理程序)获取数据,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

第一步: 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() {@Overridepublic 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> {@Overrideprotected 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 中,然后怎么使用都可以了@Overrideprotected 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);}}
}


这篇关于Android调用asp.net编写的*.ashx(一般处理程序)获取数据的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/818954

相关文章

javax.net.ssl.SSLHandshakeException:异常原因及解决方案

《javax.net.ssl.SSLHandshakeException:异常原因及解决方案》javax.net.ssl.SSLHandshakeException是一个SSL握手异常,通常在建立SS... 目录报错原因在程序中绕过服务器的安全验证注意点最后多说一句报错原因一般出现这种问题是因为目标服务器

python编写朋克风格的天气查询程序

《python编写朋克风格的天气查询程序》这篇文章主要为大家详细介绍了一个基于Python的桌面应用程序,使用了tkinter库来创建图形用户界面并通过requests库调用Open-MeteoAPI... 目录工具介绍工具使用说明python脚本内容如何运行脚本工具介绍这个天气查询工具是一个基于 Pyt

Java调用C#动态库的三种方法详解

《Java调用C#动态库的三种方法详解》在这个多语言编程的时代,Java和C#就像两位才华横溢的舞者,各自在不同的舞台上展现着独特的魅力,然而,当它们携手合作时,又会碰撞出怎样绚丽的火花呢?今天,我们... 目录方法1:C++/CLI搭建桥梁——Java ↔ C# 的“翻译官”步骤1:创建C#类库(.NET

MyBatis编写嵌套子查询的动态SQL实践详解

《MyBatis编写嵌套子查询的动态SQL实践详解》在Java生态中,MyBatis作为一款优秀的ORM框架,广泛应用于数据库操作,本文将深入探讨如何在MyBatis中编写嵌套子查询的动态SQL,并结... 目录一、Myhttp://www.chinasem.cnBATis动态SQL的核心优势1. 灵活性与可

Android学习总结之Java和kotlin区别超详细分析

《Android学习总结之Java和kotlin区别超详细分析》Java和Kotlin都是用于Android开发的编程语言,它们各自具有独特的特点和优势,:本文主要介绍Android学习总结之Ja... 目录一、空安全机制真题 1:Kotlin 如何解决 Java 的 NullPointerExceptio

C/C++和OpenCV实现调用摄像头

《C/C++和OpenCV实现调用摄像头》本文主要介绍了C/C++和OpenCV实现调用摄像头,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录准备工作1. 打开摄像头2. 读取视频帧3. 显示视频帧4. 释放资源5. 获取和设置摄像头属性

Mybatis嵌套子查询动态SQL编写实践

《Mybatis嵌套子查询动态SQL编写实践》:本文主要介绍Mybatis嵌套子查询动态SQL编写方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录前言一、实体类1、主类2、子类二、Mapper三、XML四、详解总结前言MyBATis的xml文件编写动态SQL

使用Python实现调用API获取图片存储到本地的方法

《使用Python实现调用API获取图片存储到本地的方法》开发一个自动化工具,用于从JSON数据源中提取图像ID,通过调用指定API获取未经压缩的原始图像文件,并确保下载结果与Postman等工具直接... 目录使用python实现调用API获取图片存储到本地1、项目概述2、核心功能3、环境准备4、代码实现

使用@Cacheable注解Redis时Redis宕机或其他原因连不上继续调用原方法的解决方案

《使用@Cacheable注解Redis时Redis宕机或其他原因连不上继续调用原方法的解决方案》在SpringBoot应用中,我们经常使用​​@Cacheable​​注解来缓存数据,以提高应用的性能... 目录@Cacheable注解Redis时,Redis宕机或其他原因连不上,继续调用原方法的解决方案1

C#通过进程调用外部应用的实现示例

《C#通过进程调用外部应用的实现示例》本文主要介绍了C#通过进程调用外部应用的实现示例,以WINFORM应用程序为例,在C#应用程序中调用PYTHON程序,具有一定的参考价值,感兴趣的可以了解一下... 目录窗口程序类进程信息类 系统设置类 以WINFORM应用程序为例,在C#应用程序中调用python程序