JavaWeb-HttpServletRequest和HttpServletResponse

HttpServletRequest

1.request获得请求行

获得客户端的请求方式:String getMethod()

获得请求的资源:
String getRequestURI()
StringBuffer getRequestURL()
String getContextPath() ---web应用的名称
String getQueryString() ---- get提交url地址后的参数字符串
username=wangwu&password=123

注意:request获得客户机(客户端)的一些信息
request.getRemoteAddr() --- 获得访问的客户端IP地址

 

2.request获得请求头

long getDateHeader(String name)
String getHeader(String name)
Enumeration getHeaderNames()
Enumeration getHeaders(String name)
int getIntHeader(String name)

referer头的作用:执行该此访问的的来源。可以做防盗链

 

3.request获得请求体

请求体中的内容是通过post提交的请求参数,格式是:
username=wangwu&password=123&hobby=football&hobby=basketball

key ------ value
username [wangwu]
password [123]
hobby [football,basketball]

以上面参数为例,通过一下方法获得请求参数:
String getParameter(String name)
String[] getParameterValues(String name)
Enumeration getParameterNames()

Map<String,String[]> getParameterMap()
注意:get请求方式的请求参数 上述的方法一样可以获得

解决post提交方式的乱码:
request.setCharacterEncoding("UTF-8");
解决get提交的方式的乱码:
parameter = new String(parameter.getbytes("iso8859-1"),"utf-8");


 

4.request的其他功能

(1)request是一个域对象
request对象也是一个存储数据的区域对象,所以也具有如下方法:
setAttribute(String name, Object o)
getAttribute(String name)
removeAttribute(String name)
注意:request域的作用范围:一次请求中

(2)request完成请求转发
获得请求转发器----path是转发的地址
RequestDispatcher getRequestDispatcher(String path)
通过转发器对象转发
requestDispathcer.forward(ServletRequest request, ServletResponse response)

注意:ServletContext域与Request域的生命周期比较?
ServletContext:
创建:服务器启动
销毁:服务器关闭
域的作用范围:整个web应用

request:
创建:访问时创建request
销毁:响应结束request销毁
域的作用范围:一次请求中

注意:转发与重定向的区别?--> http://www.jb51.net/article/120301.htm
1)重定向两次请求,转发一次请求
2)重定向地址栏的地址变化,转发地址不变
3)重新定向可以访问外部网站 转发只能访问内部资源
4)转发的性能要优于重定向

注意:客户端地址与服务器端地址的写法?
客户端地址:是客户端去访问服务器的地址,服务器外部的地址,特点:写上web应用名称

服务器端地址:服务器内部资源的跳转的地址,特点:不需要写web应用的名称


HttpServletResponse

1.response设置响应行

设置响应行的状态码:setStatus(int sc)
 

2.通过response设置响应头

addHeader(String name, String value)
addIntHeader(String name, int value)
addDateHeader(String name, long date)
setHeader(String name, String value)
setDateHeader(String name, long date)
setIntHeader(String name, int value)
注意:add表示添加,而set表示设置
 

3.通过response设置响应体

(1)响应体设置文本
PrintWriter getWriter()
获得字符流,通过字符流的write(String s)方法可以将字符串设置到response 缓冲区中,随后Tomcat会将response缓冲区中的内容组装成Http响应返回给浏览 器端。

关于设置中文的乱码问题
      原因:response缓冲区的默认编码是iso8859-1,此码表中没有中文,可以通过 response的setCharacterEncoding(String charset) 设置response的编码

      我们可以发现客户端还是不能正常显示文字。原因:我们将response缓冲区的编码设置成UTF-8,但浏览器的默认编码是本地系 统的编码,因为我们都是中文系统,所以客户端浏览器的默认编码是GBK,我们可以手动修改浏览器的编码是UTF-8。

      我们还可以在代码中指定浏览器解析页面的编码方式,通过response的setContentType(String type)方法指定页面解析时的编码是UTF-8
       response.setContentType("text/html;charset=UTF-8");
      上面的代码不仅可以指定浏览器解析页面时的编码,同时也内含setCharacterEncoding的功能,所以在实际开发中只要编写 response.setContentType("text/html;charset=UTF-8");就可以解决页面输出中文乱码问题。
 
