Passing parameters to Controller ..but NOT on the URL

你。 提交于 2019-12-22 07:01:32

问题


Is there a way to pass a parameter to a controller without putting it on the URL?

For example, http://www.winepassionate.com/p/19/wine-chianti-docg-la-moto

has the value 19 on the URL. If you actually change that value to another, the page displays a different record even it the page name remains the same.

So I would like to NOT pass the ID on the URL but still be able to pass that to the Controller. What's the recommended way to do so?


回答1:


You can do a post and send it as a form parameter. I do not recommend this. Posts should be for requests that modify data. In this case you're most likely looking just to get that data. The fact that the id is in the URL is a good thing (see the Stack Overflow URLs for reference). If you really don't want the user to be able to modify it (I hope it's not because you think this makes it more secure, because it doesn't), you could do some simple encryption on it to make it more difficult to guess/produce a valid ID.

Using TempData, as some other suggest, is not a robust solution. It won't work for links on a page, just a GET after POST, and then only once since TempData is deleted after the next request.




回答2:


Well, you have a couple of options:

  1. Is this a form post? If so, then you can simply add a specific key value pair to your form when you submit it and then data will be passed along.
  2. Is the URL unique to that resource? i.e. Does "Wine-chianti-docg-la-moto" exist as a unique representation of the number 19 in a database somewhere? If so, then you can simply do a lookup of that route component in your database to retrieve the value you need (or push that logic all the way down to the database).
  3. Is that a value that is not expected to change a bunch? You can set that value in Session or in a cookie that would be persisted across pages and then pull it from the respective collection.
  4. Are you redirecting to this page from another request on your server? If so, then you can use TempData to store this temporary value. However, I would recommend against this approach, as it is very transient and not good practice imo.
  5. Lastly, you can obscure the value on the URL if you dont want it to be easily user editable. Encrypt it with some algorithm, and then decrypt it on the destination page. The user will be unlikely to be able to alter the ID by typing in a different value in the URL.



回答3:


If the page is a GET, and you are following the PRG like you should be (Post-Redirect-Get) then you can use TempData["dataName"] = value; in your [HttpPost] controller and then consume it in your [HttpGet] method. It really depends on how the page is being called.

However, there is nothing wrong in letting the user change that number if it is not security related, and is common practice to show non-vital information in the url like that.




回答4:


You should use TempData in this case. A good read on this can be found on this blog.

TempData allows you to store a value temporarily between requests and is, by default, erased after being accessed.

// TempData samplepublic ActionResult Featured(){    var featuredProduct = new Product    {        Name = "Assorted Cupcakes",        Description = "Delectable vanilla and chocolate cupcakes",        CreationDate = DateTime.Today,        ExpirationDate = DateTime.Today.AddDays(7),        ImageName = "cupcakes.jpg",        Price = 5.99M,        QtyOnHand = 12    };


来源:https://stackoverflow.com/questions/8648869/passing-parameters-to-controller-but-not-on-the-url

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!