Xamarin android 调用Web Api(ListView使用远程数据)

简介: xamarin android如何调用sqlserver 数据库呢(或者其他的),很多新手都会有这个疑问。xamarin android调用远程数据主要有两种方式:在Android中保存数据或调用数据库可以利用SQLite,android中提供了几个类来管理SQLite数据库,对数据进行增删改查直接调用Asp.net Web API对数据进行增删改查这两种方式到底选择哪一种方式好一点呢?哪一种方式好不好我不敢确定,市场上大部分app都是调用api来clud的。

xamarin android如何调用sqlserver 数据库呢(或者其他的),很多新手都会有这个疑问。xamarin android调用远程数据主要有两种方式:

  1. 在Android中保存数据或调用数据库可以利用SQLite,android中提供了几个类来管理SQLite数据库,对数据进行增删改查
  2. 直接调用Asp.net Web API对数据进行增删改查

这两种方式到底选择哪一种方式好一点呢?哪一种方式好不好我不敢确定,市场上大部分app都是调用api来clud的。当然我也推荐大家使用web api来调用远程数据,至少目前来看我们公司都是使用web api来做的。好吧废话不多说,下面就是ListView来调用web api执行增删改查的例子。

先看一下效果图:


这个示例我还是拿之前的listview入门的例子做, xamarin android listview的用法,数据是直接调用远程的web api中的数据。主要实现步骤

  1. 新建一个web api的项目,写好要用到的方法。
  2. 在MainActivity.cs中发送请求并将相应的json字符串序列化成List集合

 web api中的 NewsControl.cs

using System.Collections.Generic;
using System.Linq;
using System.Net;
using System.Web.Http;
using WebApi10_9.Models;
namespace WebApi10_9.Controllers
{
    public class NewsController : ApiController
    {
        List<News> list = new List<News>() {
              new News (1001,"加内特的历史地位能在NBA排第几,超越德国战车?",1200),
                new News (1002,"盘点新赛季最期待的十场比赛,无湖人比赛?",560),
                new News (1003,"库里新赛季铁定无缘常规赛MVP",158200),
                new News (1004,"我服,库里,杜兰特,汤普森谁才是出手的最佳选择",900),
                new News (1005,"易建联的出场时间你能猜出来吗,大概多少",960),
                  new News (1006,"卡戴珊三姐妹睡多少男人",960),
                  new News(1007,"科比退役后湖人到底失去多少中国的粉丝",4986),
                  new News(1008,"科比退役湖人签中国篮球当家背后隐藏了多少阴谋",65987)
       };
        public IEnumerable<News> GetAllNews()
        {
            return list;
        }
        [HttpGet]
        public List<News> Remove(int id)
        {
            var item = list.FirstOrDefault(p => p.Id == id);
            if (item == null)
               throw new HttpResponseException(HttpStatusCode.NotFound);
            list.Remove(item);
            return list;
        }
    }
}

MainActivity.cs

