如何使用POST请求收集页面数据?

时间:2016-09-19 20:19:27

标签: c# jquery asp.net asp.net-mvc

我们假设我有一个包含一些信息和表格的简单页面。

Redirect

所有输入的数据将像模型或FormCollection一样发送到Controller。

但是,我还想向控制器发送任何text \ image,通常是位于表单外部的页面中的任何信息。这里带有id" user_info"举个例子。

我想知道它是否可以在没有jQuery的情况下实现,只能使用默认的Controller的功能。

2 个答案:

答案 0 :(得分:1)

尝试使用隐藏字段将其他数据表单发送到控制器。

@using (Html.BeginForm("UpdateOrder", "Order", FormMethod.Post)) {
      // some inputs here
      <input type="hidden" name="user_info" id="user_info" value="Norway">
}
//<p id="user_info">Some text here</p>

OrderController 控制器操作方法

public ActionResult UpdateOrder(String user_info)
{
//Hidden filed **name** will be the name of the String
//From collection can be used in similar way
}
编辑:您可以通过jQuery / javascript更新隐藏字段值,提交后您可以获得控制器和文本/图像中的更新值,这是略有不同

答案 1 :(得分:1)

你可以做到这一点

1-如果你想上传一些文件或图像,你的表格应该是这样的    下面的代码:

@using (Html.BeginForm("ApplyOnline", "Applieds", null, FormMethod.Post, new { enctype = "multipart/form-data" }))
{
  @Html.AntiForgeryToken()
  <input type="hidden" name="JobId" id="JobId" value="@ViewBag.JobId" />

  @Html.ValidationSummary(true, "", new { @class = "text-danger" })

   <div class="form-group">
      <label class="control-label col-md-3">First Name (اسم)</label>
      <div class="col-md-8">
      @Html.EditorFor(model => model.FirstName, new { htmlAttributes = new { @class = "form-control",@required="required" } })
      @Html.ValidationMessageFor(model => model.FirstName, "", new { @class = "text-danger" })
   </div>
  </div>
   <input type='file' name='pmd' id='pmd' />
<input type="submit" value="Apply" class="btn btn-primary"  />
}

比postbox方法

[HttpPost]
[ValidateAntiForgeryToken]
public ActionResult ApplyOnline([Bind(Include = "Id,JobId,FirstName")] Applied applied, HttpPostedFileBase pmd, int JobId)
{
  if (ModelState.IsValid)
  {
            //---save the data---------//
            db.MyAppliedContext.Add(applied);
            db.SaveChanges();
            //---Get inserted Id----//
            int insertedId = applied.Id;
             //--------Upload PMD-------------------//
            if (pmd != null && pmd.ContentLength > 0)
            {
                try
                {
                    var PMDFileName = "PMD-" + applied.JobId + "-" + TrimedUser + "-" + insertedId + "-" + pmd.FileName;
                    //var P11FileName = DateTime.Now.ToString();
                    string path = Path.Combine(Server.MapPath("~/App_Data/system"),
                                               Path.GetFileName(PMDFileName));
                    pmd.SaveAs(path);
                    UploadFiles MyPMDUploads = new UploadFiles();
                    MyPMDUploads.JobId = applied.JobId;
                    MyPMDUploads.ApplyId = insertedId;
                    MyPMDUploads.FileName = Path.GetFileName(PMDFileName);
                    MyPMDUploads.FilePath = path;
                    db.MyUploadFileContext.Add(MyPMDUploads);
                    db.SaveChanges();

                    ViewBag.Message = "PMD uploaded successfully";
                }
                catch (Exception ex)
                {
                    ViewBag.Message = "ERROR PMD:" + ex.Message.ToString();
                }

            }
            else
            {
                ViewBag.Message = "You have not specified a PMD file.";
            }
   }
   return view(Model);
}

通过这种方式你可以上传文件和数据,包括这个帮助你