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

转载随意!


目录
相关文章
|
8天前
|
JSON 前端开发 API
如何调用体育数据足篮接口API
本文介绍如何调用体育数据API:首先选择可靠服务商并注册获取密钥,接着阅读文档了解基础URL、端点、参数及请求头,然后使用Python等语言发送请求、解析JSON数据,最后将数据应用于Web、App或分析场景,同时注意密钥安全、速率限制与错误处理。
|
8天前
|
供应链 数据挖掘 API
揭秘天猫详情 API 接口:开启电商数据新大门
天猫详情API接口是电商数据利器,助力选品、市场调研与销售预测。通过获取商品价格、销量、评价等信息,提升决策效率,赋能企业精准运营,抢占市场先机。
38 0
|
8天前
|
JSON 自然语言处理 监控
淘宝关键词搜索与商品详情API接口(JSON数据返回)
通过商品ID(num_iid)获取商品全量信息,包括SKU规格、库存、促销活动、卖家信息、详情页HTML等。
|
8天前
|
Java API 开发者
揭秘淘宝详情 API 接口:解锁电商数据应用新玩法
淘宝详情API是获取商品信息的“金钥匙”,可实时抓取标题、价格、库存等数据,广泛应用于电商分析、比价网站与智能选品。合法调用,助力精准营销与决策,推动电商高效发展。(238字)
70 0
|
15天前
|
供应链 监控 安全
1688商品详情API接口实战指南:合规获取数据,驱动B2B业务增长
1688商品详情API(alibaba.product.get)是合规获取B2B商品数据的核心工具,支持全维度信息调用,助力企业实现智能选品、供应链优化与市场洞察,推动数字化转型。
|
15天前
|
人工智能 供应链 API
淘宝API商品详情接口全解析:从基础数据到深度挖掘
淘宝API商品详情接口不仅提供基础数据,更通过深度挖掘实现从数据到洞察的跨越。开发者需结合业务场景选择合适分析方法,利用AI标签、区块链溯源等新技术,最终实现数据驱动的电商业务创新。
|
15天前
|
缓存 监控 供应链
亚马逊 MWS API 实战:商品详情精准获取与跨境电商数据整合方案
本文详细解析亚马逊MWS API接口的技术实现,重点解决跨境商品数据获取中的核心问题。文章首先介绍MWS接口体系的特点,包括多站点数据获取、AWS签名认证等关键环节,并对比普通电商接口的差异。随后深入拆解API调用全流程,提供签名工具类、多站点客户端等可复用代码。针对跨境业务场景,文章还给出数据整合工具实现方案,支持缓存、批量处理等功能。最后通过实战示例展示多站点商品对比和批量选品分析的应用,并附常见问题解决方案。该技术方案可直接应用于跨境选品、价格监控等业务场景,帮助开发者高效获取亚马逊商品数据。
|
18天前
|
JSON API 数据安全/隐私保护
Python采集淘宝评论API接口及JSON数据返回全流程指南
Python采集淘宝评论API接口及JSON数据返回全流程指南
|
18天前
|
自然语言处理 监控 API
小红书爆文解码:用API分析互动数据,精准指导创作方向
在内容为王时代,爆文背后有科学公式!通过小红书API抓取百万笔记数据,提炼出点赞转化率、收藏价值系数、评论情感值三大核心指标,揭秘爆文特征不等式与内容元素矩阵,手把手教你用数据驱动创作,实现从0到百万曝光的逆袭!
112 0
|
19天前
|
JSON 缓存 自然语言处理
多语言实时数据微店商品详情API:技术实现与JSON数据解析指南
通过以上技术实现与解析指南,开发者可高效构建支持多语言的实时商品详情系统,满足全球化电商场景需求。

热门文章

最新文章