一、form表单基本使用

  • <form>标签可创建一个表单,属性如下:

  • <form>标签子标签可以有如下:
  1. <input> : 用于搜集用户信息。    

      <input>标签中有很多属性,如下:

          (1)type属性:规定input的类型。type属性有多个值,如下表格:

              

            (2)name :注释:只有设置了 name 属性的表单元素才能在提交表单时传递它们的值。

            (3)maxlength :输入字段中的字符的最大长度。

            (4)min :输入字段中的字符的最短长度。

            (5)value :规定 input 元素的值。

   2.<select>标签: <select>中的子标签 <option>标签用于定义列表中的可用选项。属性如下:

      (1)size属性:规定下拉列表中可见选项的数目。

如果 size 属性的值大于 1,但是小于列表中选项的总数目,浏览器会显示出滚动条,表示可以查看更多选项。
 
  3.<textarea>:多行文本标签.属性如下:

      (1)cols: 设置文本的列数。
     (2)rows: 设置文本的行数。
 

1.1 静态页面中的form表单

<!doctype html>
<html>
<head>
<title>表单测试</title>
<meta http-equiv="content-type" content="text/html;charset=UTF-8">
</head>
<body>
<form >
用户名:<input type="text" maxlength="8" min="3" value="f"/><br/> //maxlength设置最大长度,min设置最小长度,value在这里设置默认值即页面加载之后显示在本行的值
           密码:<input type="password" /><br/>
性别:<select size="1" name="sex">                 //设置可见选项的数目
<option >男</option>
<option >女</option>
</select><br/>
描述:<textarea rows="5" cols="10" > </textarea >
<input type="submit">
</form>
</body>
</html>
结果:

  1.2 与servlet结合的表单。

  • 表单文件:form.html:

  

<!doctype html>
<html>
<head>
<title>表单测试</title>
<meta http-equiv="content-type" content="text/html;charset=UTF-8">
</head>
<body>
<form action="../servlet/form" method="post" >
用户名:<input type="text" name="userName" maxlength="8" min="3" value="f"/><br/>
密码:<input type="password" name="userPass" /><br/>
性别:<select size="1" name="sex">
<option value="m">男</option>
<option value="f">女</option>
</select><br/>
描述:<textarea rows="5" cols="10" name="desc"> </textarea >
<input type="submit">
</form>
</body>
</html>

form.java文件如下:

protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
request.setCharacterEncoding("UTF-8");
response.setCharacterEncoding("utf-8");
String name=(String)request.getParameter("userName");
String sex=(String)request.getParameter("sex");
String desc=(String)request.getParameter("desc");
System.out.println(name);
System.out.println(sex);
System.out.println(desc);
}

配置文件如下:

  <servlet>
<servlet-name>form</servlet-name>
<servlet-class>servlet.form</servlet-class> //创建servlet包下的form类的对象,类名是form。 <servlet-class>填写完整的包名。类名 <servlet-name>填写对象的名字。
</servlet>
<servlet-mapping>
<servlet-name>form</servlet-name>
<url-pattern>/servlet/form</url-pattern> //所有发送到<url-pattern>路径下的数据都会被form处理,而form在<servlet>要被定义,且<servlet>中的<servlet-name>要与<servlet-mapping>中的<servlet-name>要一致。
</servlet-mapping>

解析:1.当用户填好表单并提交之后,数据被发送到action所指向的路径,即action="../servlet/form"(../表示返回上一级目录,./表示当前目录)  当前文件即form.html目录为“localhost:8080/test/study/form.html” 所以action的地址为"localhost:8080/test/servlet/form"   ,查看配置文件中的<url-pattern>可知,当地址为“/servlet/form”(不完整路径,默认基准路径为本目录路径即“localhost:8080/test”),所以数据被发送到form处理。

  2.数据传到了servlet中,request.getParameter("userName")方法用来获取用户填写的值,其中的userName是在表格中的某一个元素的name,例如<input type="password" name="userPass" /> 如果没有定义属性name 那么在servlet中将无法获取这个值更不可能处理了。

注意:参数parameter与属性Attribute的区别:

        

        •       来源不同:   参数(parameter)是从客户端(浏览器)中由用户提供的,若是GET方法是从URL中 
          提供的,若是POST方法是从请求体(request body)中提供的; 
            属性(attribute)是服务器端的组件(JSP或者Servlet)利用requst.setAttribute()设置的
        •       操作不同:   参数(parameter)的值只能读取不能修改,读取可以使用request.getParameter()读取; 
            属性(attribute)的值既可以读取亦可以修改,读取可以使用request.setAttribute(),设置可使用request.getAttribute()
        •       数据类型不同:   参数(parameter)不管前台传来的值语义是什么,在服务器获取时都以String类型看待,并且客户端的参数值只能是简单类型的值,不能是复杂类型,比如一个对象。 
             属性(attribute)的值可以是任意一个Object类型。

