一、表单提交时注意

如果是以get方式提交数据的时候,在接收时是用QueryString方式进行接收

如果是以post请求数据时在接收时是用Form进行接收

为什么么要这样做呢?我们用Request[];的形式也能接收到数据啊?

---》当用户提交表单时如果是以get请求发送数据的那么用Form是接收不到数据的,

用post请求提交时QueryString 也是接收不到数据的,,我们发现,get请求是把文本框等提交的

内容放到url地址栏里提交,就是把这些内容追加到请求报文头的请求文件后面了,

post请求则是把这些内容放到请求报文体里,

通过测试发现QueryString读取不到请求报文体里的内容但是能够读取到url里的内容,

而Form则是能够读取到请求体里的内容url请求头里的读取不到。

我们提交表单时,大多数情况下,将表单的method属性设置为post(安全,可以传递大数据)

这时表单中各个元素的值会议请求报文体的方式发给服务端,

在服务端通过context.Request.Form来进行接收,所以表单的元素必须要加上name属性

注意一下隐藏域的应用,它也是一个表单元素,只不过在浏览器看不出该元素的效果,

但是当单击提交按钮时发出(post请求)该隐藏域的value属性的值也会提交到服务端,

然后再服务端也是通过Request.Form接收,

我们在‘计算’的这个小程序中用来判断用户是否单击了提交按钮,起到一个标识作用。

二、重定向

context.Response.Redirect()

这时服务器端返回的响应头中 ,包含了一个302响应码,和一个Location属性,

然后浏览器发现302标识重定向,重定项到Location属性指向的页面

1)context.Response.End()终止执行,该语句后面的代码都不会执行了

2)注意问题:

有哪些表单元素可以向服务器进行提交,而且有哪些属性会提交到服务端

readonly/ disabled:  readonly和disabled都是只2读的,

区别在于readonly会把value值提交到服务器而disabled则不会

当我们点击【提交】按钮以后是浏览器将用户填写的文本框等控件中的值“提取”出来发送给服务器,

而不是服务器来读取用户填写的这个页面。哪些标签的哪些值会被提交给服务器呢?

将用户填写的内容提交到服务器有如下几个条件:

只能为 input、textarea、select三种类型的标签。只有input(文本框、CheckBox等)用户才可能填写值,

<label>、<p>、<font>等标签仅供显示用,没有提交到服务器的必要。

只有value属性的值才会提交给服务器。以input标签为例,input标签有title、type、disabled等属性,

但是这些属性都是供显示用的,用户并不能修改,只有value属性才是用户输入的属性,

因此只有value属性的值才会被提交到服务器。

标签必须设定name属性。学习Dom的时候我们知道如果要通过JavaScript操作标签,

必须为标签设定Id。如果要将标签的value属性值提交到服务器,则必须为标签设定name属性

,提交到服务器的时候将会以“name=value”的键值对的方式提交给服务器,多个键值对之间用&分割。

除了单选按钮等少数标签之外,大部分标签的name的值不能重复。name是给服务器用的,

id是给Dom用的。对于RadioButton,同name的为一组,选中的RadioButton的value被提交到服务器。

如果设置了控件的disabled属性的话,浏览器也不会提交该控件的值。这是与readonly的区别

放到form标签内。只有放到form标签内的标签才可能会被提交到服务器,form之外的input等标签被忽略。

知识点

1)url传值

//url传值

        context.Response.Write("<a href='MyFirst.ashx?name=张三&pwd=12345'>哈哈</a>");

url传值会向服务器提交一个get请求,get请求是把文本框等提交的内容放到url地址栏里提交,

就是把这些内容追加到请求报文头的请求文件后面了

在服务端就可以通过context.Request.QueryString来接收

2)重定向

  //重定向

        context.Response.Redirect ("Login.ashx");

3)隐藏域

<input type='hidden' value='true' name='postBack' />

这个标签在浏览器端不会显示出来,

当用户点击表单里的提交按钮发送post请求时就会把这个hidden标签里的value值的内容提交到服务端,

那么我们在服务端就可以

判断浏览器提交的是get请求还是post请求了

