request和response简介

response对象(响应对象)

想要获取客户端的内容,使用request对象。对客户端做出响应使用response对象。
1. 响应:
响应行
状态码:
void setStatus(int sc) 设置状态码

2. 响应头(key:value的形式,一个key对应一个value,一个key对应多个value)
设置头信息

void setHeader(String name, String value)  (一个key对应一个value)经常使用的
	setHeader("aa","bb");
	setHeader("aa","cc");
	结果:aa:cc

void setIntHeader(String name, int value)  
void setDateHeader(String name, long date) 值是毫秒值(intlong 毫秒)
					
void addHeader(String name, String value)  (一个key对应多个value)
	addHeader("aa","bb");
	addHeader("aa","cc");
	结果:aa:bb,cc

void addIntHeader(String name, int value)  
void addDateHeader(String name, long date)  

3. 响应体
ServletOutputStream getOutputStream() 字节输出流
PrintWriter getWriter() 字符输出流

4. 案例
重定向(登录页面)
* 登录页面重定向
* 状态码302 应头location
* 需求:登录页面,用户名和密码的登录页面,用户名和密码都是admin,如果有一个不是,重定向到登录页面,重新登录。

// 设置302的状态码
response.setStatus(302);
// 设置地址
response.setHeader("location", "/day10/response/login.html");	

// response对象提供了一个方法,可以完成重定向。
response.sendRedirect("/day10/response/login.html");

页面定时刷新(页面读秒操作)
响应的头 refresh

<meta http-equiv="refresh" content="5;url=/day10/response/login.html">

禁用浏览器缓存(三个头信息)
* 应用:网银。页面的数据是发送变化的。
Cache-Control : no-cache
Expires: -1 值是日期类型(setDateHeader())
Pragma : no-cache

向页面输出中文(乱码问题)
字节:ServletOutputStream getOutputStream() 字节输出流
* 字节的输出中文的乱码
* * 输出哈罗我的是否乱码呢?
* * 不一定乱码。
* * 解决办法
* * 设置浏览器打开文件时所采用的编码
* response.setHeader(“Content-Type”, “text/html;charset=UTF-8”);
* * 获取字符串byte数组时编码和打开文件时编码一致。
* “哈罗我的”.getBytes(“UTF-8”)

PrintWriter getWriter() 字符输出流

字符输出中文是否乱码呢?
* * 肯定乱码
* response缓冲区的编码,默认值ISO-8859-1
* * 设置response缓冲编码
* response.setCharacterEncoding(“UTF-8”);
* * 设置浏览器打开文件所采用的编码
* response.setHeader(“Content-Type”, “text/html;charset=UTF-8”);
* * 简写方式
* response.setContentType(“text/html;charset=UTF-8”);

总结:
response对象输出中文,产生乱码。
* 字节
* 解决方案
* 设置浏览器打开文件时采用的编码
response.setHeader(“Content-Type”, “text/html;charset=UTF-8”);
* 获取字符串的byte数组采用的编码
“哈罗我的”.getBytes(“UTF-8”)
* 字符
* 解决方法
* 设置浏览器打开文件时采用的编码
response.setHeader(“Content-Type”, “text/html;charset=UTF-8”);
* 设置response缓冲区的编码
response.setCharacterEncoding(“UTF-8”);

简写的方式(等于上面的两句)
* response.setContentType(“text/html;charset=UTF-8”);

实现文件下载(初级的下载)
* 超链接,浏览器可以解析直接打开。
* 弹出下载窗口。
* 前提条件:先准备一个文件。
* 读取文件,读入到输入流中。
* 通过response读出到浏览器端。
* 设置头信息
* Content-Disposition attachment;filename=文件名称
* 以附件的形式打开。
实现验证码
验证码与登录结合

request对象(请求对象)

	ServletRequest
		|
	HttpServletRequest	

获取客户机信息
getRemoteAddr 获取IP地址
getMethod() 获取请求方式
getContextPath() 获取虚拟路径

获取请求头信息
String getHeader(String name)
long getDateHeader(String name)
int getIntHeader(String name)

请求头
referer 记住当前网页的来源
User-Agent 判断浏览器
if-modified-since 控制缓存

获取请求参数
String getParameter(String name) 获取一个name
String[] getParameterValues(String name) 获取多个name

Map getParameterMap() 获取map键值的形式

Enumeration getParameterNames() 枚举类型(用的比较少)

乱码问题解决:
POST请求乱码 :request.setCharacterEncoding(“utf-8”);

GET请求乱码
解决方案一:
修改tomcat/conf/server.xml

<Connector port="80" protocol="HTTP/1.1" 
	connectionTimeout="20000" 
	redirectPort="8443" URIEncoding="utf-8"/>

必须有修改tomcat服务器配置文件权限

解决方案二:
逆向编解码
username = URLEncoder.encode(username, “ISO8859-1”);
username = URLDecoder.decode(username, “utf-8”);

解决方案三:
简写的方式(推荐使用)
username = new String(username.getBytes(“ISO-8859-1”),“utf-8”);

request获取中文数据乱码(总结:)
* post提交
* 设置request缓冲区的编码
request.setCharacterEncoding(“utf-8”);
* get提交
* String构造方法
username = new String(username.getBytes(“ISO-8859-1”),“utf-8”);
代码案例
reg.html

