JavaWeb——Servlet开发2
1、HttpServletRequest的使用
获取Request的参数的方法。
- 方法getParameter将返回参数的单个值
- 方法getParameterValues将返回参数的值的数组
- 方法getParameterMap将返回包含了所有参数名值对的java.util.Map<String,String[]>
- 方法getParameterNames方法将返回所有可用参数的名字的枚举
确定与内容相关的信息
- getContentType将返回请求的MIME内容类型,例如text/html、application/javascript等等
- getContentLength和getContentLong都将返回请求正文的长度,区别是getContentLong用于内容超过2GB的
- getCharacterEncoding将返回请求内容的字符编码
读取请求的内容
- getInputStream将返回一个javax.servlet.ServletInputStream,用于读取请求中的二进制内容
- getReader将返回一个java.io.BufferedReader,用于读取字符编码
要注意的是不能在统一请求上同时使用这两个方法,调用了其中一个方法之后,再调用另一个方法将触发异常
读取请求特有的数据
getRequestURL,返回客户端同于创建请求的完整URL,包括协议、服务器名、端口号和服务器路径,不包括查询字符串,例如http://localhost:8080/hello-world/first?user=a%20user,该方法将返回http://localhost:8080/hello-world/first
- getRequestURI,只返回URL的服务器路径部分,对于上面的例子来说,该方法将返回/hello-world/first
- getServletPath,只返回Servlet映射的URL部分/first
getHeader,返回指定名字的头数据,传入参数的大小写不必与头名称大小写一致,所以getHeader("contenttype")可以匹配Content-Type头,如果多个头使用了相同的名字,将只返回第一个值如果不指定参数名,将返回所有值的枚举
- getHeaderNames:返回请求中所有头数据的枚举
- getDateHeader:对于可以表示有效时间戳的头数据,将返回一个Unix时间戳
2、使用HttpServletResponse
编写响应正文
- getOutputStream将返回一个javax.servlet.ServletOutputStream,将用于编写二进制数据
- getWriter将返回一个java.io.PrintWriter,使用这个方法可以向客户端返回HTML或者其他基于字符编码的文本。
同样不能对同一个响应对象同时使用这两个方法,调用了其中一个方法之后,再调用另一个方法将触发异常
- setContentType和setCharacterEncoding将用于设置内容类型和编码格式
设置头和其他响应属性
- setHeader、setIntHeader、setDateHeader等方法可以设置几乎所有的头数据,如果现有的响应头中已经包括了同名的头、该头数据将被覆盖。
- 为了防止覆盖可以使用addHeader、addIntHeader、addDateHeader等方法,这些方法不会覆盖原有的头数据,会添加一个额外的值。
- 还可以使用getHeader、getIntHeader、getDateHeader等方法判断是否已经在响应中设置过某个响应头
另外还可以使用
- setStatus 用于设置HTTO响应状态码
- getStatus 判断当前响应的状态
- sendError 设置状态码,表示一条可选的错误消息将会输出到响应数据中,重定向到Web容器为客户端提供错误页面,并清空缓存
sendRedirect 将客户端重定向至另一个URL
3、使用参数和接受表单提交
上面记录了很多方法,接下来就是使用的时候了
在我自己实现的HelloServlet中我修改了doGet和doPost方法:
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 = HelloServlet.DEFAULT_USER;
}
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>hello user application</title>\r\n")
.append(" </head>\r\n")
.append(" <body>\r\n")
.append(" Hello, ").append(user).append("!<br/><br/>\r\n")
.append(" <form action=\"first\" method=\"POST\">")
.append(" Enter your name:<br/>\r\n")
.append(" <input type=\"text\" name=\"user\"/><br/>\r\n")
.append(" <input type=\"submit\" value=\"Submit\"/>\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 {
this.doGet(req,resp);
}
这里的实现的具体逻辑是:
- 检查请求中是否包含user参数,如果没有包含的话,就设置为我提前设置好的常量
- 将响应的内容类型设置为text/html,将字符编码设置为UTF-8
- 从响应中获取一个PrintWriter,然后调用append方法编写响应正文
这里的HTML中的表单方法设置为POST,不过在doPost中只是简单的调用了doGet方法,因为这里的表单将读取我们输入的数据并赋值给user变量。
这是直接访问这个URL的效果。

在URL中添加字符串user=niko,变成http://localhost:8080/hello-world/first?user=niko

在输入框中输入xx,点击Submit

