我还在学习REST,在我的测试中,想出了这个我不知道如何处理的场景.
我有一个使用Linq-to-Sql的现有示例WCF服务.它是一个非常简单的数据库,带有一个名为"Tasks"的表,它有四个字段:Id,Description,IsCompleted和EnteredDate.(我之所以提到这是因为我没有在服务本身中定义数据合约,它都来自Linq创建的Context.)
获取数据对于转换为REST来说是微不足道的......就像删除数据一样.但是,插入新记录似乎并不容易.
我的RPC样式的合同操作如下所示:
[OperationContract] void AddTask(string description);
不需要Id,IsCompleted和EnteredDate,因为服务实现如下所示:
public void AddTask(string description) { TaskListLinqDataContext db = new TaskListLinqDataContext(); Task task = new Task() { Description = description, IsCompleted = false, EntryDate = DateTime.Now }; db.Tasks.InsertOnSubmit(task); db.SubmitChanges(); }
Id是一个标识,因此由数据库处理.
我的第一个想法是装饰这样的操作合同:
[WebInvoke(Method="PUT", UriTemplate="tasks/{description}")] [OperationContract] void AddTask(string description);
但我真的不知道如何让它发挥作用.当我尝试使用Fiddler添加它时,它返回结果411(需要长度).
这样做的正确方法是什么?我是否必须重新编写实现以接受表示新记录的整个XML文档?