mvc中Action前HttpPost的作用

来源:互联网 发布:java jdk下载地址 编辑:程序博客网 时间:2024/06/03 19:26

mvc中Action前HttpPost的作用

更多2015/9/9 来源:ASP.NET学习浏览量:995
学习标签: mvc
本文导读:在ASP.NET MVC框架中,为了限制某个action只接受HttpPost的请求,对于HttpGet的请求则提示404找不到页面,可以在action的方法前面加上[HttpPost]属性。下面介绍Action前HttpPost的作用

一、Action前HttpPost实例

 

[HttpPost]  public string post_test(string str)  {      return "post的字符串是:"+str;  } 

 

脚本调用

 

function post_test()  {     $.post("/test/post_test", { str: "John" }, function (data)    {        $('#lbl_show').text(data);     });  }  
 
 
或者
 
 
$.ajax({            type: "POST",            url: "/test/post_test",            data: "str='" + John+ "'",           success: function(msg) {               $('#lbl_show').text(data);              }      });

 

二、Action前HttpPost 的作用

限制action只接受HttpPost的请求,对于HttpGet的请求则提示404找不到页面。

如果Action前即没有 [HttpPost],也没有 [HttpGet] ,则两种方式的请求都接收。

 

三、Post方式提交数据后,Controller中寻找Action的相应机制

1、查找有没有[HttpPost]标注的Register Action,如果有,则执行,如果没有,则2

2、查找有没有没有任何[HttpPost]或者[HttpGet]标记的Register Action,如果有,则执行,如果没有,则3

3、返回“The Resource can't be found"的异常信息

===============================================================================================

两种 HTTP 请求方法:GET 和 POST

在客户机和服务器之间进行请求-响应时,两种最常被用到的方法是:GET 和 POST。

  • GET - 从指定的资源请求数据。
  • POST - 向指定的资源提交要被处理的数据
 GETPOST后退按钮/刷新无害数据会被重新提交(浏览器应该告知用户数据会被重新提交)。书签可收藏为书签不可收藏为书签缓存能被缓存不能缓存编码类型application/x-www-form-urlencodedapplication/x-www-form-urlencoded 或 multipart/form-data。为二进制数据使用多重编码。历史参数保留在浏览器历史中。参数不会保存在浏览器历史中。对数据长度的限制是的。当发送数据时,GET 方法向 URL 添加数据;URL 的长度是受限制的(URL 的最大长度是 2048 个字符)。无限制。对数据类型的限制只允许 ASCII 字符。没有限制。也允许二进制数据。安全性

与 POST 相比,GET 的安全性较差,因为所发送的数据是 URL 的一部分。

在发送密码或其他敏感信息时绝不要使用 GET !

POST 比 GET 更安全,因为参数不会被保存在浏览器历史或 web 服务器日志中。可见性数据在 URL 中对所有人都是可见的。数据不会显示在 URL 中。
0 0