(三)表单与servlet的初步结合的更多相关文章

  1. 简单的form表单操作(Servlet)

    Servlet模型 [表单的处理][模型(1)] ●HTML网页 <!DOCTYPE html> <html> <head> <meta charset=&q ...

  2. jsp文件放在webcontent子目录下提交表单给servlet报404错误解决办法

    新版的web项目已经不需要配置web.xml了,并且eclipse neon版本里面新建web项目时候,默认不会生成web.xml文件.我们也不需要手动添加该文件,因为内部为我们提供了最新的处理方式, ...

  3. 【IDEA】HTML通过servlet3.0注解名提交表单到servlet类找不到页面的问题

    IDEA一时爽,摸不着头的BUG火葬场 这个问题困扰我整整一天一夜,先是代码检查路径设置找不出问题,后面换tomcat版不行,抱着侥幸心理换IDEA版本意料之中还是没解决问题. 都快想秃了最后终于完美 ...

  4. html提交表单到Servlet

    源码地址 https://github.com/YouXianMing/Java-Web-Study/tree/master/Servlet-Form 演示效果(注意post与get提交方式浏览器地址 ...

  5. 最适合入门的Laravel中级教程(三)表单验证

    做开发有个原则是永远不能信任用户输入的数据: 即便前端已经做了验证: 在后端 php 也必须要再次验证: laravel 为表单验证提供了强大且简单的方案: 创建示例路由: routes/web.ph ...

  6. Servlet与JSP内置对象的对应关系、Servlet获取表单、Servlet路径跳转

    项目的根目录指的是webroot: 服务器内部跳转: 或者使用../:“..”代表回到上一级目录

  7. Servlet表单数据处理

    以下内容引用自http://wiki.jikexueyuan.com/project/servlet/form-data.html: 当需要从浏览器到Web服务器传递一些信息并最终传回到后台程序时,一 ...

  8. Servlet中转发和重定向的路径问题以及表单提交路径问题

    一.请求转发与响应重定向的种类 有两种方式获得Servlet转发对象(RequestDispatcher):一种是通过HttpServletRequest的getRequestDispatcher() ...

  9. html文件form表单action调用servlet连接mysql数据库实例

    web.xml文件 <?xml version="1.0" encoding="UTF-8"?> <web-app xmlns:xsi=&qu ...

随机推荐

  1. .NET Core SignalR 和 .NET SignalR 区别

    由于要转 .NET Core ,对于以前用到的一些进行迁移. 在迁移 SignalR 的时候发现 .NET Core 下的和 .NET 下的区别还是挺大的. 功能差异 自定重新连接 .NET 下的 S ...

  2. 分布式系统:CAP理论

    无论你是一个系统架构师,还是一个普通开发,当你开发或者设计一个分布式系统的时候,CAP理论是无论如何也绕不过去的.本文就来介绍一下到底什么是CAP理论,如何证明CAP理论,以及CAP的权衡问题. CA ...

  3. BZOJ 3698: XWW的难题(有源汇上下界最大流)

    题面 XWW是个影响力很大的人,他有很多的追随者.这些追随者都想要加入XWW教成为XWW的教徒.但是这并不容易,需要通过XWW的考核. XWW给你出了这么一个难题:XWW给你一个N*N的正实数矩阵A, ...

  4. 题解 [51nod1340]地铁环线

    题解 [51nod1340]地铁环线 题面 解析 本文参考这篇博客 一开始看到只有120行就打算写一写, 结果一刚就是三个星期摆摆摆 本来是当查分约束入门学的. step 1 首先来考虑下如果已知总长 ...

  5. Linux下安装mysql(离线安装和在线安装)

    一:在线安装mysql 1.首先检测一下,mysql之前有没有被安装 命令:rpm -qa | grep mysql 2.删除mysql的命令: rpm -e --nodeps `rpm -qa | ...

  6. MongoDB 3.2变动一览

    3.2测试版本总算release了!E叔带大家来一览MongoDB 3.2版本的真容. (PS:内容比较多,在此仅针对个人认为比较重要的进行讲解,markdown写的,貌似WP的markdown插件有 ...

  7. MyBatis中jdbcType=INTEGER、VARCHAR作用

    Mapper.xml中 pid = #{pid,jdbcType=INTEGER} pid = #{pid} 都可以用 Mybatis中什么时候应该声明jdbcType? 当Mybatis不能自动识别 ...

  8. jsp利用webuploader实现超大文件分片上传、断点续传

    1,项目调研 因为需要研究下断点上传的问题.找了很久终于找到一个比较好的项目. 在GoogleCode上面,代码弄下来超级不方便,还是配置hosts才好,把代码重新上传到了github上面. http ...

  9. 使用Keras训练神经网络备忘录

    小书匠深度学习 文章太长,放个目录: 1.优化函数的选择 2.损失函数的选择 2.2常用的损失函数 2.2自定义函数 2.1实践 2.2将损失函数自定义为网络层 3.模型的保存 3.1同时保持结构和权 ...

  10. java 标准日期格式

    public static void main(String[] argv) { // 使用默认时区和语言环境获得一个日历 Calendar cale = Calendar.getInstance() ...