如何在 Webhook 中接收 json 发布数据



我们使用第三方 api kraken.io 来优化我们的图像。

优化图像的结果发布在Webhook中。

在他们的 api 文档中,它指出:优化结束后,Kraken 将以JSON格式POST消息到您的请求中指定的callback_urlapplication/json

我正在使用 ngrok 允许远程webhooks将数据发送到我的开发计算机,使用本文。

发布到回调网址的结果:

HTTP/1.1 200 OK
{
"id": "18fede37617a787649c3f60b9f1f280d",
"success": true,
"file_name": "header.jpg",
"original_size": 324520,
"kraked_size": 165358,
"saved_bytes": 159162,
"kraked_url": "http://dl.kraken.io/18/fe/de/37617a787649c3f60b9f1f280d/header.jpg"
}

要映射的类

public class KrakenOptimizedResults
{
public string id { get; set; }
public bool success { get; set; }
public string file_name { get; set; }
public int original_size { get; set; }
public int kraked_size { get; set; }
public int saved_bytes { get; set; }
public string kraked_url { get; set; }
}

操作方法

[HttpPost]
public ActionResult OptimizedWebHook()
{
Request.InputStream.Position = 0;
string jsonString = new System.IO.StreamReader(Request.InputStream).ReadToEnd();
KrakenOptimizedResults obj = new JavaScriptSerializer().Deserialize<KrakenOptimizedResults>
(jsonString);

return Json(obj);
}     

但是当我在 Html 可视化工具中debug收到的jsonString时,它看起来像keyvalue对,而不是 Json 格式。

收到的结果不是 Json 格式的:

file_name=header.jpeg&original_size=118066&kraked_size=102459&saved_bytes=15607

我想content-type:接收到的数据是application/x-www-form-urlencoded.

为什么我收到keyvalue对而不是 Json 格式? 如何在 asp.net MVC 中反序列化 Json 数据?

https://kraken.io 的联合创始人。

我们的文档中有一个明显的遗漏,我今天将修复。要恢复 JSON,您需要在请求中设置"json": true标志。省略该标志或设置"json": false将返回 URLEncoded。示例 cURL 请求:

curl http://api.kraken.io/v1/upload -X POST --form data='{"auth":{"api_key":"YOUR_KEY", "api_secret":"YOUR_SECRET"}, "wait": true, "lossy": true, "callback_url": "http://requestb.in/wbhi63wb", "json": true}' --form upload=@test.jpg

