首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >从HttpListenerRequest获取表单数据

从HttpListenerRequest获取表单数据
EN

Stack Overflow用户
提问于 2011-03-05 02:11:08
回答 2查看 25.7K关注 0票数 16

我有一个HttpListenerRequest,这是从一个html的<form>是张贴的。我需要知道如何获得张贴的表单值+上传的文件。有没有人知道一个例子可以帮我节省自己的时间?我用谷歌搜索了一下,但没有找到任何有用的东西。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2011-04-03 01:59:42

奇怪的是,一个被接受的带有完整源代码的答案+一个下载工作演示的链接将导致负分和投票被删除。如果我是那种关心我的分数的人,我会删除这个答案,这样就没有人会受益了。心理学,嗯:)

我找到了一些用于MonoTouch的web服务器的示例,但它们都没有解析POST请求中发送的数据。我环顾了一下网络,找不到任何如何实现这一点的例子。因此,既然我已经自己编写了它,我决定分享我自己的实现。这不仅包括处理表单post数据的代码,还包括注册请求处理程序等的代码。

以下是如何使用web服务器的示例

代码语言:javascript
复制
 public BookUploadViewController() 
   : base("BookUploadViewController", null)
 {
   RequestHandler = new DefaultRequestHandler();
   var defaultActionHandlerFactory = new DefaultActionHandlerFactory();
   RegisterActionHandlers(defaultActionHandlerFactory);
   RequestHandler.AddActionHandlerFactory(defaultActionHandlerFactory);

   WebServer = new EmbeddedWebServer(RequestHandler);
 }

 void RegisterActionHandlers(DefaultActionHandlerFactory factory)
 {
   factory.RegisterHandler(
     request => request.RawUrl == "/",
     request => new IndexActionHandler(request)
     );
   factory.RegisterHandler(
     request => 
       string.Compare(request.RawUrl, "/Upload", true) == 0 && 
       string.Compare(request.HttpMethod, "POST", true) == 0,
     request => new UploadActionHandler(request)
     );
 }

 public override void ViewDidAppear(bool animated)
 {
   base.ViewDidAppear(animated);
   StatusLabel.Text = string.Format("Server listening on\r\nhttp://{0}:8080", GetIPAddress ());
   WebServer.Start(8080);
 }

 public override void ViewDidDisappear (bool animated)
 {
   base.ViewDidDisappear(animated);
   WebServer.Stop();
 }

下面是两个特定于应用程序的请求处理程序示例

代码语言:javascript
复制
 class IndexActionHandler : DefaultActionHandler
 {
   public IndexActionHandler(HttpListenerRequest request)
     : base(request)
   {
   }

   public override ActionResult Execute()
   {
     var result = new HtmlResult();
     result.AppendLine("<html>");
     result.AppendLine("<body>");
     result.AppendLine("<h1>Upload an image</h1>");
     result.AppendLine("<form action='/Upload' enctype='multipart/form-data' method='post'>");
     result.AppendLine ("<input name='Image' type='file'/><br/>");
     result.AppendLine("<input name='Upload' type='submit' text='Upload'/>");
     result.AppendLine("</form>");
     result.AppendLine("</body>");
     result.AppendLine("</html>");
     return result;
   }
 }

 class UploadActionHandler : DefaultActionHandler
 {
   public UploadActionHandler(HttpListenerRequest request)
     : base(request)
   {
   }

   public override ActionResult Execute()
   {
     string errorMessage = null;
     var file = FormData.GetFile("Image");
     if (file == null 
       || file.FileData == null 
       || file.FileData.Length == 0 
       || string.IsNullOrEmpty(file.FileName))
       errorMessage = "No image uploaded";

     if (errorMessage == null)
       ProcessFile(file);

     var result = new HtmlResult();
     result.AppendLine("<html>");
     result.AppendLine("<body>");
     if (errorMessage == null)
       result.AppendLine("<h1>File uploaded successfully</h1>");
     else
     {
       result.AppendLine("<h1>Error</h1>");
       result.AppendLine("<h2>" + errorMessage + "</h2>");
     }
     result.AppendLine("</body>");
     result.AppendLine("</html>");
     return result;
   }

   void ProcessFile(MultiPartStreamFileValue postedFile)
   {
     string fileName = "Where to save the file";
     using (var fileStream = 
       new FileStream(fileName, FileMode.Create, FileAccess.Write, FileShare.None))
     {
       fileStream.Write(postedFile.FileData, 0, postedFile.FileData.Length);
     }
   }
 }

你可以在这里下载源代码https://sites.google.com/site/mrpmorris/EmbeddedWebServerMT.zip

票数 1
EN

Stack Overflow用户

发布于 2011-03-05 03:02:11

要理解的主要事情是,HttpListener是一个处理http请求的低级工具。所有的post数据都在HttpListenerRequest.InputStream流中。假设我们有一个这样的表单:

代码语言:javascript
复制
<form method=\"post\" enctype=\"multipart/form-data\"><input id=\"fileUp\" name=\"fileUpload\" type=\"file\" /><input type=\"submit\" /></form>

现在我们想要查看post数据。让我们实现一个方法来做到这一点:

代码语言:javascript
复制
public static string GetRequestPostData(HttpListenerRequest request)
{
  if (!request.HasEntityBody)
  {
    return null;
  }
  using (System.IO.Stream body = request.InputStream) // here we have data
  {
    using (var reader = new System.IO.StreamReader(body, request.ContentEncoding))
    {
      return reader.ReadToEnd();
    }
  }
}

上传一些文件并查看结果:

代码语言:javascript
复制
Content-Disposition: form-data; name="somename"; filename="D:\Test.bmp" 
Content-Type: image/bmp
...here is the raw file data...

接下来,假设我们有一个不上传文件的简单表单:

代码语言:javascript
复制
<form method=\"post\">First name: <input type=\"text\" name=\"firstname\" /><br />Last name: <input type=\"text\" name=\"lastname\" /><input type=\"submit\" value=\"Submit\" /></form>

让我们看看输出:

代码语言:javascript
复制
firstname=MyName&lastname=MyLastName

合并后的表单结果:

代码语言:javascript
复制
Content-Disposition: form-data; name="firstname"
My Name
Content-Disposition: form-data; name="somename"; filename="D:\test.xls"
Content-Type: application/octet-stream
...raw file data...

正如您所看到的,在简单表单的情况下,您只需将InputStream读取为字符串并解析POST值。如果有一个更复杂的形式-你需要执行更复杂的解析,但它仍然可以完成。希望这个例子能节省你的时间。请注意,将所有流作为字符串读取并不总是这样的。

票数 25
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/5197579

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档