KickJava   Java API By Example, From Geeks To Geeks.

Java > Open Source Codes > org > jboss > ejb3 > test > dd > web > servlets > ssl > SecureServlet


1 /*
2   * JBoss, Home of Professional Open Source
3   * Copyright 2005, JBoss Inc., and individual contributors as indicated
4   * by the @authors tag. See the copyright.txt in the distribution for a
5   * full listing of individual contributors.
6   *
7   * This is free software; you can redistribute it and/or modify it
8   * under the terms of the GNU Lesser General Public License as
9   * published by the Free Software Foundation; either version 2.1 of
10   * the License, or (at your option) any later version.
11   *
12   * This software is distributed in the hope that it will be useful,
13   * but WITHOUT ANY WARRANTY; without even the implied warranty of
14   * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15   * Lesser General Public License for more details.
16   *
17   * You should have received a copy of the GNU Lesser General Public
18   * License along with this software; if not, write to the Free
19   * Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
20   * 02110-1301 USA, or see the FSF site: http://www.fsf.org.
21   */

22 package org.jboss.ejb3.test.dd.web.servlets.ssl;
23
24 import java.io.IOException JavaDoc;
25 import java.io.PrintWriter JavaDoc;
26 import java.security.Principal JavaDoc;
27 import javax.servlet.ServletConfig JavaDoc;
28 import javax.servlet.ServletException JavaDoc;
29 import javax.servlet.http.HttpServlet JavaDoc;
30 import javax.servlet.http.HttpServletRequest JavaDoc;
31 import javax.servlet.http.HttpServletResponse JavaDoc;
32 import javax.servlet.http.HttpSession JavaDoc;
33
34 /** A servlet that is secured by the web.xml descriptor. When accessed
35  * it simply prints the getUserPrincipal that accessed the url.
36  *
37  * @author Scott.Stark@jboss.org
38  * @version $Revision: 37459 $
39  */

40 public class SecureServlet extends HttpServlet JavaDoc
41 {
42    private String JavaDoc expectedPrincipalName = null;
43
44    public void init(ServletConfig JavaDoc config)
45       throws ServletException JavaDoc
46    {
47       super.init(config);
48       expectedPrincipalName = config.getInitParameter("expectedPrincipalName");
49    }
50
51    protected void processRequest(HttpServletRequest JavaDoc request, HttpServletResponse JavaDoc response)
52       throws ServletException JavaDoc, IOException JavaDoc
53    {
54       // Validate that this is a secure connection
55
if( request.isSecure() == false )
56          throw new ServletException JavaDoc("Expected a secure connection");
57
58       // If there is an expectedPrincipalName validate it against the caller
59
Principal JavaDoc user = request.getUserPrincipal();
60       if( expectedPrincipalName != null )
61       {
62          
63       }
64
65       HttpSession JavaDoc session = request.getSession(false);
66       response.setContentType("text/html");
67       PrintWriter JavaDoc out = response.getWriter();
68       out.println("<html>");
69       out.println("<head><title>SecureServlet</title></head>");
70       out.println("<h1>SecureServlet Accessed</h1>");
71       out.println("<body>");
72       out.println("You have accessed this servlet as user:"+user);
73       if( session != null )
74          out.println("<br>The session id is: "+session.getId());
75       else
76          out.println("<br>There is no session");
77       out.println("</body></html>");
78       out.close();
79    }
80
81    protected void doGet(HttpServletRequest JavaDoc request, HttpServletResponse JavaDoc response)
82       throws ServletException JavaDoc, IOException JavaDoc
83    {
84       processRequest(request, response);
85    }
86
87    protected void doPost(HttpServletRequest JavaDoc request, HttpServletResponse JavaDoc response)
88       throws ServletException JavaDoc, IOException JavaDoc
89    {
90       processRequest(request, response);
91    }
92
93 }
94
Popular Tags