- p_w_picpath.jsp用於生成數字圖片
- <%@ page contentType="p_w_picpath/jpeg;charset=gb2312" import="java.awt.*,
- java.awt.p_w_picpath.*,java.util.*,javax.p_w_picpathio.*" %>
- <%!
- Color getRandColor(int fc,int bc){//給定範圍得到隨機顏色
- Random random = new Random();
- if(fc>255) fc=255;
- if(bc>255) bc=255;
- int r=fc+random.nextInt(bc-fc);
- int g=fc+random.nextInt(bc-fc);
- int b=fc+random.nextInt(bc-fc);
- return new Color(r,g,b);
- }
- %>
- <%
- //設置頁面不緩存
- response.setHeader("Pragma","No-cache");
- response.setHeader("Cache-Control","no-cache");
- response.setDateHeader("Expires", 0);
- // 在內存中建立圖象
- int width=60, height=20;
- BufferedImage p_w_picpath = new BufferedImage(width, height, BufferedImage.TYPE_INT_RGB);
- // 獲取圖形上下文
- Graphics g = p_w_picpath.getGraphics();
- //生成隨機類
- Random random = new Random();
- // 設定背景色
- g.setColor(getRandColor(200,250));
- g.fillRect(0, 0, width, height);
- //設定字體
- g.setFont(new Font("Times New Roman",Font.PLAIN,18));
- //畫邊框
- //g.setColor(new Color());
- //g.drawRect(0,0,width-1,height-1);
- // 隨機產生155條幹擾線,使圖象中的認證碼不易被其它程序探測到
- g.setColor(getRandColor(160,200));
- for (int i=0;i<155;i++)
- {
- int x = random.nextInt(width);
- int y = random.nextInt(height);
- int xl = random.nextInt(12);
- int yl = random.nextInt(12);
- g.drawLine(x,y,x+xl,y+yl);
- }
- // 取隨機產生的認證碼(4位數字)
- String sRand="";
- String rand="";
- for (int i=0;i<4;i++){
- rand=String.valueOf(random.nextInt(10));
- sRand+=rand;
- // 將認證碼顯示到圖象中
- g.setColor(new Color(20+random.nextInt(110),20+random.nextInt(110),20+random.nextInt(110)));
- //調用函數出來的顏色相同,多是由於種子太接近,因此只能直接生成
- g.drawString(rand,13*i+6,16);
- }
- // 圖象生效
- g.dispose();
- // 將認證碼存入SESSION
- session.setAttribute("random",sRand);
- // 輸出圖象到頁面
- ImageIO.write(p_w_picpath, "JPEG", response.getOutputStream());
- %>
- login.jsp用於進入登錄界面:
- <%@ page contentType="text/html; charset=gb2312" language="java" errorPage="" %>
- <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
- <%
- String Username=request.getParameter("Username");
- String Password=request.getParameter("Password");
- String input= request.getParameter("rand");
- if (Username!=null && Password!=null)
- {
- //把用戶名和密碼保存在session中
- session.setAttribute("user_name",Username);
- session.setAttribute("pass_word",Password);
- session.setAttribute("input",input);
- //驗證用戶輸入的驗證碼是否正確
- if(input.equals(session.getAttribute("random")))
- {
- //若是正確就跳轉到check.jsp驗證用戶名密碼
- response.sendRedirect("check.jsp");
- }
- else
- {
- //驗證碼不正確
- out.print("錯誤");
- // JOptionPane.showMessageDialog(null,"請選擇文件!","提示",JOptionPane.ERROR_MESSAGE);
- }
- }
- %>
- <script type="text/javascript">
- function check()
- {
- if (form.Username.value=="")
- {
- alert("請輸入用戶名!!!");
- form.Username.focus();
- return false;
- }
- if (form.Password.value=="")
- {
- alert("請輸入密碼!!!");
- form.Username.focus();
- return false;
- }
- }
- </SCRIPT>
- <html>
- <HEAD>
- <title>用戶登錄</title>
- </HEAD>
- <BODY>
- <form name="form" onsubmit="return check()" action="login.jsp" method="post">
- <TABLE width=265 align=center border=0>
- <TBODY>
- <TR align=center valign="middle">
- <TD colspan="2">
- <STRONG>登陸</STRONG>
- </TD>
- </TR>
- <tr>
- <td height="54" align="center">用戶名:</td>
- <td width="181" height=54>
- <input id=Username name=Username>
- </TD>
- </TR>
- <tr>
- <td height="54" align="center">密碼:</td>
- <td width="181" height=54>
- <input id=Password type=Password name=Password>
- </TD>
- </TR>
- <tr>
- <td height="54" align="center">認證碼:</td>
- <td width="181" height=54>
- <input type=text name=rand maxlength=4 value="" size=6>
-
- <img border=1 src="p_w_picpath.jsp">
- </td>
- </tr>
- <TR>
- <TD colspan="2" align=center>
- <INPUT type=submit value=登錄>
- <INPUT type=reset value=重置>
- </TD>
- </TR>
- </TBODY>
- </TABLE>
- </FORM>
- </BODY>
- </HTML>
- check.jsp用於測試是否成功:
- <%@ page contentType="text/html; charset=gb2312" language="java" errorPage=""%>
- <%@ page import="java.sql.*" %>
- <jsp:useBean id="sqltest" class="database.sqlbean" scope="page">
- </jsp:useBean>
- <html>
- <head>
- <title>認證碼驗證頁面</title>
- <meta http-equiv="Content-Type" content="text/html; charset=gb2312">
- <META HTTP-EQUIV="Pragma" CONTENT="no-cache">
- <META HTTP-EQUIV="Cache-Control" CONTENT="no-cache">
- <META HTTP-EQUIV="Expires" CONTENT="0">
- </head>
- <body>
- <%
- String rand =(String)session.getAttribute("random");
- String input =(String)session.getAttribute("input");
- String user_name= (String)session.getAttribute("user_name");
- String pass_word= (String)session.getAttribute("pass_word");
- %>
- 系統產生的認證碼爲:
- <%= rand %><br>
- 您輸入的認證碼爲:
- <%= input %><br>
- <font color=green>驗證碼輸入相同,認證成功!</font><br>
- <br>
- 您輸入的用戶名爲:
- <%= session.getAttribute("user_name") %><br>
- 密碼爲:
- <%= session.getAttribute("pass_word") %><br>
- <%
- String permit;
- ResultSet rs=null;
- String SqlString="select * from UserInfo where username='"+user_name+"'and password='"+pass_word+"'";
- try
- {
- //設置鏈接
- sqltest.setConnection("com.microsoft.jdbc.sqlserver.SQLServerDriver",
- "jdbc:microsoft:sqlserver://localhost:1433;DatabaseName=university",
- "admin","123456");
- //設置SQL語句
- sqltest.setQuerystatement(SqlString);
- //獲得查詢結果
- rs=sqltest.getResult();
- if (rs.next())
- {
- out.print("登錄成功");
- //得到用戶的權限
- permit=rs.getString("permit");
- if (permit.equals("1"))
- {
- out.println(":你的權限是管理員組");
- }
- else
- {
- out.println(":你的權限是用戶組");
- }
- }
- else
- {
- out.print("登錄失敗,用戶名或密碼錯");
- }
- }
- catch(SQLException e1)
- {
- out.print("SQL異常!");
- }
- %>
- </body>
- </html>
- 鏈接數據庫的Javabean: sqlbean.java
- package database;
- import java.sql.*;
- public class sqlbean {
- public String query_statement;
- public ResultSet result=null;
- public Connection conn;
- public void setQuerystatement(String query_statement)
- {
- this.query_statement=query_statement;
- }
- public void setConnection(String driverName ,String jdbcURL,
- String username,String passwd) throws Exception
- {
- Connection conn1;
- Class.forName(driverName);
- conn1=DriverManager.getConnection(jdbcURL, username, passwd);
- conn1.setAutoCommit(false);
- this.conn = conn1;
- }
- public ResultSet getResult()
- {
- try
- {
- PreparedStatement select_stm=conn.prepareStatement(query_statement,
- java.sql.ResultSet.TYPE_SCROLL_INSENSITIVE,java.sql.ResultSet.CONCUR_READ_ONLY);
- result=select_stm.executeQuery();
- }
- catch(Exception e)
- {
- System.out.println(e);
- }
- return result;
- }
- }