之前常使用的方式是html+ajax+ashx(一般处理程序),这样的方案也是不错的,但比起WebApi来,还是不够方便。WebApi的关键就是路由配置。为此我们先建一个WebApiConfig.cs的配置文件,代码如下
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Web.Http; namespace DingDingWeb { public class WebApiConfig { public static void Register(HttpConfiguration config) { //注册路由映射 config.Routes.MapHttpRoute( name: "DefaultApi", routeTemplate: "api/{controller}/{action}/{id}",//action表示按方法路由 defaults: new { id = RouteParameter.Optional } ); } } }再添加一个全局的Global.asax,代码如下
using System; using System.Collections.Generic; using System.Linq; using System.Web; using System.Web.Http; using System.Web.Security; using System.Web.SessionState; namespace DingDingWeb { public class Global : System.Web.HttpApplication { protected void Application_Start(object sender, EventArgs e) { WebApiConfig.Register(GlobalConfiguration.Configuration); } protected void Session_Start(object sender, EventArgs e) { } protected void Application_BeginRequest(object sender, EventArgs e) { } protected void Application_AuthenticateRequest(object sender, EventArgs e) { } protected void Application_Error(object sender, EventArgs e) { } protected void Session_End(object sender, EventArgs e) { } protected void Application_End(object sender, EventArgs e) { } } }记得在项目中加入System.Net.Http、System.Web.Http、System.Web.Http.WebHost的引用,同时使用nuget来安装Newtonsoft.Json的库(自己引用很可能会出现兼容问题而导到运转起来报Newtonsoft.Json版本的错误)。
再建一个controller的文件夹,里面增加一个相关的类,类名的后面一定要是Controller。比如我们定义一个授权类AuthController。
public class AuthController : ApiController { #region GetSignPackage Function /// <summary> /// 获取签名包 /// </summary> public SignPackage GetSignPackage(String url) { //对于首页的URL,由于可以直接使用域名跳转来进入(比如http://www.king-ecs.com),所以这时取的URL其实是域名, //而不是当前页的URL(http://www.king-ecs.com/index.html),这时产生的签名包是针对域名的(即http://www.king-ecs.com)。 //这样一来就有会造成服务端计算的签名和钉钉计算出的签名不致,从而导致验证失败。 //所以首页URL跳转需要签名名时,需要将URL传入以计算签名包。 //string url = HttpContext.Current.Request.Url.AbsoluteUri; var signPackage = SdkTool.FetchSignPackage(url); return signPackage; } #endregion }这个API就是global.js中调用的方法。方法名记得使用Get开头,否则无法以GET的请求方式获取。获取增加[HttpGet]的契约。比如下面的方法
#region Register Function /// <summary> /// 登记群 /// </summary> /// <param name="chatId"></param> [HttpGet]//方法名以Get开头则不需要加HttpGet的标识,否则无法以Get方式发起请求 public RequestResult<string> Register(String chatId) { //记录到数据库 }有了路由请求后,代码就会比较方便,而且返回的结果都是以json的方式返回的,所以JS端以$.getJSON来获取就变的相当方便。据此我们可以调用biz.chat.chooseConversationByCorpId来获取企业群的chatId,然后记录到数据库中。这样在服务端还没有可以获取chatId接口的情况下,也可以曲线达到目的,虽然麻烦了一点。
附RequestResult的类
/// <summary> /// 请求结果 /// </summary> [Serializable] [DataContract] public class RequestResult<T> { /// <summary> /// 状态(参见<seealso cref="StatusCode"/>) /// </summary> [DataMember] public int Status { get; set; } /// <summary> /// 信息 /// </summary> [DataMember] public string Message { get; set; } /// <summary> /// 具体数据 /// </summary> [DataMember] public T Data { get; set; } #region PackageData Function /// <summary> /// 打包数据 /// </summary> /// <param name="data"></param> public static RequestResult<T> PackageData(T data, string failMessage = "fail", string okMessage = "ok") { RequestResult<T> result = new RequestResult<T>(); if (data == null) { result.Status = StatusCode.FAIL; result.Message = failMessage; result.Data = default(T); } else { result.Status = StatusCode.OK; result.Message = okMessage; result.Data = data; } return result; } #endregion }
以上WepApi的方式,也适用于其他的Web开发。
欢迎打描左侧二维码打赏。
转载请注明出处。