客户端浏览器发送一个请求,服务器作出一系列操作后作出一个响应,发送给客户端,完成一次Web过程操作。Web编程的过程就是通过分析客户需要什么信息或者进行了什么操作,然后进行一系列的处理,最后通过响应结果显示给客户。即一次请求-响应的过程。
一、请求-HttpServletRequest对象
客户端浏览器的请求被封装成一个HttpServletRequest对象。所有的信息包括请求的地址,请求的参数,提交的数据,上传的文件,客户端的IP地址甚至客户端操作系统都包含在HttpServletRequest对象中。
- 封装信息以及获取的方法:
1、编码信息和文档类型。
1)编码信息:设置与获取编码信息
A、request.setCharacterEncoding("UTF-8") :设置编码
B、request.getCharacterEncoding() :获取编码方法。
2)文档信息:设置与获取文档信息
A、response.setContentType("text/html") :设置 文档类型为HTML类型。这边可以设置输出数据的类型,text/html、image/jpeg、application/msword
B、request.getContentType() :获取文档类型。
3)代码示例:
// 1-设置编码方式,可以用时setCharacterEncodingFilter过滤器统一处理
request.setCharacterEncoding("UTF-8");// 设置 request 的编码方式
response.setCharacterEncoding("UTF-8");// 设置 response 的编码方式
response.setContentType("text/html");// 设置 文档类型为HTML类型
request.getCharacterEncoding();
request.getContentType();
2、服务器信息。
1)Authorization信息:request.getAuthType()
2)本地IP, 即服务器IP:request.getLocalAddr()
A、实际项目中,一般会用到java.net包下 InetAddress 来获取服务器的真实 IP 地址:
// 2-1 实际项目中,一般会用到java.net包下 InetAddress 来获取服务器的真实 IP 地址
String myLocalIp = InetAddress.getLocalHost().getHostAddress();// 本地地址,服务器IP地址
logger.debug("利用java.net包下 InetAddress 来获取服务器真实 IP 地址: " + myLocalIp);
3)本地名称, 即服务器名称: request.getLocalName()
4)本地端口号, 即Tomcat 端口号: request.getLocalPort()
5)本地环境: Locale locale = request.getLocale();
Locale locale = request.getLocale();// 本地环境
2.String localLangurage = getLocaleLangurage(locale);// 语言环境
3.String localCountry = locale.getCountry();// 国家
6)服务器名称:request.getServerName()
7)服务器端口:request.getServerPort()
3、客户端信息。
1)远程IP,即客户端IP:request.getRemoteAddr()
2)远程端口,即客户端端口:request.getRemotePort()
3)客户端的IP,往往会有代理,所以一般的获取方法,需要处理代理信息:
// 客户端的IP,往往会有代理,所以一般的获取方法,需要处理信息
String realCusIp = getRealCusIpAddr(request);//真实客户端IP地址
/**
* 获得用户真实IP
*
* @param request 请求对象
* @return 真实IP地址
*/
public String getRealCusIpAddr(HttpServletRequest request) {
String ip = request.getHeader("x-forwarded-for");
if (ip == null || ip.length() == 0 || "unknown".equalsIgnoreCase(ip)) {
ip = request.getHeader("Proxy-Client-IP");
}
if (ip == null || ip.length() == 0 || "unknown".equalsIgnoreCase(ip)) {
ip = request.getHeader("WL-Proxy-Client-IP");
}
if (ip == null || ip.length() == 0 || "unknown".equalsIgnoreCase(ip)) {
ip = request.getRemoteAddr();
}
return ip;
}
4)远程用户:
request.getRemoteUser()。
如果提供了Authorization头,则代表其用户部分。它代表发出请求的用户的名字。
4、获取请求信息。
1)获取本次请求的协议信息
A、协议,这里为HTTP协议:request.getProtocol()
B、协议头,这里为Http: request.getScheme()
2)获取头信息 利用浏览器都可以看到
A、浏览器支持的格式,访问Accept的HTTP头: request.getHeader("accept")
B、从哪个页面单机链接到了本页:直接输入为空。request.getHeader("referer")
C、User Agent 信息:request.getHeader("user-agent")
D、其他:request.getHeader("Host") | request.getHeader("Accept-Language") |
request.getHeader("Accept-Encoding") | request.getHeader("Connection")|
request.getHeader("Cookie");
3)获取本次请求的一些基本信息
A、访问的方式:Get还是Post。request.getMethod()
B、查询字符串,即访问时 ? 后面的字符串。request.getQueryString()
C、用户请求的URI:request.getRequestURI(),权限使用。
D、用户请求的URL: request.getRequestURL()
用户请求的URL: http://localhost:8080/JavaWeb/servlet/RequestServlet,那么用户请求的URI为: /JavaWeb/servlet/RequestServlet
4)获取请求的Servlet的信息
A、Context路径:request.getContextPath()。上下文路径,一般是“/工程名”,如:/JavaWeb
B、Servlet的路径: request.getServletPath()。访问的servlert的路径,一般可以在filter中使用,作为拦截。如:/servlet/RequestServlet 。
C、URL中Servlet路径之后、查询字符串之前的那部分: request.getPathInfo()
D、映射到服务器实际路径之后的路径信息: getPathTranslated()
E、 request.getServletPath() 和 request.getPathInfo()的差别,见文章。
5、其他信息
1)客户端Session的ID: request.getRequestedSessionId()
2)获取Session信息:request.getSession()
3)获取CooKie信息:request.getCookies()
4)当前授权用户的名称: request.getUserPrincipal()
5)本Servlet运行的服务器信息:this.getServletContext().getServerInfo()
8、使用头信息request.getHeader("referer"), 实现防盗链。
二、响应-HttpServletResponse
服务器对客户端浏览器作出的响应被封装成一个HttpServletResponse 对象。要对浏览器进行操作,只要要操作HttpServletResponse 对象就可以了。通过HttpServletResponse.getWriter()获得一个 PrintWriter 对象,该对象为 OutputStream 的子类。
1、HttpServletResponse.getWriter():对象只能写字符型的数据。HttpServletResponse.getOutputStream ():写二进制数据,如输出图片等。注意:这两个方法不能同时使用,特别是多层转发的时候,使用的还是同一个request对象,不能同时调用这两个方法。(getOutputStream () has already bean called for this response)
2、输出必须设置输出类型:response.setContentType("image/jpeg"),需要与输出方式统一。