不用评论留邮箱了,不想发了。累


运行环境:Eclipse tomcat8.5、数据库SQL SERVER


运行截图如下


## 登录页

java对接企业微信通讯录接口 java web通讯录_css

通讯录首页

java对接企业微信通讯录接口 java web通讯录_css_02

添加一名联系人页面

java对接企业微信通讯录接口 java web通讯录_sql_03

通讯录更改联系人信息页面

java对接企业微信通讯录接口 java web通讯录_java_04

通讯录查询页面

java对接企业微信通讯录接口 java web通讯录_java对接企业微信通讯录接口_05

项目结构图

java对接企业微信通讯录接口 java web通讯录_sql_06



获取 数据库连接类:

package bean;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;

public class DbConnect {
    public static Connection connection;
    public static String url = "jdbc:sqlserver://localhost:1433; DatabaseName=addressList";
    private static String username = "sa";
	private static String password ="";
    public static Connection getConnection() {
        try {
            Class.forName("com.microsoft.sqlserver.jdbc.SQLServerDriver");
            connection = DriverManager.getConnection(url,username, password);
        } catch (ClassNotFoundException e) {
            e.printStackTrace();
        } catch (SQLException e) {
            e.printStackTrace();
        }catch (Exception e) {
        	System.out.println("数据库连接失败");
        	e.printStackTrace();
		}
        return connection;
    }
}

通讯录实体类:

package bean;
import java.io.Serializable;
public class Address implements Serializable{
	private int id;
	private String name;
	private String phone1;
	private String phone2;
	public Address() {
	}
	public Address(int id,String name,String phone1,String phone2) {
		super();
		this.id=id;
		this.name=name;
		this.phone1=phone1;
		this.phone2=phone2;
	}
	public int getId() {
		return id;
	}
	public void setId(int id) {
		this.id = id;
	}
	public String getName() {
		return name;
	}
	public void setName(String name) {
		this.name = name;
	}
	public String getPhone1() {
		return phone1;
	}
	public void setPhone1(String phone1) {
		this.phone1 = phone1;
	}
	public String getPhone2() {
		return phone2;
	}
	public void setPhone2(String phone2) {
		this.phone2 = phone2;
	}
	@Override
	public String toString() {
		return "Address [id=" + id + ", name=" + name + ", phone1=" + phone1 + ", phone2=" + phone2 + "]";
	}
}

登录JSP页面:

<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>通讯录</title>
<link rel="stylesheet" href="./css/bootstrap.min.css">
<link href="css/mystyle.css" rel="stylesheet" type="text/css" />
<style type="text/css">
.container {
	color: white;
}
#footer {
	position: fixed;
	bottom: 0;
	text-align: center;
	margin-left: -50px; /*div宽度的一半*/
	left: 39%;
}
</style>
</head>
<body>
<div id="container">
		<div class="container">
			<h1 class="display-4">通讯录</h1>
			<p class="lead">AddressList Book</p>
		</div>
	<br>
	<br>
	<div id="login-container">
		<div align="center">
		<form action="/addressList/loginServer" method="post">
			<br><br>
		 	<img class="mb-4" src="images/b.jpg" alt="这是一个图标" width="72" height="72">
 			 <h1 class="h3 mb-3 font-weight-normal">Please sign in</h1>
			<table>
				<tr>
					<td>
						<div class="input-group mb-3">
							<div class="input-group-preend">
								<span class="input-group-text" id="inputGroup-sizing-default">账号</span>
							</div>
								<input name="user" type="text" required autofocus class="form-control" aria-label="Sizing example input" aria-describedby="inputGroup-sizing-default">
						</div>
					</td>
				</tr>
				<tr>
					<td>
						<div class="input-group mb-3">
							<div class="input-group-prepend">
								<span class="input-group-text" id="inputGroup-sizing-default">密码</span>
							</div>
							<input name="pwd" id="pwd" required type="password" class="form-control" aria-label="Sizing example input" aria-describedby="inputGroup-sizing-default"> 
							<div class="input-group-append">
								<button class="btn btn-outline-secondary" type="submit" id="button-addon2">登录</button>
							</div>
						</div>
					</td>
				</tr>
			</table>
		</form>
		</div>
	</div>
	<div id="footer" align="center">
		<footer class="text-muted">
			<div class="container">
				<p style="color: white;">Copyright © 2019 gxu author:Wanmao Yi, All Rights Reserved</p>
			</div>
		</footer>
	</div>
