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

相关文章

Java调用Python代码的几种方法小结

《Java调用Python代码的几种方法小结》Python语言有丰富的系统管理、数据处理、统计类软件包,因此从java应用中调用Python代码的需求很常见、实用,本文介绍几种方法从java调用Pyt... 目录引言Java core使用ProcessBuilder使用Java脚本引擎总结引言python

Android数据库Room的实际使用过程总结

《Android数据库Room的实际使用过程总结》这篇文章主要给大家介绍了关于Android数据库Room的实际使用过程,详细介绍了如何创建实体类、数据访问对象(DAO)和数据库抽象类,需要的朋友可以... 目录前言一、Room的基本使用1.项目配置2.创建实体类(Entity)3.创建数据访问对象(DAO

java如何调用kettle设置变量和参数

《java如何调用kettle设置变量和参数》文章简要介绍了如何在Java中调用Kettle,并重点讨论了变量和参数的区别,以及在Java代码中如何正确设置和使用这些变量,避免覆盖Kettle中已设置... 目录Java调用kettle设置变量和参数java代码中变量会覆盖kettle里面设置的变量总结ja

使用Java编写一个文件批量重命名工具

《使用Java编写一个文件批量重命名工具》这篇文章主要为大家详细介绍了如何使用Java编写一个文件批量重命名工具,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录背景处理1. 文件夹检查与遍历2. 批量重命名3. 输出配置代码片段完整代码背景在开发移动应用时,UI设计通常会提供不

Android WebView的加载超时处理方案

《AndroidWebView的加载超时处理方案》在Android开发中,WebView是一个常用的组件,用于在应用中嵌入网页,然而,当网络状况不佳或页面加载过慢时,用户可能会遇到加载超时的问题,本... 目录引言一、WebView加载超时的原因二、加载超时处理方案1. 使用Handler和Timer进行超

.NET利用C#字节流动态操作Excel文件

《.NET利用C#字节流动态操作Excel文件》在.NET开发中,通过字节流动态操作Excel文件提供了一种高效且灵活的方式处理数据,本文将演示如何在.NET平台使用C#通过字节流创建,读取,编辑及保... 目录用C#创建并保存Excel工作簿为字节流用C#通过字节流直接读取Excel文件数据用C#通过字节

如何在页面调用utility bar并传递参数至lwc组件

1.在app的utility item中添加lwc组件: 2.调用utility bar api的方式有两种: 方法一,通过lwc调用: import {LightningElement,api ,wire } from 'lwc';import { publish, MessageContext } from 'lightning/messageService';import Ca

Android实现任意版本设置默认的锁屏壁纸和桌面壁纸(两张壁纸可不一致)

客户有些需求需要设置默认壁纸和锁屏壁纸  在默认情况下 这两个壁纸是相同的  如果需要默认的锁屏壁纸和桌面壁纸不一样 需要额外修改 Android13实现 替换默认桌面壁纸: 将图片文件替换frameworks/base/core/res/res/drawable-nodpi/default_wallpaper.*  (注意不能是bmp格式) 替换默认锁屏壁纸: 将图片资源放入vendo

Android平台播放RTSP流的几种方案探究(VLC VS ExoPlayer VS SmartPlayer)

技术背景 好多开发者需要遴选Android平台RTSP直播播放器的时候,不知道如何选的好,本文针对常用的方案,做个大概的说明: 1. 使用VLC for Android VLC Media Player(VLC多媒体播放器),最初命名为VideoLAN客户端,是VideoLAN品牌产品,是VideoLAN计划的多媒体播放器。它支持众多音频与视频解码器及文件格式,并支持DVD影音光盘,VCD影

poj 1258 Agri-Net(最小生成树模板代码)

感觉用这题来当模板更适合。 题意就是给你邻接矩阵求最小生成树啦。~ prim代码:效率很高。172k...0ms。 #include<stdio.h>#include<algorithm>using namespace std;const int MaxN = 101;const int INF = 0x3f3f3f3f;int g[MaxN][MaxN];int n