<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Insert title here</title>
</head>
<body>
	<form action="/reg" method="get">
		<table border="1" width="50%">
			<tr>
				<td>输入姓名</td>
				<td>
					<input type="text" name="username" />
				</td>
			</tr>
			<tr>
				<td>输入密码</td>
				<td>
					<input type="password" name="password" />
				</td>
			</tr>
			<tr>
				<td>选择性别</td>
				<td>
					<input type="radio" name="sex" value="nan" /><input type="radio" name="sex" value="nv" /></td>
			</tr>
			<tr>
				<td>选择爱好</td>
				<td>
					<input type="checkbox" name="love" value="lq" />篮球
					<input type="checkbox" name="love" value="zq" />足球
					<input type="checkbox" name="love" value="pq" />排球
				</td>
			</tr>
			<tr>
				<td>选择城市</td>
				<td>
					<select name="city">
						<option value="none">--请选择--</option>
						<option value="bj">北京</option>
						<option value="sh">上海</option>
						<option value="gz">广州</option>
					</select>
				</td>
			</tr>
			<tr>
				<td colspan="2">
					<input type="submit" value="登录"/>
				</td>
			</tr>
		</table>
	
	</form>

</body>
</html>

RegServelt.java

package cn.itcast.request;

import java.io.IOException;
import java.util.Arrays;
import java.util.Map;
import java.util.Set;

import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

/**
 * 获取请求参数
 * @author Administrator
 *
 */
public class RegServlet extends HttpServlet {

	public void doGet(HttpServletRequest request, HttpServletResponse response)
			throws ServletException, IOException {
		
		/**
		 * request获取中文的乱码
		 * 	post请求(经常使用)
		 * 		setCharacterEncoding(String env) 设置request的缓冲区的编码
		 * 	get请求	
		 * 		username = new String(username.getBytes("ISO-8859-1"),"UTF-8");
		 */
		
		// 设置request缓冲区的编码(一定要在request.getParameter("username");之前)
		// request.setCharacterEncoding("UTF-8");
		
		// 获取内容,做其他操作
		// 获取姓名
		String username = request.getParameter("username");
		// 解析get方式乱码的问题
		username = new String(username.getBytes("ISO-8859-1"),"UTF-8");
		// 获取密码
		String password = request.getParameter("password");
		// 获取性别
		String sex = request.getParameter("sex");
		// 获取城市
		String city = request.getParameter("city");
		// 获取爱好	返回是String数组
		String [] loves = request.getParameterValues("love");
		
		System.out.println("用户名:"+username);
		System.out.println("密码:"+password);
		System.out.println("性别:"+sex);
		System.out.println("城市:"+city);
		System.out.println("爱好:"+Arrays.toString(loves));
		
		System.out.println("===================================================================");
		// 获取map集合
		Map<String, String []> map = request.getParameterMap();
		// 循环遍历
		Set<String> keys = map.keySet();
		for (String key : keys) {
			String [] values = map.get(key);
			System.out.println(Arrays.toString(values));
		}
	}

	public void doPost(HttpServletRequest request, HttpServletResponse response)
			throws ServletException, IOException {
		doGet(request, response);
	}

}

利用请求域传递对象(request域对象)
重定向和转发的区别(转发)

域对象
ServletContext:服务器一启动,为每个web应用创建一个ServletContext对象,所有servlet实例共享对象。
request:一次请求的范围。

setAttribute("","");
getAttribute("");
removeAttribute("");

getRequestDispatcher(String path) ,返回是RequestDispatcher:对象
RequestDispatcher:
forward(ServletRequest request, ServletResponse response)(经常使用) 转发的方法
include(ServletRequest request, ServletResponse response)(了解) 包含
重定向与转发
代码案例
login.jsp

<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Insert title here</title>
</head>
<body>
	
	${msg}
	<form action="login2" method="post">
		<table border="1" width="50%">
			<tr>
				<td>输入姓名</td>
				<td>
					<input type="text" name="username" />
				</td>
			</tr>
			<tr>
				<td>输入密码</td>
				<td>
					<input type="password" name="password" />
				</td>
			</tr>
			<tr>
				<td colspan="2">
					<input type="submit" value="登录"/>
				</td>
			</tr>
		</table>
	</form>
	
</body>
</html>

LoginServlet.java

package cn.itcast.request;

import java.io.IOException;

import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

/**
 * 使用转发到登陆页面
 * @author Administrator
 *
 */
public class Login2Servlet extends HttpServlet {
	
	public void doGet(HttpServletRequest request, HttpServletResponse response)
			throws ServletException, IOException {
		
		/**
		 * 	先获取用户输入的内容(request对象)
		 * 	判断姓名和密码是否都是admin,如果有一个不是,重定向到登陆页面,如果都是,就登陆成功。
		 */
		// 获取用户输入的内容
		String username = request.getParameter("username");	// 程序入口
		// 获取密码
		String password = request.getParameter("password");
		// 判断
		if("admin".equals(username) && "admin".equals(password)){
			// 登陆成功
			// 重定向到登陆页面
			response.sendRedirect("/day10/response/refresh.html");
		}else{
			// 在request域存入内容
			request.setAttribute("msg", "用户名或者密码错误!");
			// 重定向到登陆页面
			// 重定向
			// response.sendRedirect("/day10/response/login.html");
			//转发
			request.getRequestDispatcher("/request/login.jsp").forward(request, response);
		}
	}

	public void doPost(HttpServletRequest request, HttpServletResponse response)
			throws ServletException, IOException {
		doGet(request, response);
	}

}

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值