In URL rewriting, we append a token or identifier to the URL of the next Servlet or the next resource. We can send parameter name/value pairs using the following format:
url?name1=value1&name2=value2&??
A name and a value is separated using an equal = sign, a parameter name/value pair is separated from another parameter using the ampersand(&). When the user clicks the hyperlink, the parameter name/value pairs will be passed to the server. From a Servlet, we can use getParameter() method to obtain a parameter value.
Advantage of URL Rewriting
- It will always work whether cookie is disabled or not (browser independent).
- Extra form submission is not required on each pages.
Disadvantage of URL Rewriting
- It will work only with links.
- It can send Only textual information.
Example of using URL Rewriting
In this example, we are maintaning the state of the user using link. For this purpose, we are appending the name of the user in the query string and getting the value from the query string in another page.
index.html
- <form action="servlet1">
- Name:<input type="text" name="userName"/><br/>
- <input type="submit" value="go"/>
- </form>
FirstServlet.java
- import java.io.*;
- import javax.servlet.*;
- import javax.servlet.http.*;
-
-
- public class FirstServlet extends HttpServlet {
-
- public void doGet(HttpServletRequest request, HttpServletResponse response){
- try{
-
- response.setContentType("text/html");
- PrintWriter out = response.getWriter();
-
- String n=request.getParameter("userName");
- out.print("Welcome "+n);
-
-
- out.print("<a href='servlet2?uname="+n+"'>visit</a>");
-
- out.close();
-
- }catch(Exception e){System.out.println(e);}
- }
-
- }
SecondServlet.java
- import java.io.*;
- import javax.servlet.*;
- import javax.servlet.http.*;
-
- public class SecondServlet extends HttpServlet {
-
- public void doGet(HttpServletRequest request, HttpServletResponse response)
- try{
-
- response.setContentType("text/html");
- PrintWriter out = response.getWriter();
-
-
- String n=request.getParameter("uname");
- out.print("Hello "+n);
-
- out.close();
-
- }catch(Exception e){System.out.println(e);}
- }
-
-
- }
web.xml
- <web-app>
-
- <servlet>
- <servlet-name>s1</servlet-name>
- <servlet-class>FirstServlet</servlet-class>
- </servlet>
-
- <servlet-mapping>
- <servlet-name>s1</servlet-name>
- <url-pattern>/servlet1</url-pattern>
- </servlet-mapping>
-
- <servlet>
- <servlet-name>s2</servlet-name>
- <servlet-class>SecondServlet</servlet-class>
- </servlet>
-
- <servlet-mapping>
- <servlet-name>s2</servlet-name>
- <url-pattern>/servlet2</url-pattern>
- </servlet-mapping>
-
- </web-app>
HttpSession interface
In such case, container creates a session id for each user.The container uses this id to identify the particular user.An object of HttpSession can be used to perform two tasks:
- bind objects
- view and manipulate information about a session, such as the session identifier, creation time, and last accessed time.
How to get the HttpSession object ?
The HttpServletRequest interface provides two methods to get the object of HttpSession:
- public HttpSession getSession():Returns the current session associated with this request, or if the request does not have a session, creates one.
- public HttpSession getSession(boolean create):Returns the current HttpSession associated with this request or, if there is no current session and create is true, returns a new session.
Commonly used methods of HttpSession interface
- public String getId():Returns a string containing the unique identifier value.
- public long getCreationTime():Returns the time when this session was created, measured in milliseconds since midnight January 1, 1970 GMT.
- public long getLastAccessedTime():Returns the last time the client sent a request associated with this session, as the number of milliseconds since midnight January 1, 1970 GMT.
- public void invalidate():Invalidates this session then unbinds any objects bound to it.
Example of using HttpSession
In this example, we are setting the attribute in the session scope in one servlet and getting that value from the session scope in another servlet. To set the attribute in the session scope, we have used the setAttribute() method of HttpSession interface and to get the attribute, we have used the getAttribute method.
index.html
- <form action="servlet1">
- Name:<input type="text" name="userName"/><br/>
- <input type="submit" value="go"/>
- </form>
FirstServlet.java
- import java.io.*;
- import javax.servlet.*;
- import javax.servlet.http.*;
-
-
- public class FirstServlet extends HttpServlet {
-
- public void doGet(HttpServletRequest request, HttpServletResponse response){
- try{
-
- response.setContentType("text/html");
- PrintWriter out = response.getWriter();
-
- String n=request.getParameter("userName");
- out.print("Welcome "+n);
-
- HttpSession session=request.getSession();
- session.setAttribute("uname",n);
-
- out.print("<a href='servlet2'>visit</a>");
-
- out.close();
-
- }catch(Exception e){System.out.println(e);}
- }
-
- }
SecondServlet.java
- import java.io.*;
- import javax.servlet.*;
- import javax.servlet.http.*;
-
- public class SecondServlet extends HttpServlet {
-
- public void doGet(HttpServletRequest request, HttpServletResponse response)
- try{
-
- response.setContentType("text/html");
- PrintWriter out = response.getWriter();
-
- HttpSession session=request.getSession(false);
- String n=(String)session.getAttribute("uname");
- out.print("Hello "+n);
-
- out.close();
-
- }catch(Exception e){System.out.println(e);}
- }
-
-
- }
web.xml
- <web-app>
-
- <servlet>
- <servlet-name>s1</servlet-name>
- <servlet-class>FirstServlet</servlet-class>
- </servlet>
-
- <servlet-mapping>
- <servlet-name>s1</servlet-name>
- <url-pattern>/servlet1</url-pattern>
- </servlet-mapping>
-
- <servlet>
- <servlet-name>s2</servlet-name>
- <servlet-class>SecondServlet</servlet-class>
- </servlet>
-
- <servlet-mapping>
- <servlet-name>s2</servlet-name>
- <url-pattern>/servlet2</url-pattern>
- </servlet-mapping>
-
- </web-app>
No comments:
Post a Comment