【发布时间】:2021-02-18 19:22:30
【问题描述】:
我正在尝试根据正文请求中传递的值对端点进行授权。例如,在请求的正文中传递了一个站点 ID,我想根据用户是否对该站点具有适当的权限来进行授权。
如果正文请求以 json 格式传递,我有这个工作,但如果它是 urlencoded 形式,则不是。而且我不知道如何事先找到它。这是我的代码的 sn-p,它适用于 json 数据,但如果正文请求是 urlencoded,则会失败。
public override void OnAuthorization(HttpActionContext actionContext)
{
var request = actionContext.Request;
try
{
var content = actionContext.Request.Content.ReadAsStringAsync().Result;
var jsonResult = Newtonsoft.Json.JsonConvert.DeserializeObject<dynamic>(content);
_siteId = jsonResult["siteID"].ToString();
actionContext.Response = UserWorker.UserValidation(_siteId, request) as HttpResponseMessage;
}
catch (Exception e)
{
actionContext.Response = request.CreateResponse(HttpStatusCode.BadRequest, e.Message);
}
【问题讨论】:
标签: c# json authorization httprequest x-www-form-urlencoded