很抱歉给您带来不便:-(

我能够使用这篇文章和这篇文章将查询字符串KeyValue对转换为Json格式,将表单Dictionary转换为Json有一些延迟,所以如果有更好的答案,那么请发布和建议,以下是我的解决方案。

操作方法

[HttpPost]
public ActionResult OptimizedWebHook()
{
Request.InputStream.Position = 0;
string data = new System.IO.StreamReader(Request.InputStream).ReadToEnd();
var dict = HttpUtility.ParseQueryString(data);
var json = new JavaScriptSerializer().Serialize(dict.AllKeys.ToDictionary(k => k, k =>
dict[k]));
KrakenOptimizedResults obj = new JavaScriptSerializer().Deserialize<KrakenOptimizedResults>
(json);
return Json(obj);
}

从kraken API接收JSON格式的优化结果。

正如@karim79所提到的,要取回JSON,您需要在请求中设置一个"json":true标志。

由于Kraken.Net/C#SDK没有设置"json"的选项:true,所以我必须扩展它们的基类。

扩展基类:

public class OptimizeRequestBaseExtended : OptimizeRequestBase,
IOptimizeUploadRequest, IRequest
{
public OptimizeRequestBaseExtended(Uri callbackUrl)
{
CallbackUrl = callbackUrl;
}
[JsonProperty("callback_url")]
public Uri CallbackUrl { get; set; }
[JsonProperty("json")]
public bool JsonFormat { get; set; }
}

请求海妖API:

var callbackUrl = new Uri("http://localhost:0000/Home/OptimizedWebHook");
OptimizeRequestBaseExtended settings = new OptimizeRequestBaseExtended(callbackUrl);
settings.Lossy = true;
settings.JsonFormat = true;
var response = client.Optimize(image: image, filename: filename, optimizeRequest: settings);

操作方法

[HttpPost]
public ActionResult OptimizedWebHook()
{
Request.InputStream.Position = 0;
string jsonString = new System.IO.StreamReader(Request.InputStream).ReadToEnd();

KrakenOptimizedResults obj = JsonConvert.DeserializeObject<KrakenOptimizedResults>
(jsonString);
return Json(obj);
}

第 1 步: 创建一个 aspx 页。此页面必须能够接受 HTTP POST 请求。 第 2 步: 添加此代码以获取 HTTP POST 数据。文件:默认.aspx.cs 文件:默认.aspx.cs

var reader = new StreamReader(Request.InputStream);
var json = reader.ReadToEnd();
FileStream ostrm;
StreamWriter writer;
TextWriter oldOut = Console.Out;
ostrm = new FileStream(@"C:logfile4webhook.txt", FileMode.Append, FileAccess.Write);
writer = new StreamWriter(ostrm);
Console.SetOut(writer);
Console.Write(DateTime.Now + " ");
Console.WriteLine(json.ToString() + " ");
Console.SetOut(oldOut);
writer.Close();
ostrm.Close();

第 3 步: 创建网络钩子。此代码可以链接到单击时按钮事件。文件:默认.aspx.cs

AuthenticationDetails auth = new ApiKeyAuthenticationDetails("your api key");
string listID = "";
listID = "your list id";
List list = new List(auth, listID);
List<string> events = new List<string>();
events.Add("Update");
string postback = list.CreateWebhook(events, "URL", "json");
FileStream ostrm;
StreamWriter writer;
TextWriter oldOut = Console.Out;
ostrm = new FileStream(@"C:logfile4webhook.txt", FileMode.Append, FileAccess.Write);
writer = new StreamWriter(ostrm);
Console.SetOut(writer);
Console.Write(DateTime.Now + " ");
Console.WriteLine(postback + " ");
Console.SetOut(oldOut);
writer.Close();
ostrm.Close();

第 4 步: 激活网络钩子。从文本文件中复制该 webhook id,并将其粘贴到下面的代码中。 文件:默认.aspx.cs

AuthenticationDetails auth = new ApiKeyAuthenticationDetails("your api key");
string listID = "";
listID = "your list id";
List list = new List(auth, listID);
list.ActivateWebhook("webhook id");

第 5 步: 测试啪。文件:默认.aspx.cs

AuthenticationDetails auth = new ApiKeyAuthenticationDetails("your api key");
string listID = "";
listID = "your list id";
List list = new List(auth, listID);
string postback = list.TestWebhook("webhook id").ToString();
FileStream ostrm;
StreamWriter writer;
TextWriter oldOut = Console.Out;
ostrm = new FileStream(@"C:logfile4webhook.txt", FileMode.Append, FileAccess.Write);
writer = new StreamWriter(ostrm);
Console.SetOut(writer);
Console.Write(DateTime.Now + " ");
Console.WriteLine(postback + " ");
Console.SetOut(oldOut);
writer.Close();
ostrm.Close();

第 6 步: 反序列化 JSON 对象的主体。我们需要基于 JSON 数据创建类结构。我把示例json放在这里,它创建了必需的类

public class CustomField
{
public string Key { get; set; }
public string Value { get; set; }
}
public class Event
{
public List<CustomField> CustomFields { get; set; }
public string Date { get; set; }
public string EmailAddress { get; set; }
public string Name { get; set; }
public string SignupIPAddress { get; set; }
public string Type { get; set; }
}
public class RootObject
{
public List<Event> Events { get; set; }
public string ListID { get; set; }
}

创建类后,在后面附加步骤 2 中的代码

var json = reader.ReadToEnd();

反序列化和分析 JSON。

RootObject myClass = JsonConvert.DeserializeObject(json);

if (myClass != null)
{
List<Event> t = myClass.Events;
string old_email = "", new_email = "";
old_email = t[0].OldEmailAddress;
new_email = t[0].EmailAddress;
//now you can do your logic with old_email and new_email
}

相关内容

  • 没有找到相关文章

最新更新