欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JSP的login程序代碼

 更新時(shí)間:2006年10月13日 00:00:00   作者:  
JSP的login程序代碼

<!-- Login Manager -->
<JAVA TYPE="class">

public static boolean checkUserPermission(HttpSession mySession, HttpServletRequest request, HttpServletResponse response)
{
if (mySession.getValue("hasPermission") == null || !((Boolean) mySession.getValue ("hasPermission" )).booleanValue())
{
String requestedUrl = HttpUtils.getRequestURL(request).toString();
String queryString = request.getQueryString();
if (queryString != null)
{
requestedUrl = requestedUrl + "?" + queryString;
}
requestedUrl = response.encodeUrl(requestedUrl);
mySession.putValue("requestedUrl", requestedUrl);
return false;
}
else
{
return true;
}
}

</JAVA>

<%
// JSP文件
String goodUser = "bill";
String goodPass = "bobo";
HttpSession mySession = request.getSession(true);
String errorMessage = "Please Login To Access The Page You Requested";
boolean loginAttempt = false;
String myMethod = request.getMethod();
if (request.getParameterValues("click") != null && request.getParameterValues ("click")[0].trim().equals("Log In"))
{
loginAttempt = true;
}

if (loginAttempt)
{
String username = request.getParameterValues("user")[0].trim();
String password = request.getParameterValues("pass")[0].trim();
//out.println("username = |" + username + "| & password = |" + password + "|<BR>");
if (goodUser.equals(username) && goodPass.equals(password))
{
response.sendRedirect((String)mySession.getValue("requestedUrl"));
mySession.putValue("hasPermission", new Boolean(true));
errorMessage = "Unable to redirect: " + (String) mySession.getValue("requestedUrl");
}
else
{
errorMessage = "You did not get the Username or Password right";
}
}
else
{
errorMessage = "Haven't tried logging in yet.";
if (mySession.getValue("requestedUrl") == null)
{
mySession.putValue("requestedUrl", "/index.jsp");
}
//out.println("set userReferrer to " + mySession.getValue("redirectTo") + "<BR>");
}
%>

<CENTER>
<font color=red><%=errorMessage%></font>
<TABLE align=center>
<FORM action="adminLogin2.jsp" method=post name="login">
<TR>
<TD>Username:</TD>
<TD><input type=text name=user value=""></TD>
</TR>
<TR>
<TD>Password:</TD>
<TD><input type=password name=pass value=""></TD>
</TR>
<TR>
<TD colspan=2 align=center><input type=submit name=click value="Log In"> </TD>
</TR>
</FORM>
</TABLE>
</CENTER>
Original URL: <%= (String)mySession.getValue("requestedUrl") %>
<script language="Javascript">
// <!--
if (document.forms.login != null)
document.forms.login.user.focus();
// -->
</script>

  5.11 checkbox在jsp中的使用方法



<%@ page language="Java" contentType="text/html" %>
<%@ page import="com.ora.jsp.util.*" %>
<html>
<body bgcolor="white">
<form action="checkbox.jsp">
<input type="checkbox" name="fruits" value="Apple">Apple<br>
<input type="checkbox" name="fruits" value="Banana">Banana<br>
<input type="checkbox" name="fruits" value="Orange">Orange<br>
<input type="submit" value="Enter">
</form>

<%
String[] picked = request.getParameterValues("fruits");
if (picked != null && picked.length != 0) {
%>
You picked the following fruits:
<form>
<input type="checkbox" name="fruits" value="Apple"
<%= ArraySupport.contains(picked, "Apple")?"checked" : "" %> >Apple<br>
<input type="checkbox" name="fruits" value="Banana"
<%= ArraySupport.contains(picked,"Banana")?"checked":"" %> >Banana<br>
<input type="checkbox" name="fruits" value="Orange"
<%= ArraySupport.contains(picked,"Orange")?"checked" : "" %> >Orange<br>
</form>
<% } %>
</body>
</html>

  5.12 request對(duì)象

  ·如何獲得一個(gè)運(yùn)行時(shí)刻的JSP/Servlet文件的絕對(duì)URL地址

String url = request.getRequestURL();
if (request.getQueryString() != null)
{
url += '?' + request.getQueryString();
}
URL theURL = new URL ( request.getScheme() , request.getServerName() , request.getServerPort(),url);
out.print(URL.toString());

  ·如何知道客戶端通過(guò)哪個(gè)URL訪問(wèn)本頁(yè)面

String callingPage = request.getHeader("Referer");
Out.print(callingPage);

  ·如果form中出現(xiàn)好幾個(gè)submit按鈕,JSP/Servlet如何判斷哪個(gè)按鈕進(jìn)行了提交在form中可以這樣定義:

<input type=submit name="name" value="john"><br>
<input type=submit name="name" value="joe"><br>
在JSP/Servlet中使用request.getParameter("name"),根據(jù)返回值就可進(jìn)行判斷。

  5.13 include指令

  這個(gè)指令讓你可以在JSP編譯成servlet的時(shí)候可以包含進(jìn)一些文件。這個(gè)指令是這樣的:

<%@ include file="relative url" %>

  這個(gè)指定的URL通常是指向它的JSP頁(yè)面的相關(guān)解釋。包含的文件內(nèi)容被當(dāng)作JSP文本來(lái)分析,因此可以包含靜態(tài) HTML、scripting elements、directives以及actions。

  例如,很多站點(diǎn)的每個(gè)頁(yè)面上都包含有小的導(dǎo)航條。這個(gè) include 是做這個(gè)的很好方法,省得開(kāi)發(fā)者經(jīng)??截怘TML到不同的文件中。例如:

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
<HTML>
<HEAD>
<TITLE>Servlet Tutorial: JavaServer Pages (JSP) 1.0</TITLE>
<META NAME="author" CONTENT="webmaster@somesite.com">
<META NAME="keywords" CONTENT="...">
<META NAME="description" CONTENT="...">
<LINK REL=STYLESHEET HREF="Site-Styles.css" TYPE="text/css">
</HEAD>
<BODY>
<%@ include file="/navbar.html" %>
<!-- Part specific to this page ... -->
</BODY>
</HTML>

  既然文件是在頁(yè)面被編譯的時(shí)候插入的,如果導(dǎo)航條改變了,你需要去重新編譯它所指向的所有JSP頁(yè)面。注意,問(wèn)題很容易在這里出現(xiàn)。一些讀者在改變導(dǎo)航條后,重新運(yùn)行包含導(dǎo)航條的JSP文件時(shí),發(fā)現(xiàn)導(dǎo)航條不變。原因有兩個(gè):一是前面提到的include指令在JSP編譯成servlet的時(shí)候包含進(jìn)導(dǎo)航條文件;第二就是JSP文件是被編譯成servlet之后再運(yùn)行的,如果服務(wù)器發(fā)現(xiàn)JSP文件沒(méi)有被修改,則直接去調(diào)用已經(jīng)編譯好的servlet。如此一來(lái),當(dāng)調(diào)用JSP文件時(shí),由于直接調(diào)用了編譯好的servlet,顯示的結(jié)果當(dāng)然就是以前的導(dǎo)航條了。只要稍微修改一下JSP文件,該問(wèn)題就可以自行解決。

  如果導(dǎo)航條不是經(jīng)常改變的,而且想要整個(gè)過(guò)程盡可能高效,那么在這樣的環(huán)境下這是好的妥協(xié)。 如果這個(gè) included 文件經(jīng)常改變,那么建議讀者使用用 jsp:include 行為(action)來(lái)代替。

相關(guān)文章

最新評(píng)論