OData V4 系列 Ajax请求 CRUD

       OData 学习目录

       上一篇已经完成了服务创建,本篇主要介绍如何通过Ajax请求Odata服务,OData操作主要有 Get、Post、Patch、Put、Delete等操作。

    Post 操作       

        public async Task<IHttpActionResult> Post(Product product)
        {
            if (!ModelState.IsValid)
            {
                return BadRequest(ModelState);
            }
            _dbContext.Products.Add(product);
            await _dbContext.SaveChangesAsync();
            return Created(product);
        }
function addPro() {
        var pro = {
            Name: "OData Create",
            Price: 1024,
            Category: "IT"
        };
        //创建产品信息
        $.ajax({
            url: "/Odata/Products",
            type: "POST",
            contentType: "application/json; charset=utf-8",
            dataType: "JSON",
            data: JSON.stringify(pro),
            success: function (r) {
                alert(r.Id);
            },
            error: function (e) {
                debugger;
            }
        });
    }

         Patch 操作 只修改有变化的实体属性

public async Task<IHttpActionResult> Patch([FromODataUri] int key, Delta<Product> product)
        {
            if (!ModelState.IsValid)
            {
                return BadRequest(ModelState);
            }
            var entity = await _dbContext.Products.FindAsync(key);
            if (entity == null)
            {
                return NotFound();
            }
            product.Patch(entity);
            try
            {
                await _dbContext.SaveChangesAsync();
            }
            catch (DbUpdateConcurrencyException)
            {
                throw;
            }
            return Updated(entity);
        }
var pro = {
            SupplierId: 2
        };

        //创建产品信息
        $.ajax({
            url: "/Odata/Products(" + id + ")",
            type: "Patch",
            contentType: "application/json; charset=utf-8",
            dataType: "JSON",
            data: JSON.stringify(pro),
            success: function (r) {
                debugger;
            },
            error: function (e) {
                debugger;
            }
        });

          Update 操作,修改所有实体

public async Task<IHttpActionResult> Put([FromODataUri] int key, Product update)
        {
            if (!ModelState.IsValid)
            {
                return BadRequest(ModelState);
            }
            if (key != update.Id)
            {
                return BadRequest();
            }
            _dbContext.Entry(update).State = EntityState.Modified;
            try
            {
                await _dbContext.SaveChangesAsync();
            }
            catch (DbUpdateConcurrencyException)
            {
                if (!Exists(key))
                {
                    return NotFound();
                }
                else
                {
                    throw;
                }
            }
            return Updated(update);
        }

           Delete 操作

public async Task<IHttpActionResult> Delete([FromODataUri] int key)
        {
            var product = await _dbContext.Products.FindAsync(key);
            if (product == null)
            {
                return NotFound();
            }
            _dbContext.Products.Remove(product);
            await _dbContext.SaveChangesAsync();
            return StatusCode(HttpStatusCode.NoContent);
        }
function deletePro(id) {
        $.ajax({
            url: "/Odata/Products(" + id + ")",
            contentType: "application/json; charset=utf-8",
            type: "Delete",
            success: function (r) {
                debugger;
            },
            error: function (r) {
                debugger;
            }
        });
    }

 

转载于:https://www.cnblogs.com/Fengger/p/4958728.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: MockServer可以通过在其中配置期望的OData请求和响应来提供OData服务请求。 具体来说,您需要配置期望的OData请求的HTTP方法、路径和头,以及期望的响应的HTTP状态代码和正文。然后,在MockServer中启动服务并将其与客户端应用程序连接,客户端应用程序将向MockServer发送OData请求,并且MockServer将返回预先配置的响应。 这可以让您在开发和测试OData客户端应用程序时不依赖于实际的OData服务器,并且可以随时更改期望的请求和响应以进行测试。 下面是一个示例配置,假设您希望在MockServer中提供一个OData服务,其中包含一个名为"Customers"的实体集,您可以使用以下代码进行配置: ``` client.when( request() .withMethod("GET") .withPath("/odata/Customers") ).respond( response() .withStatusCode(200) .withHeader("Content-Type", "application/json") .withBody('{"value": [{"ID": 1, "Name": "Alice"}, {"ID": 2, "Name": "Bob"}]}') ); ``` 这将配置MockServer以接受来自客户端应用程序的OData GET请求,并返回包含两个客户信息的JSON响应。 ### 回答2: 要使用MockServer提供OData服务请求,可以按照以下步骤进行操作: 1. 首先,你需要创建一个MockServer的实例。你可以使用MockServerClient类来进行实例化。 ```java MockServerClient mockServerClient = new MockServerClient("localhost", 1080); ``` 2. 接下来,你需要定义OData服务的模拟响应。你可以使用mockServerClient的when方法并指定请求来设置响应。 ```java Expectation[] expectations = { when( request() .withMethod("GET") // 设置请求方法 .withPath("/odata/Customers") // 设置请求路径 ) .respond( response() .withStatusCode(200) // 设置响应状态码 .withHeader("Content-Type", "application/json") // 设置响应头 .withBody("{ \"value\": [] }") // 设置响应体 ) }; ``` 3. 最后,你需要将模拟响应应用到MockServer上,以便开始监听和处理请求。 ```java mockServerClient.sendExpectation(expectations); mockServerClient.stop(); ``` 以上是一个简单的示例,用于在MockServer上模拟一个返回空结果的OData服务请求。你可以根据自己的需求进行定制和扩展,以满足更复杂的场景。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值