然后我修改了一下,试用了上面的大部分代码,比较乱,代码是:
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 = HelloServlet.DEFAULT_USER;
}
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>hello user application</title>\r\n")
.append(" </head>\r\n")
.append(" <body>\r\n")
.append(" Hello, ").append(user).append("!<br/><br/>\r\n")
.append(" <form action=\"first\" method=\"POST\">\r\n")
.append(" 用户名:<input type=\"text\" name=\"user\"/><br/>\r\n")
.append(" 密码 :<input type=\"text\" name=\"pwd\"><br/>\r\n")
.append(" 性别:<input type=\"radio\" name=\"sex\" value=\"boy\" checked=\"checked\">男\r\n")
.append(" <input type=\"radio\" name=\"sex\" value=\"girl\">女<br/>\r\n")
.append(" 爱好:<input type=\"checkbox\" name=\"hobby\" value=\"game\" >打游戏\r\n")
.append(" <input type=\"checkbox\" name=\"hobby\" value=\"book\" >看书\r\n")
.append(" <input type=\"checkbox\" name=\"hobby\" value=\"music\" >听音乐\r\n")
.append(" <input type=\"checkbox\" name=\"hobby\" value=\"coding\" >编程<br/>\r\n")
.append(" 所在学校:<select name=\"school\">\r\n")
.append(" <option>---请选择---</option>\r\n")
.append(" <option value=\"yz\">一中</option>\r\n")
.append(" <option value=\"ez\">二中</option>\r\n")
.append(" <option value=\"bz\">八中</option>\r\n")
.append(" </select><br/>\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 user = req.getParameter("user");
String pwd = req.getParameter("pwd");
String sex = req.getParameter("sex");
String[] hobby = req.getParameterValues("hobby");
String school = req.getParameter("school");
Map<String,String[]> paramMap = req.getParameterMap();
Enumeration<?> paramNames = req.getParameterNames();
Enumeration<?> HeaderNames = req.getHeaderNames();
this.doGet(req,resp);
PrintWriter writer = resp.getWriter();
if(user != null){
writer.append("用户名 = ").append(user).append("<br/>");
}
if(pwd != null){
writer.append("密码 = ").append(pwd).append("<br/>");
}
if(sex != null){
writer.append("性别 = ").append(sex).append("<br/>");
}
if(hobby != null){
writer.append("爱好 = ").append(Arrays.toString(hobby)).append("<br/>");
}
if(school != null){
writer.append("学校 = ").append(school).append("<br/><br/>");
}
if(paramMap != null){
writer.append("paramMap:").append("<br/>");
for (Map.Entry<String,String[]> entry : paramMap.entrySet()) {
writer.append(entry.getKey()).append(" = ").append(Arrays.toString(entry.getValue())).append("<br/>");
}
}
if(paramNames != null){
writer.append("paramNames: ");
while(paramNames.hasMoreElements()){
String value = (String)paramNames.nextElement();
writer.append(value).append(", ");
}
writer.append("<br/>");
}
writer.append("getContentType: ").append(req.getContentType()).append("<br/>");
writer.append("getContentLength: " + req.getContentLength()).append("<br/>");
writer.append("getCharacterEncoding: ").append(req.getCharacterEncoding()).append("<br/>");
writer.append("getRequestURL: ").append(req.getRequestURL()).append("<br/>");
writer.append("getRequestURI: ").append(req.getRequestURI()).append("<br/>");
writer.append("getDateHeader: " + req.getDateHeader("")).append("<br/>");
if(HeaderNames != null){
writer.append("HeaderNames: ");
while(HeaderNames.hasMoreElements()){
String value = (String)HeaderNames.nextElement();
writer.append(value).append(", ");
}
writer.append("<br/>");
}
}
具体效果:

