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)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • Navicat:Access violation at address xxxxxxxxx in module ‘navicat.exe’.Read of address xxxxxx

    Navicat:Access violation at address xxxxxxxxx in module ‘navicat.exe’.Read of address xxxxxx在navicat中如果报了这个错误,则表示内存越界,需要重新注册windows的动态链接库;解决方案:打开cmd;在命令行中输入for%1in(%windir%\system32\*.dll)doregsvr32.exe/s%1回车运行;等待动态链接库刷新完成,重启mysql和navicat即可。…

    2022年8月22日
    7
  • 《滕王阁序》在古文中处于什么水平?

    《滕王阁序》在古文中处于什么水平?杜工部 戏为六绝句 其三 纵使卢王操翰墨 劣于汉魏近风骚 龙文虎脊皆君驭 历块过都见尔曹 如果把现存的古来文章分个一二三等 这篇文章无疑在第一等 可是这样下来 第一等也太多了 怎么也得上千篇了 如果还要在这个第一等上千篇文章分个上中下 滕王阁序大概出于一等中的水平 上中下按照 1 3 6 的比例 1000 篇文章 一等上文章 100 篇 一等中 300 篇 一等下 600 篇 滕王阁序 就是一等中这 300 篇的序列 这是比较客观的了 其实 滕王阁序 在这个位置 并不是对这篇文章的贬低 恰恰相反 它反映了我国古代文学

    2025年9月21日
    3
  • 【Spark】Spark基础教程

    【Spark】Spark基础教程Spark最初由美国加州伯克利大学的AMP实验室于2009年开发,是基于内存计算的大数据并行计算框架,可用于构建大型的、低延迟的数据分析应用程序。Spark特点Spark具有如下几个主要特点:运行速度快:Spark使用先进的DAG(DirectedAcyclicGraph,有向无环图)执行引擎,以支持循环数据流与内存计算,基于内存的执行速度可比HadoopMapReduce快上百倍,…

    2022年5月4日
    48
  • python-获取图片的exif信息

    python-获取图片的exif信息

    2021年9月18日
    99
  • Spark和Hadoop的区别和比较[通俗易懂]

    Spark和Hadoop的区别和比较[通俗易懂]目录一、两者的各方面比较二、Spark相对Hadoop的优越性三、三大分布式计算系统Spark,是分布式计算平台,是一个用scala语言编写的计算框架,基于内存的快速、通用、可扩展的大数据分析引擎Hadoop,是分布式管理、存储、计算的生态系统;包括HDFS(存储)、MapReduce(计算)、Yarn(资源调度)一、实现原理的比较Hadoop和Spark都是并…

    2025年7月6日
    2
  • Python优秀开源项目Rich源码解析

    Python优秀开源项目Rich源码解析这篇文章对优秀的开源项目Rich的源码进行解析,OMG,盘他。为什么建议阅读源码,有两个原因,第一,单纯学语言很难在实践中灵活应用,通过阅读源码可以看到每个知识点的运用场景,印象会更深,以后写代码的时

    2022年7月5日
    26

发表回复

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

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