Servlet 快速开始 表单中文字段

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 快速开始 表单中文字段的更多相关文章
- PHP 表单 - 3(PHP 表单 - 必需字段)
PHP 表单 - 必需字段 本章节我们将介绍如何设置表单必需字段及错误信息. PHP - 必需字段 在上一章节我们已经介绍了表的验证规则,我们可以看到"名字", "E-m ...
- [Swift通天遁地]二、表格表单-(8)快速实现表单的输入验证
★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★➤微信公众号:山青咏芝(shanqingyongzhi)➤博客园地址:山青咏芝(https://www.cnblogs. ...
- RookeyFrame Bug 表单管理 -> 查看表单 ->编辑字段页面 JS报错
表单管理 -> 查看表单 ->编辑字段页面 小bug onchange里面直接就是方法,修改:去掉外面的function(){},直接把方法体写在onchange里面就可以了. 后台方法: ...
- ajax和servlet交互,表单日历插件,表单验证,form.js
我的index.jsp <body> <a>点我获取数据</a> <table border=1px> <tr> <td>ID& ...
- JQuery插件使用之Validation 快速完成表单验证的几种方式
JQuery的Validation插件可以到http://plugins.jquery.com/上去下载.今天来分享一下,关于这个插件的使用. 简易使用 这第一种方式可谓是傻瓜式的使用,我们只需要按照 ...
- Spring MVC 3 表单中文提交post请求和get请求乱码问题的解决方法
在spring mvc 3.0 框架中,通过JSP页面.HTML页面以POST方式提交表单时,表单的参数传递到对应的servlet后会出现中文显示乱码的问题.解决办法可采用spring自带的过滤技术, ...
- java工作流系统jflow表单引擎字段扩展组件介绍
关键词:工作流快速开发平台 工作流流设计 业务流程管理 asp.net 开源工作流 bpm工作流系统 java工作流主流框架 自定义工作流引擎 表单设计器 流程设计器 装饰类图片 用于 ...
- Servlet作业2-将表单提交的商品信息输出到页面中
1,表单页面 shangpin.html <!DOCTYPE html> <html> <head> <meta charset="UTF-8&qu ...
- 【java学习】Servlet简单的表单程序(一)
此文用于java学习,在此小记. 在此小Demo中使用到了Servlet,所以有必要了解一下Servlet的相关知识.(Servlet的相关知识摘抄自http://blog.csdn.net/jiuq ...
随机推荐
- 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[]; ][ ...
- Linux:文件系统层次结构标准(Filesystem Hierarchy Standard)
Linux FHS_2.3标准文档:http://refspecs.linuxfoundation.org/FHS_3.0/fhs-3.0.pdf
- A1115. Counting Nodes in a BST
A Binary Search Tree (BST) is recursively defined as a binary tree which has the following propertie ...
- bzoj2434 阿狸的打字机
题目链接 思路 可以发现,其实题目中所描述的操作,就是在\(AC\)自动机上走的过程.输出就是打上标记.删除就是返回父亲节点. 然后看询问.每次询问字符串\(x\)在字符串中\(y\)出现的次数.其实 ...
- Day29--Python--缓冲区, 粘包
tcp: 属于长连接,与一个客户端进行连接了以后,其他的客户端要等待.要想连接另外一个客户端,需要优雅地断开当前客户端的连接 允许地址重用:server.setsockopt(socket.SOL_S ...
- unsigned 变量名:n
在结构体内定义位,节省空间 /* * size是字节数 * addr是打印的起始地址 */ static void printb(void * addr,size_t size){ ;i<siz ...
- 流明(lux)和坎德拉;
流明是光照度: 坎德拉是光强: 流明是光通量的单位, cd是光强单位 光强是单位立体角的光通量: 照度是单位面积的光通量: 尼特是亮度单位 1尼特 = 1CD/m^2: 1 lx = 1 流明每 ...
- Python对象的创建和赋值
创建类 类的定义以关键字class开头,之后跟着一个名字(用户定义)来标识这个类,并且以冒号结尾.类的内容以缩进(4个空格)表示,如下例的pass表示什么事情也不做. Python命名规则(以字母或者 ...
- Java抽象类、接口整理
抽象类 5.1抽象类产生(上标为A) 编写一个类时,会给该类定义一些方法,这些方法是用来描述功能和具体实现的方式,这些方法都有方法体 例如:一个图形类应该有周长的方法,但是不同的图形求周长方法不一样. ...
- flask models循环使用和migrate迁移脚本
使用models目的是为了将创建数据库模型的代码与主程序代码分离,migrate的作用就是在数据库字段改变时不用drop表直接做更新操作 新建 models.py exts.py manage.py ...