`
cynhafa
  • 浏览: 154735 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

HTML表单(HTML Form)中get 和post 的区别

 
阅读更多

当用户在 HTML 表单 (HTML Form) 中输入信息并提交之后,有两种方法将信息从浏览器传送到 Web 服务器 (Web Server)。

一种方法是通过 URL,另外一种是在 HTTP Request 的 body 中。

前一种方法,我们使用 HTML Form 中的 method = "get",后一种方法我们使用 HTML Form 中的 method ="post"

例句如下:

<form action = "..." method = "get">
<from action = "..." method = "post">

通过 get 或者 post 方法都可以获得 Form 的数据,两者主要区别在于以下几方面:

Get

  • URL 改变,在URL 里显示 HTML Form 参数的 name/value 值。
  • 只适合有少量参数的 HTML Form,因为 URL 长度有字符限制,不能无限长。
  • 涉及安全性的信息,比如用户密码,不能用 get,因为会在 URL 上显示,不安全。

Post

  • URL 不改变,不在 URL 里显示 HTML Form 的数据。
  • Form 提交的信息没有长度限制。
  • 涉及安全性的信息,如用户密码,应采用 post 方式。

我们看看 get 是如何提交 Form 数据的。我们先写一个 HTML 文件,如下:

<html>
<head><title>Blablar.com HTML Form Method Get Example</title></head>
<body>
<form action ="get.php" method ="get">
Name: <input type="text" name="username" />
<input type ="submit" value="ok" />
</form>
</body>
</html>

该 HTML 的显示界面如下:

html form get

当你在这个 HTML 文件的表单文本框输入框里输入姓名,比如 "Jacky",然后鼠标点击ok 按钮,会跳转到 get.php,在 get.php 里会显示如下图。

php $_GET

你可以看到在浏览器地址栏里的URL是:

http://localhost:8080/get.php?username=Jacky

注意get.php后面的字符串 ?username=Jacky,这是一对 name/value 数据,前面加一个问号。

如果你将 form 改成 method = "post",你在浏览器地址栏就看不到这对 name/value 数据,而只有:

http://localhost:8080/get.php

使用 get 时,第一对 name/value 值前要加一个问号? ,以后每对 name/value 值则要用 & 分开。比如一个 form中有三个参数,如下:

<form action ="u.php" method ="get">
Name: <input type="text" name="username" />
Age: <input type="text" name="age" />
Gender: <input type="text" name="gender" />
<input type ="submit" value="ok" />
</form>

比如你在Name 项填写Jacky,Age项填写50,Gender项填了male,提交之后的 URL 显示为:

http://localhost:8080/get.php?username=Jacky&age=50&gender=male

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

 在B/S应用程序中,前台与后台的数据交互,都是通过HTMLForm表单完成的。Form提供了两种数据传输的方式——get和post。虽然它们都是数据的提交方式,但是在实际传输时确有很大的不同,并且可能会对数据产生严重的影响。虽然为了方便的得到变量值,Web容器已经屏蔽了二者的一些差异,但是了解二者的差异在以后的编程也会很有帮助的。
 Form中的get和post方法,在数据传输过程中分别对应了HTTP协议中的GET和POST方法。二者主要区别如下:
 1、Get是用来从服务器上获得数据,而Post是用来向服务器上传递数据。
 2、Get将表单中数据的按照variable=value的形式,添加到action所指向的URL后面,并且两者使用“?”连接,而各个变量之间使用“&”连接;Post是将表单中的数据放在form的数据体中,按照变量和值相对应的方式,传递到action所指向URL。
 3、Get是不安全的,因为在传输过程,数据被放在请求的URL中,而如今现有的很多服务器、代理服务器或者用户代理都会将请求URL记录到日志文件中,然后放在某个地方,这样就可能会有一些隐私的信息被第三方看到。另外,用户也可以在浏览器上直接看到提交的数据,一些系统内部消息将会一同显示在用户面前。Post的所有操作对用户来说都是不可见的。
 4、Get传输的数据量小,这主要是因为受URL长度限制;而Post可以传输大量的数据,所以在上传文件只能使用Post(当然还有一个原因,将在后面的提到)。
 5、Get限制Form表单的数据集的值必须为ASCII字符;而Post支持整个ISO10646字符集。
 6、Get是Form的默认方法。
 下面我们一个实例来查看二者的不同:

 
 
 
 
 
Username: Password:

//接受数据的Servlet文件 import java.io.*;

import javax.servlet.*; import javax.servlet.http.*;

public class ParseServlet extends HttpServlet { public void init(ServletConfig config) throws ServletException { super.init(config); }

public void service(HttpServletRequest request, HttpServletResponse response) throws IOException, ServletException { System.out.println("************** begin ***************"); String method = request.getMethod(); System.out.println("method = " + method); int contentLength = request.getContentLength(); System.out.println("contentLength = " + contentLength); System.out.println("ContentType = " + request.getContentType()); //System.out.println("------- 在设定字符编码前 -------"); System.out.println("QueryString = " + request.getQueryString());

//得到ServletInputStream,请注意:这段代码和得到user的值的代码,不能同时出现,否则 //在后面的那个将会得到空值。 if (method.equalsIgnoreCase("Post")) { try { ServletInputStream ins = request.getInputStream(); byte[] arr = new byte[contentLength]; while (ins.read() != -1) ins.read(arr, 0, contentLength); System.out.println("content = " + new String(arr)); } catch (IOException e) {} } //得到user的值 //System.out.println("Username = " + request.getParameter("user"));

//设置字符编码,必须放在得到ServletInputStream或者得到user的值的代码之前,否则将起不 //到转化编码的作用。 try { request.setCharacterEncoding("gb2312"); } catch (UnsupportedEncodingException use) {}

//System.out.println("------- 在设定字符编码后 -------"); //得到user的值 //System.out.println("Username = " + request.getParameter("user"));

//System.out.println("QueryString = " + request.getQueryString()); System.out.println("************** end ***************"); } } 首先,我们设置form的method="post",提交数据,则可以得到如下的结果: HTML表单Form中的get和post方法(图一) 从结果中可以看到,QueryString为null,而content是输入的值,并且按照variable=value的形式组织,而且变量之间使用“&”连接,这和结果中的另外一个变量(ContentType)有关。在后面将会提到ContentType的有关概念。 接着,我们将form中的method设置为get,重新提交数据,则可以得到如下的结果: HTML表单Form中的get和post方法(图二) 可以看到,QueryString的值正是我们在页面上的变量及其对应值,而此时ContentLength=-1。从以上的结果,我们可以清楚地看到,Get和Post分别将数据放在不同的位置来传输。我们还可以将程序中注释去掉,观察一下,在Get和Post下设置字符编码对数据的影响,会发现:使用Post传输的数据,可以通过设置编码的方式正确转化中文;而Get传输的数据却没有变化。在以后的程序中,我们一定要注意这一点。 下面简单介绍一下ContentType,它和Form中enctype属性的相对应,它是Form用来组织数据的方式,主要包含了两种: 1、application/x-www-form-urlencoded:它是默认内容类型(content type),在结果中我们已经看到了经它编码的数据的效果。编码方法:i.将空格使用“+”代替,非字母和数字字符,是用以%HH表示的该字符的ASCII代替(汉字就是这种形式);ii.变量和值使用“=”,各个变量和值对之间使用“&”连接。 2、multipart/form-data:它可以用来传输大量二进制数据或者非ASCII字符的文本,因此在上传文件需设置enctype="multipart/form-data",此时method必须为post。它传输的消息包含了一系列的数据块,每一块都代表Form中的一个变量,并且数据块的顺序和页面上的顺序一致,块与块之间使用特殊字符(boundary)分隔。如果Form中包含file控件,相应的数据块还会包含一个Content-Type头,用来指定MIME,默认值为text/plain。下面是设置enctype="multipart/form-data"时content的结果: HTML表单Form中的get和post方法(图三)

点击查看大图 此时在Servlet中,使用常规getParameter(String)方法已经不能到值,至于如何解析,可以参考文件上传的程序。
分享到:
评论

相关推荐

    js 提交form表单和设置form表单请求路径的实现方法

    如下所示: form表单ID:postform 设置表单请求url document.postform.action = SaveReturnInfo...以上就是小编为大家带来的js 提交form表单和设置form表单请求路径的实现方法全部内容了,希望大家多多支持软件开发网~

    HTML中Form表单的method属性使用介绍

    1 method是指定数据如何发送到服务器的一个属性 2 只可能是post和get post:官方解释是把数据通过post会话传送到服务器。实际就是提交数据。 get:将表单中数据的按照variable=value的形式,添加到action所指向的URL...

    C#-HTTP请求(Post,GET,表单)

    C#-HTTP请求(Post,GET,表单)

    Form表单中method=post/get两种数据传输的方式的区别

    Form提供了两种数据传输的方式—get和post,Form中的get和post方法,在数据传输过程中分别对应了HTTP协议中的GET和POST方法,感兴趣的朋友可以了解下,或许对你学习get/post有所帮助

    C# 使用Get和Post请求获取数据

    C# 使用Get或Post请求获取数据 并解析获取到的Json数据

    java HttpClient 发送GET请求和带有表单参数的POST请求教程例子

    java HttpClient 发送GET请求和带有表单参数的POST请求教程例子

    基于Django URL传参 FORM表单传数据 get post的用法实例

    今天小编就为大家分享一篇基于Django URL传参 FORM表单传数据 get post的用法实例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧

    浅析get和post两种提交方式

    get是把参数数据队列加到提交表单的ACTION属性所指的URL中,值和表单内各个字段一一对应,在URL中可以看到。post是通过HTTP post机制,将表单内各个字段与其内容放置在HTML HEADER内一起传送到ACTION属性所指的URL...

    Web应用安全:HTTP协议GET和POST的使用区别实验.docx

    实验一:HTTP协议POST 实验目的 通过ajax实例深入理解http协议之post方法。 二、实验用到的工具软件 ...&lt;form action="a2.php" name="form1" method="post"&gt; 姓名: 年龄: &lt;input type="submit" value="

    C#-HTTP请求接收(Post数据流,GET,表单)

    C#-HTTP请求接收(Post数据流,GET,表单)

    HTML5&CSS3网页制作:创建表单.pptx

    在HTML5中,&lt;form&gt;&lt;/form&gt;标记被用于定义表单域,即创建一个表单,以实现用户信息的收集和传递,&lt;form&gt;&lt;/form&gt;中的所有内容都会被提交给服务器。 描述 语法格式 &lt;form action="url地址" method="提交方式" name=...

    PHP通过get方法获得form表单数据方法总结

    对于稍有HTML基础的朋友来说,应该都知道HTML form表单中有两种提交方式即get和post,但是对于新手小白来说,或许这个知识点还有些模糊。 那么本篇文章主要就给大家详细介绍其中的get方法即PHP通过get变量获取form...

    动态设置form表单的action属性的值的简单方法

    form name="myform" id="myform" action="ssss" method="post" onsubmit="getUrl();"&gt; javascript方法: [removed] function getUrl(){ $('form').attr('action','new_url'); } [removed] 或者用单纯的...

    ASP.NET之表单和控件详解

    主要介绍的有如下知识点: HTML表单的提交方式、HTM控件、获取HTML表单内容、乱码问题、SQL注入、服务器端表单、HTML服务器控件 HTML表单的提交方式 对于一个普通HTML表单来说,它有两个...它有两个可能值get和post。

    asp教程中get post提交表单有5点区别

    asp教程中get post提交表单区别有以下5点 Get和Post方式的区别有5点 1. get是从服务器上获取数据,post是向服务器传送数据。 2. get是把参数数据队列加到提交表单的ACTION属性所指的URL中,值和表单内各个字段一一...

    fsockopen get/post 表单及上传文件例子

    fsockopen get/post 表单及上传文件例子。

    HTML常用标签及属性.docx

    】 表单按钮:提交按钮·,复原按钮【面试题】get和post的区别a.get请求地址栏中会携带页面中所有的信息,post中不会【http请求】b.get请求安全性低,post相对较高c.get请求效率高,post相对较低d.get请求对数据的...

    html表单制作及多种实例

    这个表单有两个文本输入字段(名和姓),一个提交按钮,当用户点击提交按钮时,数据会以POST方式发送到服务器的"/submit_form"地址。 下面是这个表单的各个部分的解释: • &lt;form&gt;: 表单的开始和结束。action属性...

    多种实例解析HTML表单form的使用方法

    九个简单实例为大家分析了HTML表单form的使用方法,供大家参考,具体内容如下 1 form表单标签 网站怎样与用户进行交互?答案是使用HTML表单(form)。表单是可以把浏览者输入的数据传送到服务器端,这样服务器端程序就...

    qt post,get进行表单提交的demo

    NULL 博文链接:https://793101503-qq-com.iteye.com/blog/1618684

Global site tag (gtag.js) - Google Analytics