jsp from表单 get 、post 提交方式

1. get是从服务器上获取数据,post是向服务器传送数据。
2. get是把参数数据队列加到提交表单的ACTION属性所指的URL中,值和表单内各个字段一一对应,在URL中可以看到。post是通过HTTP post机制,将表单内各个字段与其内容放置在HTML HEADER内一起传送到ACTION属性所指的URL地址。用户看不到这个过程。
3. 对于get方式,服务器端用Request.QueryString获取变量的值,对于post方式,服务器端用Request.Form获取提交的数据。
4. get传送的数据量较小,不能大于2KB。post传送的数据量较大,一般被默认为不受限制。但理论上,IIS4中最大量为80KB,IIS5中为100KB。
5. get安全性非常低,post安全性较高。但是执行效率却比Post方法好。

建议:
1、get方式的安全性较Post方式要差些,包含机密信息的话,建议用Post数据提交方式;
2、在做数据查询时,建议用Get方式;而在做数据添加、修改或删除时,建议用Post方式;

Post和Get都是表单属性Method的可选值,Method的默认值为Get,两者的主要区别在于: 

1.在客户端,Get方式在通过URL提交数据,

Get方式提交表单后的地址栏 

而Post提交后地栏不变,

2.在服务器端只能用Request.QueryString来获取Get方式提交来的数据,用Post方式提交的数据只能用Request.Form来获取: 

<%@language="VBScript" Codepage="936"%> 
<html> 
<head> 
<title> 表单提交方式测试</title> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312"> 
</head> 
<body> 
<form method="post" action="<%=Request.ServerVariables("Script_Name")%>"> 
  提交数据: 
  <input name="oStr" type="text"> 
    <br> 
    提交方式: 
    <select name="select" οnchange="this.form.method=this.value"> 
      <option value="Post" selected>Post</option> 
      <option value="Get">Get</option> 
    </select> 
    <br> 
  <input type="submit" name="Submit" value="提交"> 
</form> 
<% 
 if Request("Submit")<>"" then 
        Response.Write "通过"&Request.ServerVariables("Request_Method")&"方式提交的数据为:" 
    if Request.ServerVariables("Request_Method")="GET" then 
          Response.Write Request.QueryString("oStr") 
    else 
          Response.Write Request.Form("oStr") 
    end if 
end if 
%> 
</body> 
</html> 

注意:虽然两种提交方式可以统一用Request("oStr")来获取提交数据,但是这样对程序效率有影响,不推荐使用。 
特别提示  
通过IIS运行本例代码(用http://localhost/method.asp这种方式来浏览,有关IIS的安装和配置,请参考第四部分),输入所提交的数据,选择Post方式提交,将看到图1.4.4所示的效果。选择Get方式提交,效果将如图1.4.3所示。 
特别说明

一般来说,尽量避免使用Get方式提交表单,因为有可能会导致安全问题。比如说在登陆表单中用Get方式,用户输入的用户名和密码将在地址栏中暴露无遗。但是在分页程序中,用Get方式就比用Post好。本例中用到的表单的属性解释(ASP部分请参考第四部分): 
    Get把参数添加到action属性指定的地址中,并以锚方式打开。 
    Post通过HTTP post处理发送数据。 

总结:
在提交时的区别:
一:get提交最大能提交8192个字符,执行效率高,但不安全 post提交没有大小限制,效率比get低,安全
二:post是传输信息内容,get是传输url值
 GET -- 这是缺省方式,填充form的内容将被附在 URL 的后面,就好象它是一个普通的查询请求. POST -- 这种方式把 form 的内容用一个数据块方式发送给服务器,而不是作为 URL 的一部分.
三:POST 在HTTP请求的主体内 Request.Form读取数据. GET 标识在URL的最后 Request.QueryString读取数据 GET 有一个缺点就是URL字符的长度被浏览器及服务器使用时有一些限制, 还有一个就是把HTTP请求中通过WEB传递的数据暴露出来 
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
下面是一个简单的例子,演示如何在JSP弹出窗口中提交表单: 首先,创建一个包含表单的HTML代码,保存为form.html文件: ```html <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>表单</title> </head> <body> <form id="myForm" action="submit.jsp" method="post"> <label for="name">姓名</label> <input type="text" id="name" name="name" required><br><br> <label for="email">邮箱</label> <input type="email" id="email" name="email" required><br><br> <button type="submit">提交</button> </form> </body> </html> ``` 然后,在您的JSP页面中,使用以下JavaScript代码来弹出表单提交表单: ```javascript function showForm() { var formWindow = window.open("form.html", "Form", "width=400, height=400"); formWindow.focus(); } function submitForm() { var form = window.opener.document.getElementById("myForm"); form.submit(); window.close(); } ``` 在上面的代码中,`showForm()`函数用于弹出表单,与之前的示例相同。另一个函数`submitForm()`用于在弹出窗口中提交表单。它使用`window.opener`对象来获取父窗口中的表单元素,并使用`form.submit()`方法提交表单。最后,它使用`window.close()`方法关闭弹出窗口。 在表单HTML代码中,注意form元素的action属性和method属性。action属性指定表单提交URL,method属性指定提交的HTTP方法(GET或POST)。在这个例子中,表单将被POST提交到submit.jsp页面。 最后,在您的JSP页面中,添加一个触发提交表单的按钮或链接,并将其与`submitForm()`函数关联: ```html <button onclick="submitForm()">提交表单</button> ``` 当用户点击这个按钮时,表单将被提交到submit.jsp页面,并在弹出窗口中关闭。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值