WinForm 对Web Api 增 册 改 查 的基本操作

时间:2023-02-20 11:28:21

WebApi代码:

 public class ValuesController : ApiController
{ Entities db=new Entities(); // GET api/values
public IEnumerable<Person> Get()
{
return db.Person;
} // GET api/values/5
public Person Get(int id)
{
return db.Person.FirstOrDefault(o => o.id == id);
} // POST api/values
public void Post([FromBody]Person value)
{
// People peple =(People) JsonConvert.DeserializeObject(value);
if (db.Person.FirstOrDefault(o => o.id == value.id) == null)
{
db.Person.Add(value);
}
db.SaveChanges();
} // PUT api/values/5
public void Put(int id, [FromBody]Person value)
{
var query = db.Person.FirstOrDefault(o => o.id == id);
if (query != null)
{
query.Name = value.Name;
}
db.SaveChanges();
} // DELETE api/values/5
public void Delete(int id)
{
var query = db.Person.FirstOrDefault(o => o.id == id);
if (query != null)
{
db.Person.Remove(query);
db.SaveChanges();
} }
}

Winform的基本代码:

 private Uri url = new Uri("http://localhost:18827/api/values");

 /// <summary>
/// 增
/// </summary>
private async void button1_Click(object sender, EventArgs e)
{
People people = new People();
people.Id = new Random().Next(, );
people.Name = "李" + people.Id;
string data = JsonConvert.SerializeObject(people); //创建一个处理序列化的DataContractJsonSerializer
DataContractJsonSerializer serializer = new DataContractJsonSerializer(typeof(People));
MemoryStream ms = new MemoryStream();
serializer.WriteObject(ms, people);
//一定要在这设定Position
ms.Position = ;
HttpContent content = new StreamContent(ms);//将MemoryStream转成HttpContent
//一定要设定Header
content.Headers.ContentType = new System.Net.Http.Headers.MediaTypeHeaderValue("application/json");
HttpClient client = new HttpClient();
//由HttpClient发出Post Method
HttpResponseMessage response = await client.PostAsync(url, content); if (response.IsSuccessStatusCode)
{ }
else
{ } } /// <summary>
/// 删除
/// </summary>
private async void button2_Click(object sender, EventArgs e)
{
HttpClient client = new HttpClient();
//由HttpClient发出Delete Method
HttpResponseMessage response = await client.DeleteAsync(url +"/1");
if (response.IsSuccessStatusCode)
{
MessageBox.Show("成功");
}
} //修改
private async void button3_Click(object sender, EventArgs e)
{
//创建一个处理序列化的DataContractJsonSerializer
DataContractJsonSerializer serializer = new DataContractJsonSerializer(typeof(People));
MemoryStream ms = new MemoryStream();
//将资料写入MemoryStream
serializer.WriteObject(ms, new People() { Id = , Name = "Hello ni" });
//一定要在这设定Position
ms.Position = ;
HttpContent content = new StreamContent(ms);//将MemoryStream转成HttpContent
content.Headers.ContentType = new System.Net.Http.Headers.MediaTypeHeaderValue("application/json");
HttpClient client = new HttpClient();
//由HttpClient发出Put Method
HttpResponseMessage response = await client.PutAsync(url + "/1", content);
if (response.IsSuccessStatusCode)
{
MessageBox.Show("成功");
}
} /// <summary>
/// 获取所有
/// </summary>
private void button4_Click(object sender, EventArgs e)
{
using (WebClient client = new WebClient())
{
client.Headers["Type"] = "GET";
client.Headers["Accept"] = "application/json";
client.Encoding = Encoding.UTF8;
client.DownloadStringCompleted += (senderobj, es) =>
{
if (es.Result != null)
{
var test = JsonConvert.DeserializeObject<People[]>(es.Result);
dataGridView1.DataSource = test;
}
};
client.DownloadStringAsync(url); }
}

WinForm 对Web Api 增 册 改 查  的基本操作