using Android.App;
using Android.Content;
using Android.Views;
using Android.Widget;
using Android.OS;
using System.Collections.Generic;
using DrawerLayout.Adapter;
using Newtonsoft.Json;
using System.Net;
using System.Text;
using System.IO;
namespace DrawerLayout
{
    [Activity(Label = "ListViewDemo", MainLauncher = true, Icon = "@drawable/icon")]
    public class MainActivity : Activity
    {
        int count = 1;
        private List<News> data;
        private Context context;
        private NewsAdapter adapter;
        private ListView lv_test;
        protected override void OnCreate(Bundle bundle)
        {
            base.OnCreate(bundle);
            SetContentView(Resource.Layout.Main);
            //data = new List<News>() {
            //    new News (1001,"加内特的历史地位能在NBA排第几,超越德国战车?",1200),
            //    new News (1002,"盘点新赛季最期待的十场比赛,无湖人比赛?",560),
            //    new News (1003,"库里新赛季铁定无缘常规赛MVP",158200),
            //    new News (1004,"我服,库里,杜兰特,汤普森谁才是出手的最佳选择",900),
            //    new News (1005,"易建联的出场时间你能猜出来吗,大概多少",960),
            //      new News (1006,"卡戴珊三姐妹睡多少男人",960),
            //      new News(1007,"科比退役后湖人到底失去多少中国的粉丝",4986),
            //      new News(1008,"科比退役湖人签中国篮球当家背后隐藏了多少阴谋",65987)
            //};
            string url = "http://192.168.1.172:100/api/news";
            string content = AccessData.GetRouteData(url ); //接收到响应的json 字符串
            List<News> list = JsonConvert.DeserializeObject<List<News>>(content); //已经获取到远程数据的List<News>和之前的本地data就是一样的了。
            adapter = new NewsAdapter(list,this);
            lv_test = FindViewById<ListView>(Resource.Id.lv_test);
            View lv_header = LayoutInflater.Inflate(Resource.Layout.lv_header, null);
            lv_test.AddHeaderView(lv_header);
            lv_test.Adapter = adapter;
        }
        public class AccessData
        {
            public static string GetRouteData (string url)
            {
                //构建请求
                HttpWebRequest request = (HttpWebRequest)WebRequest.Create(url);
                request.ContentType = "text/json;chartset=UTF-8";
                //request.UserAgent = "";
                request.Method = "Get";
                //接收响应
                HttpWebResponse response = (HttpWebResponse)request.GetResponse();
                Stream stream = response.GetResponseStream();
                StreamReader streamReader = new StreamReader(stream, Encoding.UTF8);
                string retString = streamReader.ReadToEnd();
                return retString;
            }
        }
    }
}
当然还有一个单击删除的事件还没有写,这个在NewsAdapter.cs里面写。

        public override View GetView(int position, View convertView, ViewGroup parent)
        {
            convertView = LayoutInflater.From(context).Inflate(Resource.Layout.lv_test,parent,false);
            ViewHolder holder = null;
            if (convertView != null)
            {
                holder = new ViewHolder();
                holder.btn = convertView.FindViewById<Button>(Resource.Id.btn_delete);
                holder.title = convertView.FindViewById<TextView>(Resource.Id.tv_title);
                holder.pv = convertView.FindViewById<TextView>(Resource.Id.tv_pv);
            }
            else
            {
                convertView.Tag = holder;
            }
            holder.pv.Text = data[position].Pv.ToString();
            holder.title.Text = data[position].Title;
            holder.btn.Click += (s, e) => DeleteClick(data[position].Id,position);
            return convertView;
        }
        public void DeleteClick(int id,int position)
        {
            string url = "http://192.168.1.172:100/api/news/"+id;
            string content = AccessData.GetRouteData(url); //已经接收到响应的json 字符串 
            Toast.MakeText(context,data[position].Title+"删除成功",ToastLength.Short).Show();
            List<News> list = JsonConvert.DeserializeObject<List<News>>(content);
            data = list;
            NotifyDataSetChanged();
        }
    }
    public class ViewHolder:Java.Lang.Object
    {
        public TextView title;
        public TextView pv;
        public Button btn;
    }

好了,这样就大功告成了。那么问题来了,上面发送http请求,然后又接收响应再序列化,这还仅仅是一个简单的例子,要是复杂实用一点的话,要写很多很多代码,这里我推荐一个非常好的第三方组件,http请求响应第三方组件RestSharp用的非常广泛。用法很简单,看完这篇大概你就懂了 RestSharp的10分钟入门实例。我为什么推荐大家使用这个第三方组件呢,因为本屌所在公司也是用这个的,好东西,就是要懂得分享,当然那种直接利用HttpWebRequest ,HttpWebResonse对象来获取文件流再序列化成List集合的原始方法肯定是要知道的。直接上代码,结果还是一样的。哦,先先Nuget下载RestSharp 才能引用。


   protected override void OnCreate(Bundle bundle)
        {
            base.OnCreate(bundle);
            SetContentView(Resource.Layout.Main);
            string url = "http://192.168.1.172:100/api/news";
           <span style="color:#ff0000;"> var client = new RestClient(url);//创建客户端请求
            var request = new RestRequest();
            //RestResponse response = (RestResponse)client.Execute(request);
            //string responseStr = response.Content; 这两句获取json字符串,下面两句获取集合也很简洁
            IRestResponse<List<News>> responseList = client.Get<List<News>>(request);
            List<News> list = responseList.Data;</span>
            //string content = AccessData.GetRouteData(url ); //接收到响应的json 字符串
            //List<News> list = JsonConvert.DeserializeObject<List<News>>(content); //已经获取到远程数据的List<News>和之前的本地data就是一样的了。
            adapter = new NewsAdapter(list,this);
            lv_test = FindViewById<ListView>(Resource.Id.lv_test);
            View lv_header = LayoutInflater.Inflate(Resource.Layout.lv_header, null);
            lv_test.AddHeaderView(lv_header);
            lv_test.Adapter = adapter;
        }

