Request对象获取数据「建议收藏」

Request对象获取数据「建议收藏」Request(.NET中的内置对象)总结了对对象中集合的理解,以及向集合中存取数据的规则

大家好,又见面了,我是你们的朋友全栈君。

1. Request对象


Request(.NET中的内置对象)—从客户端接收消息

获取前端的数据;比如form表单中的内容 ,cookis,表头信息,浏览器种类

        Request对象获取数据「建议收藏」


2. 集合(对数据的封装)


对象中的集合是一个什么概念?

个人理解:

虽然取名叫做集合,但是我觉得集合其实就是一个方法,参数是前端数据,返回值是也前端的数据。

那么为什么设置这样子的一个方法呢?我觉得原因是可以将数据作为一个整体进行传递。

提供一个集合可以存储这些数据,那么我们主要传递一个集合就可以在服务器端使用这些数据,非常的方便。

当于对数据的一个封装。
做个比喻,对象相当于一个容器,里面放着几个小容器,每个小容器都存放着他自己的物品。

        Request对象获取数据「建议收藏」


3. 对象向集合存和取数据的规则


向对象中存数据和取数据都有一定的规则。也就是说数据不是乱放的,数据只能够放在他自己的集合中。

1. 存数据:根据不同的提交方式会将数据存放在不同的对象集合中。

  1. post提交的时候存放在form集合
  1. get提交的时候存放在qureystring集合(变量和值都在url中显示出来(将表单数据以字符串的方式附加在网址的后面返回服务器))

这两个是比较常用的,那么为什么会区分出不同的集合呢!原因是他们是适合不同的情况。

    Request对象获取数据「建议收藏」

Form集合中存放的表单值是比较多,比较大的.QueryString正好相反它存的值是比较简单,比较少的.

2. 取数据:不同集合取数据的形式不同。

Request对象取得集合中数据的方式

1. Request(“”)

无论哪种集合都可以通过此方式取得数据

2. Request.集合

只能取得对应集合的数据

哪种比较好呢?这就要讲到下面的一个问题,对象处理集合中数据的顺序


4. 对象处理集合中数据的顺序


当需要调用集合中的数据,对象在集合中找数据是按照一定的顺序。

        Request对象有几个集合来获取客户端提交的数据,一般常用的是QueryString,Form和ServerVariables。上面讲到的两种方式哪一种比较好,我们通过下面一个例子来了解。

如果 Get方式和Post方式提交了同样的一个变量,比如username=pf,那么你用Request(“username”) 

取出来的到底是Get过来的数据还是Post过来的数据呢? 

        这里就提示我们: Request从这几个集合取数据是有顺序的。从前到后 的顺序依次是 QueryString,Form,最后是ServerVariables。Request对象按照这样的顺序依次搜索 这几个集合中的变量,如果有符合的就中止,后面的就不管了。 所以上面的例子Request(“username”)取到的实际是Get方法提交的数据。 

所以为了提高效率,减少无谓的搜索时间,同时也是为了程序的规范,建议大家还是用Request.集合的 
方式更好一点,比如Request.Form(“username”)。 

下面是一个测试例子,提交以后,大家可以直接在地址后面加上 ?username=pf 来测试: 


<% 
If  request(“submit”)<>”” then   
 Response.Write “直接取:”& Request(“username”) & “<br>” 
 Response.Write “取Get:” & Request.QueryString(“username”) & “<br>” 
 Response.Write “取Post:” & Request.Form(“username”) & “<br>” 
End if 
%> 
<form name=form1 action=”” method=post> 
<input type=test name=”username” value=”postuser”> 
<input type=submit name=”submit” value=”test”> 
</form> 


版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/131308.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • Android获取分辨率和像素密度「建议收藏」

    Android获取分辨率和像素密度「建议收藏」看了网上好多的代码说是获取的分辨率其实得到的是屏幕的宽和高。1.如何获取分辨率和像素密度2..实现代码如下 DisplayMetricslocalDisplayMetrics=newDisplayMetrics(); try{ DisplaylocalDisplay=getWindow().getWindowManager().getDefaultDispl

    2022年6月14日
    71
  • 词向量总结「建议收藏」

    词向量总结「建议收藏」词向量词向量是自然语言理解的重要工具,它的核心思想是把词映射到一个向量空间,并且这个向量空间很大程度上保留了原本的语义。词向量既可以作为对语料进行数据挖掘的基础,也可以作为更复杂的模型的输入,是现在nlp的主流工具。下面就总结一下nlp中经典的词向量方法。主要有:onehot、glove、cbow、skip-gram

    2022年5月6日
    38
  • ODrive开发 #1 ODrive固件开发指南[通俗易懂]

    ODrive固件开发指南本指南适用于希望修改ODrive固件的开发人员。因此,它假定您了解诸如如何使用Git,什么是编译器之类的知识。如果这听起来很陌生,以下内容对您来说可能不适合。官方发行版在master分支上。但是,由于您是开发人员,因此建议您使用devel分支,因为它包含最新功能。该项目正在积极开发中,因此请确保检查更新日志以跟踪更新动态。文章目录ODrive固件开发指南需要的开…

    2022年4月18日
    640
  • LVS+Keepalived实现高可用负载均衡

    LVS+Keepalived实现高可用负载均衡

    2021年8月26日
    55
  • spring aop用法_概念的种类

    spring aop用法_概念的种类SpringAOP入门——概念及注意点

    2022年8月11日
    4
  • 无人驾驶汽车系统入门(二)——高级运动模型和扩展卡尔曼滤波

    无人驾驶汽车系统入门(二)——高级运动模型和扩展卡尔曼滤波前言:上一篇文章的最后我们提到卡尔曼滤波存在着一个非常大的局限性——它仅能对线性的处理模型和测量模型进行精确的估计,在非线性的场景中并不能达到最优的估计效果。所以之前为了保证我们的处理模型是线性的,我们上一节中使用了恒定速度模型,然后将估计目标的加减速用处理噪声来表示,这一模型用来估算行人的状态其实已经足够了,但是在现实的驾驶环境中,我们不仅要估计行人,我们除了估计行人状态以外,我们还需要估计其他

    2022年6月29日
    51

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号