我现在准备使用eclipse和SQL server2008数据库去建立一个登录和注册界面的功能项目。
使用工具:eclipse,SQL server 2008
打开数据库,在数据库中新建一个名为MyDataBase的数据库,然后使用SQL语句创建名为mytable的一张表
使用SQL语句如下:
create table mytable(
name varchar(20),
password varchar(20)
)
首先在Java EE中创建一个项目,我取名为requestvsresponse。在项目中创建一个名为Login.jsp的登录页面
代码如下:
<%@ page language="java" contentType="text/html; charset=utf-8"
pageEncoding="utf-8"%>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>登录页面</title>
</head>
<script type="text/javascript">
</script>
<style>
.margin{
margin:20px 300px;
}
.textrange{
width:200px;
}
</style>
<body>
<h1 class="margin">登录界面</h1>
<form name="loginfrm" action="loginserv" method="post" class="margin">
<table>
<tr>
<td>用户名:</td>
<td><input type="text" name="username" class="textrange" class="textrange"></td>
</tr>
<tr>
<td>密 码:</td>
<td><input type="password" name="password1" class="textrange"></td>
</tr>
</table>
<input name="button" type="submit" value="登录" onclick=""><br><br>
<a href="register.jsp" style="text-decoration:none">没有账户,点击注册 </a>
</form>
</body>
</html>
登录界面运行效果如下:
再创建一个注册界面,格式为jsp,命名为register.jsp
注册界面代码如下:
<%@ page language="java" contentType="text/html; charset=utf-8"
pageEncoding="utf-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>注册界面</title>
</head>
<script type="text/javascript">
function a(){
var text1=loginfrm.password1.value;
var text2=loginfrm.password2.value;
var text3=loginfrm.username.value;
if(text1=="" || text2=="" || text3==""){
alert("用户名或密码不能为空!");
return false;//false:阻止提交表单
}
if(text1!=text2 && text1!="" && text2!=""){
alert("密码不一致!");
return false;//false:阻止提交表单
}
if(text1==text2 && text1!="" && text2!="" && text3!=""){
alert("注册成功,跳转登录界面");
//window.location.href='Login.jsp';
}
}
</script>
<style>
.margin{
margin:20px 300px;
}
.textrange{
width:200px;
}
</style>
<body>
<h1 class="margin">注册界面</h1>
<form name="loginfrm" action="loginserv.do" method="post" class="margin" onsubmit="return a()">
<table>
<tr>
<td>用户名:</td>
<td><input type="text" name="username" class="textrange"></td>
</tr>
<tr>
<td>密 码:</td>
<td><input type="password" name="password1" class="textrange"></td>
<tr>
<td>新密码:</td>
<td><input type="password" name="password2" class="textrange"></td>
</tr>
</table>
<input name="button" type="submit" value="注册" >
</form>
</body>
</html>
效果如下:
此时在Login.jsp登录界面中,因为JavaScript方法,点击“没有账户,点击注册”这句话能够跳转到注册界面
然后打开SQL server2008数据库,创建一个新的数据库,命名为:MyDatabase,通过新建查询在该数据库中新建一张表,命名为mytable,sql语句如下:
create mytable
(
name char(8),
passwd char(16)
)
建立好数据库表之后,我们需要在Java EE项目中加入jdbc,因为我使用的是SQL server 2008 ,所以jdbc的版本是41。将jdbc导入到WebContent的WEB-INF的lib中。可以直接在外面将其放入该文件夹下。
之后可以创建servlet项目了,作用是对数据库建立连接,我们先进行注册界面的servlet创建。
将servlet命名为ConnectRe,格式是.java文件。注意要将@WebServlet("/lConnectRe")改为@WebServlet("/loginserv.do"),自己的数据库账户和密码也需要进行修改。
代码如下:
package com.connect;
import java.io.IOException;
import java.io.PrintWriter;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.ArrayList;
import java.util.List;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
/**
* Servlet implementation class ConnectRe
*/
@WebServlet("/loginserv.do")
public class ConnectRe extends HttpServlet {
private static final long serialVersionUID = 1L;
/**
* @see HttpServlet#HttpServlet()
*/
public ConnectRe() {
super();
// TODO Auto-generated constructor stub
}
/**
* @see HttpServlet#doGet(HttpServletRequest request, HttpServletResponse response)
*/
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
// TODO Auto-generated method stub
//设置编码
response.setCharacterEncoding("UTF-8");
//response.getWriter().append("Served at: ").append(request.getContextPath());
response.setHeader("Content-type", "text/html;charset=UTF-8");
doPost(request,response);
}
/**
* @see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse response)
*/
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
// TODO Auto-generated method stub
//设置编码
request.setCharacterEncoding("utf-8");
response.setCharacterEncoding("utf-8");
response.setHeader("Content-type", "text/html;charset=utf-8");
//获取参数
String username = request.getParameter("username");
String userpwd1 = request.getParameter("password1");
String userpwd2 = request.getParameter("password2");
try{
PrintWriter pw=response.getWriter();
//连接数据库
Class.forName("com.microsoft.sqlserver.jdbc.SQLServerDriver");
System.out.println("数据库连接");
//得到连接
Connection ct=DriverManager.getConnection("jdbc:sqlserver://localhost:1433;DataBaseName=MyDatabase","sa","自己的密码");/*第20行*/
System.out.println("连接数据库成功");
//创建Statement
Statement sm=ct.createStatement();
//得到结果集
//ResultSet rs=sm.executeQuery("select top 1 * from users");
//if(rs.next()){
// pw.println("hf");
//}
PreparedStatement ps = ct.prepareStatement("insert into mytable(name,passwd) values(?,?)"); //向数据库存入数据
ps.setString(1, username);
ps.setString(2, userpwd1);
ps.execute();
ps.close();
ct.close(); //数据库关闭
System.out.println("数据库关闭");
request.getRequestDispatcher("/Login.jsp").forward(request, response);
}catch (Exception ex){
System.out.println("连接失败");
ex.printStackTrace();
}
}
}
然后运行register.jsp,可以在注册界面中对信息进行注册,信息将传送至数据库之前创建的mytable表中。
数据库中已经有了你之前存储的数据了。
接下来就是登录界面的servlet,命名为Logincon(),同样注意要修改@WebServlet("/Logincon"),还有之后登录成功后要跳转的具体页面。
代码如下:
package com.connect;
import java.io.IOException;
import java.io.PrintWriter;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.Statement;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
/**
* Servlet implementation class Logincon
*/
@WebServlet("/loginserv")
public class Logincon extends HttpServlet {
private static final long serialVersionUID = 1L;
/**
* @see HttpServlet#HttpServlet()
*/
public Logincon() {
super();
// TODO Auto-generated constructor stub
}
/**
* @see HttpServlet#doGet(HttpServletRequest request, HttpServletResponse response)
*/
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
// TODO Auto-generated method stub
//设置编码
response.setCharacterEncoding("UTF-8");
response.setHeader("Content-type", "text/html;charset=UTF-8");
doPost(request,response);
}
/**
* @see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse response)
*/
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
// TODO Auto-generated method stub
//设置编码
request.setCharacterEncoding("utf-8");
response.setCharacterEncoding("utf-8");
response.setHeader("Content-type", "text/html;charset=utf-8");
//获取参数
String username = request.getParameter("username");
String userpwd1 = request.getParameter("password1");
try{
PrintWriter pw=response.getWriter();
//连接数据库
Class.forName("com.microsoft.sqlserver.jdbc.SQLServerDriver");
System.out.println("数据库连接");
//得到连接
Connection ct=DriverManager.getConnection("jdbc:sqlserver://localhost:1433;DataBaseName=MyDatabase","sa","数据库密码");/*第20行*/
System.out.println("连接数据库成功");
//创建Statement , 执行 SQL 查询
Statement sm=ct.createStatement();
//查询用户名的密码
String sql;
sql ="select count(*) from mytable where name='" + username + "' and passwd='"+userpwd1+"'";
// 执行查询
ResultSet rs = sm.executeQuery(sql);
if(rs.next()) {
//用户存在
System.out.println("用户存在");
int dbpass = rs.getInt(1);
//System.out.println(dbpass);
if(dbpass>0){
//用户合法
System.out.println("用户合法");
response.sendRedirect("登录成功要跳转的页面");
//request.getRequestDispatcher("/register.jsp").forward(request, response);
}else {
//用户不合法
System.out.println("用户不合法");
pw.print("<script language='javascript'>alert('用户名或密码错误');window.location.href='Login.jsp';</script>");
//response.sendRedirect("Login.jsp");
//request.getRequestDispatcher("/Login.jsp").forward(request, response);
}
}else {
System.out.println("用户不存在");
pw.print("<script language='javascript'>alert('用户名或密码错误');window.location.href='Login.jsp';</script>");
//response.sendRedirect("Login.jsp");
//request.getRequestDispatcher("/Login.jsp").forward(request, response);
}
ct.close(); //数据库关闭
System.out.println("数据库关闭");
// request.getRequestDispatcher("/Login.jsp").forward(request, response);
}catch (Exception ex){
System.out.println("连接失败");
ex.printStackTrace();
}
}
}
具体运行Login.jsp,输入刚刚注册的账户和密码,将会跳转到自己设定的页面中去。
如果登录错误将会跳出一个窗口,点击确定之后将会返回登录界面
一起学习,一起进步 -.- ,如有错误,可以发评论