(2)响应头设置字节
ServletOutputStream  getOutputStream()
获得字节流,通过该字节流的write(byte[] bytes)可以向response缓冲区中写入字 节,在由Tomcat服务器将字节内容组成Http响应返回给浏览器。



举例:完成文件下载

   文件下载的实质就是文件拷贝,将文件从服务器端拷贝到浏览器端。所以文件下载需 IO技术将服务器端的文件使用InputStream读取到,在使用 ServletOutputStream写到response缓冲区中。

    我们需要设置两个响应头,告知浏览器文件的类型和文件的打开方式。
       1、告知浏览器文件的类型:response.setContentType(文件的MIME类型);
       2、告示浏览器文件的打开方式是下载:response.setHeader("Content-Disposition","attachment;filename=文件名称");

文件名称是中文的下载   代码:
protected void doGet(HttpServletRequest request, HttpServletResponse response)
            throws ServletException, IOException {        
                //获得要下载的文件的名称
		String filename = request.getParameter("filename");//????.jpg
		//解决获得中文参数的乱码
		filename = new String(filename.getBytes("ISO8859-1"),"UTF-8");//中文.jpg

		//获得请求头中的User-Agent
		String agent = request.getHeader("User-Agent");
		//根据不同浏览器进行不同的编码
		String filenameEncoder = "";
		if (agent.contains("MSIE")) {
			// IE浏览器
			filenameEncoder = URLEncoder.encode(filename, "utf-8");
			filenameEncoder = filenameEncoder.replace("+", " ");
		} else if (agent.contains("Firefox")) {
			// 火狐浏览器
			BASE64Encoder base64Encoder = new BASE64Encoder();
			filenameEncoder = "=?utf-8?B?"
					+ base64Encoder.encode(filename.getBytes("utf-8")) + "?=";
		} else {
			// 其它浏览器
			filenameEncoder = URLEncoder.encode(filename, "utf-8");				
		}
                //要下载的这个文件的类型-----客户端通过文件的MIME类型去区分类型
                response.setContentType(this.getServletContext().getMimeType(filename));
                //告诉客户端该文件不是直接解析 而是以附件形式打开(下载)----filename="+filename 客户端默认对名字进行解码
                response.setHeader("Content-Disposition", "attachment;filename="+filenameEncoder);

                //获取文件的绝对路径
                String path = this.getServletContext().getRealPath("download/"+filename);
                //获得该文件的输入流
                InputStream in = new FileInputStream(path);
                //获得输出流---通过response获得的输出流 用于向客户端写内容
                ServletOutputStream out = response.getOutputStream();
                //文件拷贝的模板代码
                int len = 0;
                byte[] buffer = new byte[1024];
                while((len=in.read(buffer))>0){
                out.write(buffer, 0, len);
            }
            in.close();
}
		


        如果下载中文文件,页面在下载时会出现中文乱码或不能显示文件名的情况, 原因是不同的浏览器默认对下载文件的编码方式不同,ie是UTF-8编码方式,而火狐 浏览器是Base64编码方式。所里这里需要解决浏览器兼容性问题,解决浏览器兼容 性问题的首要任务是要辨别访问者是IE还是火狐(其他),通过Http请求体中的一 个属性可以辨别。agent就是请求头User-Agent的值

解决乱码方法如下:

if (agent.contains("MSIE")) {
    // IE浏览器
    filename = URLEncoder.encode(filename, "utf-8");
    filename = filename.replace("+", " ");
} else if (agent.contains("Firefox")) {
    // 火狐浏览器
    BASE64Encoder base64Encoder = new BASE64Encoder();
    filename = "=?utf-8?B?"+ base64Encoder.encode(filename.getBytes("utf-8")) + "?=";
} else {
    // 其它浏览器
    filename = URLEncoder.encode(filename, "utf-8");				
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值