静态的登录界面的设计login.htm,代码如下:
<html>
<cabeça>
<title>系统登录</title>
<style type="text/css">...
<!--
.style1 {...}{
tamanho da fonte: 18px;
peso da fonte: negrito;
}
.style2 {...}{tamanho da fonte: 24px}
.style5 {...}{tamanho da fonte: 16px}
-->
</estilo>
</head>
<body bgcolor="papayawhip" width="300" height="300">
<centro>
<table border="2" bordercolor="black" bgcolor="lightgreen">
<corpo>
<tr>
<td><div align="center" class="style1 style2">系 统 登 录
</div></td>
</tr>
<form action="login.jsp" método="post">
<tr>
<td height="28"><span class="style5">用户名</span> <input type="text" name="uid" maxlength="20" style="width:150"></td </tr><br>
<tr>
<td><span class="style5">密 码</span> <input type="password" name="upwd" maxlength="20" style="width:150"></td> </tr><br>
<centro>
<tr><td><div align="center">
<input type="submit" value="登录" >
<input type="reset" value="取消">
</div></td></tr>
</centro>
</form>
</tbody>
</tabela>
</centro>
</body>
</html>
将登录用户输入的信息提交到login.jsp页面机型处理,这里为了方便,不执行数据库的访问操作,直接使用sky2098作为登录用户名和密码,但在实际中是要从数据库中读取的,该jsp页面代码实现如下:
<%...@ page contentType="text/html;charset=GB2312"%>
<%...
if(request.getParameter("uid").equals("sky2098")&&request.getParameter("upwd").equals("sky2098")){
session.setAttribute("login","ok");
sessão.setMaxInactiveInterval(-1);
%>
<jsp:forward page="main.jsp"/>
<%...
}outro{
out.println("用户名或密码输入错误!");
}
%>
如果登录成功,则设定login的值为ok,提交到下一步验证页面,则进入main.jsp页面用户名和密码不合法就打印错误信息,main.jsp页面代码如下:
<%...@ page contentType="text/html;charset=GB2312"%>
<%...@include arquivo="checkvalid.jsp" %>
<html>
<cabeça>
<title>~BEM-VINDO À MINHA PÁGINA INICIAL~</title>
</head>
<corpo>
<centro>
~BEM-VINDO À MINHA PÁGINA~
</centro>
</body>
</html>
这个页面使用<% @ include file="checkvalid.jsp" %>包含了一个jsp页面checkvalid.jsp为了验证输入信息的合法性:
<%...
if(session.getAttribute("login")==null||!session.getAttribute("login").equals("ok")){
resposta.sendRedirect("login.htm");
}
%>
如果输入信息有误,则回到登录页面,重新输入登录信息。
测试登录功能。
启动Tomcat服务器,在IE地址栏中键入URL为: