req.getParameter | getParameterValue 一大特点是 返回null表示没有。

【web.xml】

<servlet>

<serlvlet-mapping>

应用程序级别共享初始化参数(servletContext.getInitParameter):<context-param>   配置数据库连接信息、电子邮件报警信息等等。

Servlet级别私有初始化参数(servletConfig.getInitParameter):<init-param>

【HelloServlet】

逻辑:req.getParameter可以拿到浏览器  =》请求参数,writer可以写回 =》 html页面

 public class HelloServlet extends HttpServlet{
private static final String DEFAULT_USER = "GUEST";
@Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
String user = req.getParameter("user");//获取请求参数
if (user==null){
user = DEFAULT_USER;
}
resp.setContentType("text/html");//设置内容类型
resp.setCharacterEncoding("UTF-8");//设置编码 meta PrintWriter writer = resp.getWriter();
writer.append("<!DOCTYPE html>\r\n")
.append("<html>\r\n")
.append("<head>\r\n")
.append("<title>Hello User App</title>\r\n")
.append("</head>\r\n")
.append("<body>\r\n")
.append("Hello,").append(user).append("!<br/><br/>\r\n")
.append("<form action=\"greeting\" method=\"POST\">\r\n")
.append("Enter your name:<br/>\r\n")
.append("<input type=\"text\" name=\"user\" />\r\n")
.append("<input type=\"submit\" value=\"提交\" />\r\n")
.append("</form>\r\n")
.append("</body>\r\n")
.append("</html>\r\n");
} @Override
protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
doGet(req,resp);
} // @Override
// public void init() throws ServletException {
// System.out.println(this.getServletName()+"init方法");
// }
//
// @Override
// public void destroy() {
// System.out.println(this.getServletName()+"destory方法");
// }
}

【多值Servlet】

逻辑:doGet展示一个表单,doPost处理提交的表单。

 @WebServlet(name="multiValueServlet",urlPatterns = {"/selectFruits"})

 public class MultiValueServlet extends HttpServlet{
@Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
resp.setContentType("text/html");
resp.setCharacterEncoding("UTF-8");
//展示一个表单
PrintWriter writer = resp.getWriter();
writer.append("<!DOCTYPE html>\r\n")
.append("<html>\r\n")
.append("<head>\r\n")
.append("<title>挑水果</title>\r\n")
.append("</head>\r\n")
.append("<body>\r\n")
.append("<h2>欢迎光临,本店!</h2><br/><br/>\r\n")
.append("<form action=\"\" method=\"POST\">\r\n")
.append("<label for=\"apple\">苹果</label>\r\n")
.append("<input type=\"checkbox\" id=\"apple\" name=\"fruits\" value=\"newapple\" />\r\n")
.append("<label for=\"pineapple\">梨</label>\r\n")
.append("<input type=\"checkbox\" id=\"pineapple\" name=\"fruits\" value=\"newpineapple\" />\r\n")
.append("<label for=\"banana\">香蕉</label>\r\n")
.append("<input type=\"checkbox\" id=\"banana\" name=\"fruits\" value=\"newbannana\" />\r\n")
.append("<input type=\"submit\" value=\"提交\" />\r\n")
.append("</form>\r\n")
.append("</body>\r\n")
.append("</html>\r\n"); } @Override
protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
String[] fruits = req.getParameterValues("fruits");
resp.setContentType("text/html");
resp.setCharacterEncoding("UTF-8");
PrintWriter writer = resp.getWriter();
if (fruits==null){
writer.println("欢迎下次光临");
// return;
}else {
writer.append("<!DOCTYPE html>\r\n")
.append("<html>\r\n")
.append("<head>\r\n")
.append("<meta charset=\"UTF-8\">\r\n")
.append("<title>欢迎随意挑选</title>\r\n")
.append("</head>\r\n")
.append("<body>\r\n"); for (String fruit:fruits){
writer.append(fruit);
System.out.println(fruit);
}
writer.append("</body>\r\n")
.append("</html>\r\n");
} }
}

【表单提交中文细节】

浏览器编码是ISO8859-1,可以用过滤器解决,暂时可以request直接设置编码UTF-8。

Servlet 快速开始 表单中文字段的更多相关文章

  1. PHP 表单 - 3(PHP 表单 - 必需字段)

    PHP 表单 - 必需字段 本章节我们将介绍如何设置表单必需字段及错误信息. PHP - 必需字段 在上一章节我们已经介绍了表的验证规则,我们可以看到"名字", "E-m ...

  2. [Swift通天遁地]二、表格表单-(8)快速实现表单的输入验证

    ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★➤微信公众号:山青咏芝(shanqingyongzhi)➤博客园地址:山青咏芝(https://www.cnblogs. ...

  3. RookeyFrame Bug 表单管理 -> 查看表单 ->编辑字段页面 JS报错

    表单管理 -> 查看表单 ->编辑字段页面 小bug onchange里面直接就是方法,修改:去掉外面的function(){},直接把方法体写在onchange里面就可以了. 后台方法: ...

  4. ajax和servlet交互,表单日历插件,表单验证,form.js

    我的index.jsp <body> <a>点我获取数据</a> <table border=1px> <tr> <td>ID& ...

  5. JQuery插件使用之Validation 快速完成表单验证的几种方式

    JQuery的Validation插件可以到http://plugins.jquery.com/上去下载.今天来分享一下,关于这个插件的使用. 简易使用 这第一种方式可谓是傻瓜式的使用,我们只需要按照 ...

  6. Spring MVC 3 表单中文提交post请求和get请求乱码问题的解决方法

    在spring mvc 3.0 框架中,通过JSP页面.HTML页面以POST方式提交表单时,表单的参数传递到对应的servlet后会出现中文显示乱码的问题.解决办法可采用spring自带的过滤技术, ...

  7. java工作流系统jflow表单引擎字段扩展组件介绍

    关键词:工作流快速开发平台  工作流流设计  业务流程管理   asp.net 开源工作流  bpm工作流系统  java工作流主流框架  自定义工作流引擎 表单设计器  流程设计器 装饰类图片 用于 ...

  8. Servlet作业2-将表单提交的商品信息输出到页面中

    1,表单页面 shangpin.html <!DOCTYPE html> <html> <head> <meta charset="UTF-8&qu ...

  9. 【java学习】Servlet简单的表单程序(一)

    此文用于java学习,在此小记. 在此小Demo中使用到了Servlet,所以有必要了解一下Servlet的相关知识.(Servlet的相关知识摘抄自http://blog.csdn.net/jiuq ...

随机推荐

  1. Codeforces Round #487 (Div. 2) C - A Mist of Florescence

    C - A Mist of Florescence 把50*50的矩形拆成4块 #include<bits/stdc++.h> using namespace std; ],b[]; ][ ...

  2. Linux:文件系统层次结构标准(Filesystem Hierarchy Standard)

    Linux FHS_2.3标准文档:http://refspecs.linuxfoundation.org/FHS_3.0/fhs-3.0.pdf

  3. A1115. Counting Nodes in a BST

    A Binary Search Tree (BST) is recursively defined as a binary tree which has the following propertie ...

  4. bzoj2434 阿狸的打字机

    题目链接 思路 可以发现,其实题目中所描述的操作,就是在\(AC\)自动机上走的过程.输出就是打上标记.删除就是返回父亲节点. 然后看询问.每次询问字符串\(x\)在字符串中\(y\)出现的次数.其实 ...

  5. Day29--Python--缓冲区, 粘包

    tcp: 属于长连接,与一个客户端进行连接了以后,其他的客户端要等待.要想连接另外一个客户端,需要优雅地断开当前客户端的连接 允许地址重用:server.setsockopt(socket.SOL_S ...

  6. unsigned 变量名:n

    在结构体内定义位,节省空间 /* * size是字节数 * addr是打印的起始地址 */ static void printb(void * addr,size_t size){ ;i<siz ...

  7. 流明(lux)和坎德拉;

    流明是光照度:  坎德拉是光强: 流明是光通量的单位, cd是光强单位 光强是单位立体角的光通量: 照度是单位面积的光通量: 尼特是亮度单位   1尼特 = 1CD/m^2: 1 lx = 1 流明每 ...

  8. Python对象的创建和赋值

    创建类 类的定义以关键字class开头,之后跟着一个名字(用户定义)来标识这个类,并且以冒号结尾.类的内容以缩进(4个空格)表示,如下例的pass表示什么事情也不做. Python命名规则(以字母或者 ...

  9. Java抽象类、接口整理

    抽象类 5.1抽象类产生(上标为A) 编写一个类时,会给该类定义一些方法,这些方法是用来描述功能和具体实现的方式,这些方法都有方法体 例如:一个图形类应该有周长的方法,但是不同的图形求周长方法不一样. ...

  10. flask models循环使用和migrate迁移脚本

    使用models目的是为了将创建数据库模型的代码与主程序代码分离,migrate的作用就是在数据库字段改变时不用drop表直接做更新操作 新建 models.py  exts.py manage.py ...