JavaWeb——Servlet开发2的更多相关文章
- 【Java123】JavaWeb Servlet开发
http://www.runoob.com/servlet/servlet-intro.html https://www.cnblogs.com/xdp-gacl/tag/JavaWeb学习总结/de ...
- JavaWeb——Servlet开发
什么是Servlet? Servlet运行的过程 Servlet的生命周期 生命周期的各个阶段 Servlet的配置 使用Web.xml配置 使用注解配置 Servlet相关接口 ServletCon ...
- JavaWeb——Servlet开发3
1.使用初始化参数配置应用程序 初始化参数的方式有两种 在Web.xml文件中使用<context-param>标签声明上下文初始化参数 <context-param> < ...
- JavaWeb——Servlet开发1
Java Servlet是运行在服务器端上的程序,Servlet是Java Servlet包中的一个接口,能够直接处理和相应客户端的请求,也可以将工作委托给应用的其他类. public interfa ...
- javaweb学习之Servlet开发(二)
javaweb学习总结(六)--Servlet开发(二) 一.ServletConfig讲解 1.1.配置Servlet初始化参数 在Servlet的配置文件web.xml中,可以使用一个或多个< ...
- JavaWeb学习总结第四篇--Servlet开发
Servlet开发 用户在浏览器中输入一个网址并回车,浏览器会向服务器发送一个HTTP请求.服务器端程序接受这个请求,并对请求进行处理,然后发送一个回应.浏览器收到回应,再把回应的内容显示出来.这种请 ...
- JavaWeb开发之四:servlet技术 黑马程序员_轻松掌握JavaWeb开发之四Servlet开发 方立勋老师视频教程相当的经典
总结: 记住:servlet对象在应用程序运行的过程中只创建一次,浏览器每次访问的时候,创建reponse对象 request对象,然后调用servlet的service方法,reponse对象和re ...
- javaweb学习总结(五)——Servlet开发(一)
一.Servlet简介 Servlet是sun公司提供的一门用于开发动态web资源的技术. Sun公司在其API中提供了一个servlet接口,用户若想用发一个动态web资源(即开发一个Java程序向 ...
- javaWeb中servlet开发(5)——WEB开发模式:Mode I与Mode II
1.servlet开发 2.model I模式 客户端通过访问JSP,调用里面的javabean,而通过javabean调用处理数据库的操作,javabean中有专门处理数据库的操作,数据库主要以DA ...
随机推荐
- 关于Keepalive的那些事
服务端很多同学包括自己对keepalive理解不清晰,经常搞不清楚,TCP也有keepalive,HTTP也有keepalive,高可用也叫keepalive,经常混淆这几个概念.做下这几个概念的简述 ...
- java 带静态域的导出类创建时都发生了什么?
先按从基类到导出类的顺序初始化静态域(之前已经初始化过的静态域不再初始化) 再按从基类到导出类的顺序初始化类,即基类普通字段+基类构造器主体+导出类字段+导出类主体... package test; ...
- 堡垒机-jumpserver
目录 官方网站 Jumpserver 软件包环境要求: 环境 手动本地jumpserver-服务端搭建 初始化一些系统环境设置: 安装相关软件 安装 组件 自建服务器极速安装步骤 0. 防火墙.Sel ...
- springcloud高可用方案
1. 场景描述 公司在规划后续可能会做中台服务,考虑用微服务的方案,让用springcloud部署个简单的高可用Demo. 2. 解决方案 2.1 方案说明 demo用了5台虚拟机: (1)1台gat ...
- 统计greenplum_postgresql数据占用存储情况
1. 场景描述 因项目数据量略大,每天大概有几百g的存储需求,并且是多项目公用greenplum集群,需要定期检查一下磁盘情况. 2. 解决方案 2.1 按用户/项目统计 2.1.1 SQL语句 SE ...
- Go语言解密上篇中用java aes实现的加密
上一篇java aes文件加解密中加密的梅须逊雪三分白,雪却输梅一段香.使用go语言解密. 解密代码如下: AESUtil.go package util import ( "crypto/ ...
- Python 爬虫:煎蛋网妹子图
使用 Headless Chrome 替代了 PhatomJS. 图片保存到指定文件夹中. import requests from bs4 import BeautifulSoup from sel ...
- Lock和synchronized比较详解(转)
从Java5之后,在java.util.concurrent.locks包下提供了另外一种方式来实现同步访问,那就是Lock. 也许有朋友会问,既然都可以通过synchronized来实现同步访问了, ...
- D:苏卿念发红包
首先,题目中已经说得很明确了(按照常理也是). 当有mmm个包,你第kkk个抢.k>mk>mk>m的话.显然,平时会显示:来晚了一步,红包已经被领完了\text{来晚了一步,红包已经 ...
- [leetcode] 51. N-Queens (递归)
递归,经典的八皇后问题. 利用一位数组存储棋盘状态,索引表示行,值为-1表示空,否则表示列数. 对行进行搜索,对每一行的不同列数进行判断,如果可以摆放符合规则,则摆放,同时遍历下一行. 遍历过程中,若 ...