</div>

</body>
</html>

登录servlet:(查询所有学生信息显示到主页面jsp): 默认登录帐号是a,密码是1,登录帐号没有使用到数据库。

package servlet;
import java.io.IOException;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
import java.util.ArrayList;
import java.util.List;
import bean.Address;
import bean.DbConnect;

/**
 * Servlet implementation class loginServer
 */
@WebServlet("/loginServer")
public class loginServer extends HttpServlet {
	private static final long serialVersionUID = 1L;
       
    /**
     * @see HttpServlet#HttpServlet()
     */
    public loginServer() {
        super();
        // TODO Auto-generated constructor stub
    }

	protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
		response.setContentType("text/html");
		request.setCharacterEncoding("utf-8");
		response.setCharacterEncoding("utf-8");
		String user = request.getParameter("user");
		String pwd = request.getParameter("pwd");
		if (user.equals("a") && pwd.equals("1")) {
			Connection connection = DbConnect.getConnection();
			String sql = "select * from addressbook";
			PreparedStatement preparedStatement = null;
			ResultSet resultSet = null;
			List addressbook = null;
			try {
				preparedStatement = connection.prepareStatement(sql);
                resultSet = preparedStatement.executeQuery();
                if (resultSet!=null) {
                	addressbook = new ArrayList();
    				try {
    					while (resultSet.next()) {
    						Address address = new Address();
    						address.setId(resultSet.getInt(1));
    						address.setName(resultSet.getString(2));
    						address.setPhone1(resultSet.getString(3));
    						address.setPhone2(resultSet.getString(4));
    						addressbook.add(address);
    					}
    				} catch (Exception e) {
    					System.out.println("封装数据集失败");
    					e.printStackTrace();
    				}
				}
                HttpSession httpSession = request.getSession();
              httpSession.setMaxInactiveInterval(7200);
              httpSession.setAttribute("addressbook", addressbook);
              response.sendRedirect("addresslist.jsp");
			}catch (SQLException e) {
				System.out.println("1");
				e.printStackTrace();
			}catch (Exception e) {
				// TODO: handle exception
				System.out.println("2");
				e.printStackTrace();
			}	
		}else {
			response.sendRedirect("login.jsp");
		}
	}
	protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
		doGet(request, response);
	}
}

mvc模式:JSP + Servlet + JavaBean三层架构
MVC模式(Model-View-Controller),是系统分为三个基本部分:模型(Model)、视图(View)和控制器(Controller):
可以理解为:JSP充当视图,Servlet充当控制器,JavaBeans充当模型。

1.View层(JSP),前台交互,比如我们注册时的数据等等,serlvet就是与前台数据进行交互的
2.Contrller层(servlet充当):Model与View之间沟通的桥梁, 这个层有业务处理,用户的注册登录就可以看做是User的业务,我们就需要将相关的处理代码写到这个层中。
3.Model层:实现系统的业务逻辑,即javaBean,常见的就是封装对象的属性、数据库连接操作等。
常规会写一个dao层,是属于mvc里面Model层抽出来。目的就是更单纯的和数据库打交道,将servlet的数据和数据库进行交互。

特点:JSP作为视图,来表现页面;Servlet作为控制器,控制程序的流程并调用业务进行处理;JavaBean封装了业务逻辑。遵循了MVC设计模式
缺点:没有统一的开发框架导致开发周期长