WinForm 对Web Api 增 册 改 查 的基本操作的更多相关文章

  1. sql技巧&lpar;增册改查&rpar;

    1 select * from wyl.t; 2 --将数据从t1导入t2 3 insert into t2(c1,c2) select c1,c2 from t1 where c1= xx and ...

  2. 好用的SQL TVP~~独家赠送&lbrack;增-删-改-查&rsqb;的例子

    以前总是追求新东西,发现基础才是最重要的,今年主要的目标是精通SQL查询和SQL性能优化.  本系列主要是针对T-SQL的总结. [T-SQL基础]01.单表查询-几道sql查询题 [T-SQL基础] ...

  3. iOS FMDB的使用&lpar;增&comma;删&comma;改&comma;查&comma;sqlite存取图片&rpar;

    iOS FMDB的使用(增,删,改,查,sqlite存取图片) 在上一篇博客我对sqlite的基本使用进行了详细介绍... 但是在实际开发中原生使用的频率是很少的... 这篇博客我将会较全面的介绍FM ...

  4. iOS sqlite3 的基本使用&lpar;增 删 改 查&rpar;

    iOS sqlite3 的基本使用(增 删 改 查) 这篇博客不会讲述太多sql语言,目的重在实现sqlite3的一些基本操作. 例:增 删 改 查 如果想了解更多的sql语言可以利用强大的互联网. ...

  5. django ajax增 删 改 查

    具于django ajax实现增 删 改 查功能 代码示例: 代码: urls.py from django.conf.urls import url from django.contrib impo ...

  6. ADO&period;NET 增 删 改 查

    ADO.NET:(数据访问技术)就是将C#和MSSQL连接起来的一个纽带 可以通过ADO.NET将内存中的临时数据写入到数据库中 也可以将数据库中的数据提取到内存*程序调用 ADO.NET所有数据访 ...

  7. MVC EF 增 删 改 查

    using System;using System.Collections.Generic;using System.Linq;using System.Web;//using System.Data ...

  8. js数组的管理&lbrack;增&comma;删&comma;改&comma;查&rsqb;

    今天在设计表单的时候遇到对数组的一些处理的问题,比如说怎么创建一个数组,然后牵扯到数组的增删改查的方法.请看API FF: Firefox, N: Netscape, IE: Internet Exp ...

  9. 简单的php数据库操作类代码&lpar;增&comma;删&comma;改&comma;查&rpar;

    这几天准备重新学习,梳理一下知识体系,同时按照功能模块划分做一些东西.所以.mysql的操作成为第一个要点.我写了一个简单的mysql操作类,实现数据的简单的增删改查功能. 数据库操纵基本流程为: 1 ...

随机推荐

  1. git gitignore文件失效处理

    这里讲的是使用 git ignore 时候的一种特殊情况   正常你在本地给项目添加了一些文件之后,一般都会自动全部跟踪,但是在这个时候你必须编辑一个ignore文件,把一些不需要跟踪到文件ignor ...

  2. Android防止按钮连续点击

    为了防止用户或者测试MM疯狂的点击某个button,写个方法防止按钮连续点击. public class Utils { private static long lastClickTime; publ ...

  3. Swift使用Alamofire实现网络请求

    Alamofire是一个用Swift编写的HTTP网络库,由此前热门开源项目AFNetworking的的作者mattt开发,可非常简单地用于异步网络通信. 要获取最新版本的 Alamofire,前往h ...

  4. 把URL传递参数转变成自定义实体方法

    先定义下要获取的实体: public class InputClass { public long Id { get; set; } public int Status { get; set; } p ...

  5. &lbrack;Design Pattern&rsqb; Filter Pattern 简单案例

    Filter Pattern,即过滤模式,通过不同的过滤标准,或者低耦合将过滤标准组合在一起,对一组对象进行过滤,属于结构类的设计模式. 下面是一个过滤模式的简单案例. Criteria 定义过滤接口 ...

  6. 转:PHP变量作用域(花括号、global、闭包)

    花括号 很多语言都以花括号作为作用域界限,PHP中只有函数的花括号才构成新的作用域. 01 <?php 02 if (True) { 03     $a = 'var a'; 04 } 05   ...

  7. thinkphp 常用的查询

    php 常用的数据库查询方式: //根据where 条件查询,使用select()方法 访问:http://localhost/thinkphp2/index.php/Machine/search_i ...

  8. 【JAVAWEB学习笔记】25&lowbar;基础加强:类加载器、注解 &commat;xxx和动态代理

    基础加强 学习目标 案例-自定义单元测试@MyTest 案例-全局的编码的解决 一.类加载器 1.什么是类加载器,作用是什么? 类加载器就加载字节码文件(.class) 2.类加载器的种类 类加载器有 ...

  9. pytest 14 使用自定义标记mark

    标记失败用到的情况是,本身就知道这是失败的例子,所以,不用让他运行,直接跳过.或者是依赖于某个方法,某个方式失败的话,用例直接标记成失败. 标记失败有两种方法,一种是方法内部,一种是方法外部.内部用p ...

  10. P2930 &lbrack;USACO09HOL&rsqb;假期绘画Holiday Painting

    线段树水题,考虑到只有15列,所以我们对于每一列,我们都去维护一个线段树. 现在来考虑一下修改操作,因为每次修改的时候,我们都是将黑的改成白的,白的改成黑的,所以我们对线段树的每个节点维护当前这段区间 ...