钉钉开发系列(六)WebApi
之前常使用的方式是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开发。
欢迎打描左侧二维码打赏。
转载请注明出处。

浙公网安备 33010602011771号