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

转载随意!


目录
相关文章
|
9月前
|
存储 机器学习/深度学习 API
Android API Level 到底是什么?和安卓什么关系?应用发布如何知道自己的版本?优雅草卓伊凡
Android API Level 到底是什么?和安卓什么关系?应用发布如何知道自己的版本?优雅草卓伊凡
1415 31
Android API Level 到底是什么?和安卓什么关系?应用发布如何知道自己的版本?优雅草卓伊凡
|
Java API 数据库
构建RESTful API已经成为现代Web开发的标准做法之一。Spring Boot框架因其简洁的配置、快速的启动特性及丰富的功能集而备受开发者青睐。
【10月更文挑战第11天】本文介绍如何使用Spring Boot构建在线图书管理系统的RESTful API。通过创建Spring Boot项目,定义`Book`实体类、`BookRepository`接口和`BookService`服务类,最后实现`BookController`控制器来处理HTTP请求,展示了从基础环境搭建到API测试的完整过程。
503 4
|
XML JSON API
ServiceStack:不仅仅是一个高性能Web API和微服务框架,更是一站式解决方案——深入解析其多协议支持及简便开发流程,带您体验前所未有的.NET开发效率革命
【10月更文挑战第9天】ServiceStack 是一个高性能的 Web API 和微服务框架,支持 JSON、XML、CSV 等多种数据格式。它简化了 .NET 应用的开发流程,提供了直观的 RESTful 服务构建方式。ServiceStack 支持高并发请求和复杂业务逻辑,安装简单,通过 NuGet 包管理器即可快速集成。示例代码展示了如何创建一个返回当前日期的简单服务,包括定义请求和响应 DTO、实现服务逻辑、配置路由和宿主。ServiceStack 还支持 WebSocket、SignalR 等实时通信协议,具备自动验证、自动过滤器等丰富功能,适合快速搭建高性能、可扩展的服务端应用。
953 3
|
人工智能 前端开发 API
Gemini Coder:基于 Google Gemini API 的开源 Web 应用生成工具,支持实时编辑和预览
Gemini Coder 是一款基于 Google Gemini API 的 AI 应用生成工具,支持通过文本描述快速生成代码,并提供实时代码编辑和预览功能,简化开发流程。
1177 38
Gemini Coder:基于 Google Gemini API 的开源 Web 应用生成工具,支持实时编辑和预览
|
12月前
|
人工智能 搜索推荐 IDE
突破网页数据集获取难题:Web Unlocker API 助力 AI 训练与微调数据集全方位解决方案
本文介绍了Web Unlocker API、Web-Scraper和SERP API三大工具,助力解决AI训练与微调数据集获取难题。Web Unlocker API通过智能代理和CAPTCHA绕过技术,高效解锁高防护网站数据;Web-Scraper支持动态内容加载,精准抓取复杂网页信息;SERP API专注搜索引擎结果页数据抓取,适用于SEO分析与市场研究。这些工具大幅降低数据获取成本,提供合规保障,特别适合中小企业使用。粉丝专属体验入口提供2刀额度,助您轻松上手!
719 2
|
XML JSON API
Understanding RESTful API and Web Services: Key Differences and Use Cases
在现代软件开发中,RESTful API和Web服务均用于实现系统间通信,但各有特点。RESTful API遵循REST原则,主要使用HTTP/HTTPS协议,数据格式多为JSON或XML,适用于无状态通信;而Web服务包括SOAP和REST,常用于基于网络的API,采用标准化方法如WSDL或OpenAPI。理解两者区别有助于选择适合应用需求的解决方案,构建高效、可扩展的应用程序。
|
机器学习/深度学习 开发框架 API
Python 高级编程与实战:深入理解 Web 开发与 API 设计
在前几篇文章中,我们探讨了 Python 的基础语法、面向对象编程、函数式编程、元编程、性能优化、调试技巧以及数据科学和机器学习。本文将深入探讨 Python 在 Web 开发和 API 设计中的应用,并通过实战项目帮助你掌握这些技术。
|
Kubernetes 安全 Devops
有效抵御网络应用及API威胁,聊聊F5 BIG-IP Next Web应用防火墙
有效抵御网络应用及API威胁,聊聊F5 BIG-IP Next Web应用防火墙
353 10
有效抵御网络应用及API威胁,聊聊F5 BIG-IP Next Web应用防火墙
|
前端开发 API 开发者
Python Web开发者必看!AJAX、Fetch API实战技巧,让前后端交互如丝般顺滑!
在Web开发中,前后端的高效交互是提升用户体验的关键。本文通过一个基于Flask框架的博客系统实战案例,详细介绍了如何使用AJAX和Fetch API实现不刷新页面查看评论的功能。从后端路由设置到前端请求处理,全面展示了这两种技术的应用技巧,帮助Python Web开发者提升项目质量和开发效率。
376 1
|
JSON API 数据格式
如何使用Python和Flask构建一个简单的RESTful API。Flask是一个轻量级的Web框架
本文介绍了如何使用Python和Flask构建一个简单的RESTful API。Flask是一个轻量级的Web框架,适合小型项目和微服务。文章从环境准备、创建基本Flask应用、定义资源和路由、请求和响应处理、错误处理等方面进行了详细说明,并提供了示例代码。通过这些步骤,读者可以快速上手构建自己的RESTful API。
848 2

热门文章

最新文章

下一篇
开通oss服务