数往知来 ASP.NET 表单的提交_url传值_重定向 <十八>的更多相关文章

  1. ASP.NET MVC 客户端验证失败后表单仍然提交问题

    客户端验证失败后表单仍然提交问题!导致页面刷新,辛辛苦苦输入的内容荡然无存. 多么奇怪的问题.按道理,验证失败,就应该显示各种错误信息,不会提交表单才对.而现在,错误信息正常显示,但页面却刷新了一遍. ...

  2. 使用jQuery.form插件,实现完美的表单异步提交

    传送门:异步编程系列目录…… 时间真快,转眼一个月快结束了,一个月没写博客了!手开始生了,怎么开始呢…… 示例下载:使用jQuery.form插件,实现完美的表单异步提交.rar 月份的尾巴,今天的主 ...

  3. 使用jQuery,实现完美的表单异步提交

    jQuery异步提交表单 <form id="form1" method="post"> <table border="1" ...

  4. form表单的提交方式

    开发中表单提交是很常见的,表单的提交方式也多种方式. 1.使用submit按钮提交表单  <input type="submit"/> <!DOCTYPE htm ...

  5. 12、Struts2表单重复提交

    什么是表单重复提交 表单的重复提交: 若刷新表单页面, 再提交表单不算重复提交. 在不刷新表单页面的前提下: 多次点击提交按钮 已经提交成功, 按 "回退" 之后, 再点击 &qu ...

  6. java防止表单重复提交

    用session防止表单重复提交 思路:在服务器端生成一个唯一的随机标识串Token,同时在当前用户的Session域中保存这个Token.然后将Token发送到客户端的Form表单中,在Form表单 ...

  7. java web学习总结(十三) -------------------使用Session防止表单重复提交

    在平时开发中,如果网速比较慢的情况下,用户提交表单后,发现服务器半天都没有响应,那么用户可能会以为是自己没有提交表单,就会再点击提交按钮重复提交表单,我们在开发中必须防止表单重复提交. 一.表单重复提 ...

  8. 使用Struts 2防止表单重复提交

    用户重复提交表单在某些场合将会造成非常严重的后果.例如,在使用信用卡进行在线支付的时候,如果服务器的响应速度太慢,用户有可能会多次点击提交按钮,而这可能导致那张信用卡上的金额被消费了多次.因此,重复提 ...

  9. js阻止form表单重复提交

    防止表单重复提交的方法总体来说有两种,一种是在js中阻止重复提交:另一种是在后台利用token令牌实现,大致思路是生成一个随机码放到session和form表单的隐藏输入框中,提交表单时两者对比,表单 ...

随机推荐

  1. eclipse调试jsp中的scriptlet代码

    在eclipse开发环境下,jsp中的scriptlet代码,也就是<%%>中的java代码,跟普通的java代码一样可以打断点单步调试的! 做个笔记,免得自己忘了!

  2. Linux平台Cpu使用率的计算

    proc文件系统 /proc文件系统是一个伪文件系统,它只存在内存当中,而不占用外存空间.它以文件系统的方式为内核与进程提供通信的接口.用户和应用程序可以通过/proc得到系统的信息,并可以改变内核的 ...

  3. 图像分类之特征学习ECCV-2010 Tutorial: Feature Learning for Image Classification

    ECCV-2010 Tutorial: Feature Learning for Image Classification Organizers Kai Yu (NEC Laboratories Am ...

  4. UI抑制限制(UI Suppression Limitations)

    运行UI抑制的Lync进程使你的应用程序可以访问同一个Lync客户端终端,SIP处理和所有非抑制Lync客户端使用的媒体处理,但具有以下限制.SDK中的可见组件不可用,除了视频窗体(video win ...

  5. Linux驱动修炼之道-RTC子系统框架与源码分析【转】

    转自:http://helloyesyes.iteye.com/blog/1072433 努力成为linux kernel hacker的人李万鹏原创作品,为梦而战.转载请标明出处 http://bl ...

  6. 一个国内的 android 在线帮助网站

    只支持到 api 19 http://cs.szpt.edu.cn/android/develop/index.html

  7. View页面根据权限显示不同的内容

    1.View中根据权限显示相关操作按钮 @if (CoreTools.CheckAction(HttpContext.Current, "Delete"))        {    ...

  8. Elasticsearch学习笔记

    Why Elasticsearch? 由于需要提升项目的搜索质量,最近研究了一下Elasticsearch,一款非常优秀的分布式搜索程序.最开始的一些笔记放到github,这里只是归纳总结一下. 首先 ...

  9. WebForm页面生命周期及asp.net运行机制

    1.先上几张原理图着重理解: 现在针对第四副图原理进行解析: 流程: 1.浏览器发送请求 2.服务器软件(IIS)接收,它最终的目的就是为了向客户输出它请求的动态页面生成的html代码. 3.服务器不 ...

  10. 大数据导入Excel

    在平时的项目中,将数据导出到Excel的需求是很常见的,在此对一些常见的方法做以总结,并提供一种大数据量导出的实现. OLEDB   使用OLEDB可以很方便导出Excel,思路很简单,处理时将Exc ...