servlet三大作用域以及cookie的使用
package com.xuedao.servlet;
import java.io.IOException;
import javax.servlet.ServletContext;
import javax.servlet.ServletException;
import javax.servlet.http.Cookie;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
public class UserServlet extends HttpServlet {
private static final long serialVersionUID = 1L;
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
request.setAttribute("msg", "RequestMsg");
HttpSession sesson = request.getSession();
sesson.setAttribute("msg", "SessionMsg");
ServletContext application = request.getServletContext();
application.setAttribute("msg", "ApplicationMsg");
Cookie cookie = new Cookie("username","root");
cookie.setPath("localhost:8080/day11_servlet/");
response.addCookie(cookie);
request.getRequestDispatcher("/role").forward(request, response);
}
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
doGet(request, response);
}
}
package com.xuedao.servlet;
import java.io.IOException;
import java.io.PrintWriter;
import javax.servlet.ServletException;
import javax.servlet.http.Cookie;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
public class RoleServlet extends HttpServlet {
private static final long serialVersionUID = 1L;
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
PrintWriter out = response.getWriter();
response.setCharacterEncoding("utf-8");
response.setContentType("text/html;character=utf-8");
Object str = request.getAttribute("msg");
Object so = request.getSession().getAttribute("msg");
Object ap = request.getServletContext().getAttribute("msg");
out.write("request存储的数据为:" + str +"<br> ");
out.write("session存储的数据为:" + so +"<br>");
out.write("application存储的数据为:" + ap +"<br>");
Cookie[] cookies = request.getCookies();
if(cookies!=null) {
for (Cookie cookie : cookies) {
if("username".equals(cookie.getName())) {
System.out.println(cookie.getValue());
}
}
}
}
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
doGet(request, response);
}
}
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" id="WebApp_ID" version="2.5">
<display-name>day11_servlet</display-name>
<welcome-file-list>
<welcome-file>index.html</welcome-file>
<welcome-file>index.htm</welcome-file>
<welcome-file>index.jsp</welcome-file>
<welcome-file>default.html</welcome-file>
<welcome-file>default.htm</welcome-file>
<welcome-file>default.jsp</welcome-file>
</welcome-file-list>
<servlet>
<description></description>
<display-name>UserServlet</display-name>
<servlet-name>UserServlet</servlet-name>
<servlet-class>com.xuedao.servlet.UserServlet</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>UserServlet</servlet-name>
<url-pattern>/user</url-pattern>
</servlet-mapping>
<servlet>
<description></description>
<display-name>RoleServlet</display-name>
<servlet-name>RoleServlet</servlet-name>
<servlet-class>com.xuedao.servlet.RoleServlet</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>RoleServlet</servlet-name>
<url-pattern>/role</url-pattern>
</servlet-mapping>
</web-app>