删除也是差不多的,所以不贴了,只需要这几句就可以了实现发送请求接收响应了。大力推荐使用RestSharp。代码下载址: xamarin android listview调用web api

作者:张林

原文地址:http://blog.csdn.net/kebi007/article/details/52770808

转载随意!


目录
相关文章
|
3月前
|
JSON 安全 API
亚马逊商品列表API秘籍!轻松获取商品列表数据
亚马逊商品列表API(SP-API)提供标准化接口,支持通过关键词、分类、价格等条件搜索商品,获取ASIN、价格、销量等信息。采用OAuth 2.0认证与AWS签名,保障安全。数据以JSON格式传输,便于开发者批量获取与分析。
|
3月前
|
JSON 缓存 算法
如何通过API获取1688商品类目数据:技术实现指南
1688开放平台提供alibaba.category.get接口,支持获取全量商品类目树。RESTful架构,返回JSON数据,含类目ID、名称、层级等信息。需注册账号、创建应用并授权。请求需签名认证,QPS限10次,建议缓存更新周期≥24小时。
398 2
|
3月前
|
JSON 监控 API
小红书笔记评论API:一键获取分层评论与用户互动数据
小红书笔记评论API可获取指定笔记的评论详情,包括内容、点赞数、评论者信息等,支持分页与身份认证,返回JSON格式数据,适用于舆情监控、用户行为分析等场景。
|
4月前
|
供应链 监控 安全
1688商品详情API接口实战指南:合规获取数据,驱动B2B业务增长
1688商品详情API(alibaba.product.get)是合规获取B2B商品数据的核心工具,支持全维度信息调用,助力企业实现智能选品、供应链优化与市场洞察,推动数字化转型。
|
3月前
|
数据采集 JSON API
微店API使用指南:高效获取商品列表数据
本文介绍如何使用Python爬虫调用微店item_search接口,根据关键词搜索商品并获取商品列表数据,涵盖请求方式、JSON数据解析、分页参数设置及筛选排序功能,适用于电商数据分析与竞品研究。
|
3月前
|
JSON API 数据格式
淘宝拍立淘按图搜索API系列,json数据返回
淘宝拍立淘按图搜索API系列通过图像识别技术实现商品搜索功能,调用后返回的JSON数据包含商品标题、图片链接、价格、销量、相似度评分等核心字段,支持分页和详细商品信息展示。以下是该API接口返回的JSON数据示例及详细解析:
|
3月前
|
JSON 算法 API
Python采集淘宝商品评论API接口及JSON数据返回全程指南
Python采集淘宝商品评论API接口及JSON数据返回全程指南
|
3月前
|
自然语言处理 算法 数据可视化
看球总刷比分?好奇数据哪来的?你该认识一下「体育API」了
体育API是赛事数据的“幕后搬运工”,实时同步比分、赛程、球员统计等信息,支撑各类应用提供精准推送、深度分析与互动体验,让观赛更智能高效。
446 150
|
3月前
|
JSON API 数据安全/隐私保护
Python采集淘宝拍立淘按图搜索API接口及JSON数据返回全流程指南
通过以上流程,可实现淘宝拍立淘按图搜索的完整调用链路,并获取结构化的JSON商品数据,支撑电商比价、智能推荐等业务场景。
|
4月前
|
JSON 前端开发 API
如何调用体育数据足篮接口API
本文介绍如何调用体育数据API:首先选择可靠服务商并注册获取密钥,接着阅读文档了解基础URL、端点、参数及请求头,然后使用Python等语言发送请求、解析JSON数据,最后将数据应用于Web、App或分析场景,同时注意密钥安全、速率限制与错误处理。
564 152