gpt4 book ai didi

c# - POST 字符串到 ASP.NET Web Api 应用程序 - 返回 null

转载 作者:IT王子 更新时间:2023-10-29 03:57:09 26 4
gpt4 key购买 nike

我正在尝试将字符串从客户端传输到 ASP.NET MVC4 应用程序。

但是我收不到字符串,要么是null要么找不到post方法(404错误)

传输字符串的客户端代码(控制台应用程序):

HttpWebRequest request = (HttpWebRequest)WebRequest.Create("http://localhost:49032/api/test");
request.Credentials = new NetworkCredential("user", "pw");
request.Method = "POST";
string postData = "Short test...";
byte[] byteArray = Encoding.UTF8.GetBytes(postData);
request.ContentType = "application/x-www-form-urlencoded";
request.ContentLength = byteArray.Length;

Stream dataStream = request.GetRequestStream();
dataStream.Write(byteArray, 0, byteArray.Length);
dataStream.Close();

WebResponse response = request.GetResponse();
Console.WriteLine(((HttpWebResponse)response).StatusDescription);
dataStream = response.GetResponseStream();

StreamReader reader = new StreamReader(dataStream);
string responseFromServer = reader.ReadToEnd();
Console.WriteLine(responseFromServer);
reader.Close();
dataStream.Close();
response.Close();
Console.ReadLine();

ASP.NET 网络 API Controller :

public class TestController : ApiController
{
[Authorize]
public String Post(byte[] value)
{
return value.Length.ToString();
}
}

在这种情况下,我可以调用“Post”方法,但“value”是NULL。如果我将方法签名更改为(字符串值),它将永远不会被调用。

即使“没有” [Authorize] 设置,它也有同样奇怪的行为。 -> 所以它与用户身份验证无关。

知道我做错了什么吗?我很感激任何帮助。

最佳答案

您似乎在 Web API Controller 操作中使用了一些 [Authorize] 属性,但我看不出这与您的问题有什么关系。

那么,让我们开始练习吧。下面是一个简单的 Web API Controller 的样子:

public class TestController : ApiController
{
public string Post([FromBody] string value)
{
return value;
}
}

以及与此相关的消费者:

class Program
{
static void Main()
{
using (var client = new WebClient())
{
client.Headers[HttpRequestHeader.ContentType] = "application/x-www-form-urlencoded";
var data = "=Short test...";
var result = client.UploadString("http://localhost:52996/api/test", "POST", data);
Console.WriteLine(result);
}
}
}

您无疑会注意到 [FromBody] Web API Controller 属性的修饰以及客户端 POST 数据的 = 前缀。我建议您阅读有关 how does the Web API does parameter binding 的内容以便更好地理解这些概念。

[Authorize] 属性而言,这可用于保护服务器上的某些操作不被仅经过身份验证的用户访问。实际上,您在这里要达到的目标还不清楚。顺便说一句,您应该在问题中更清楚地说明这一点。您是否正在尝试了解参数绑定(bind)在 ASP.NET Web API 中的工作原理(如果这是您的目标,请阅读我链接到的文章)或正在尝试进行一些身份验证和/或授权?如果第二种情况是您的情况,您可能会发现 following post我写的关于这个主题的文章很有趣,可以帮助您入门。

如果在阅读了我链接到的 Material 之后,你和我一样对自己说,WTF 伙计,我需要做的就是将一个字符串 POST 到服务器端端点,我需要做所有这些吗?没门。然后结帐ServiceStack .您将有一个很好的基础来与 Web API 进行比较。我不知道 Microsoft 的家伙在设计 Web API 时在想什么,但是说真的,我们应该为我们的 HTML(想想 Razor)和 REST 东西有单独的基本 Controller ?这不可能是严重的。

关于c# - POST 字符串到 ASP.NET Web Api 应用程序 - 返回 null,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13771032/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com