如何实现服务器与数据库的连接
第一步:先建立数据库,通过apache将数据库据发布到服务器上
1.配置数据库 安装Apache2.2
2.在计算机管理 ---》服务---》启动myApache2.2
3.在网页上查看数据库 输入数据库的端口http://localhost:8011---》输入用户名root 密码123456进入数据库查看在网页上
4.把一个项目的数据库倒进来 将一个现成的数据库文件复制到安装Apache2.2的路径下,我的是c:\AppServ\MYsQL\data\下
第二步:创建一个服务器项目,通过tomcat服务器发布。
1.先打开myEcplipse安装tomcat window---Preferences--MyEclipse--Servers---Tomcat 6.0--tomcat文件包路径e盘software\tomcat下.----点击ok
2.在MyEclipse下新建一个web项目 file--newproject--WebProject 启动tomcat 在上面有个服务器图标那启动。
3.在MyEclipse上发布web项目
第四步:建一个用户封装类,用户封装用户的信息。例如User类
第五步:在SqlWeb这个服务器端,建五个包,如dao数据库接口包,Impl实现接口的包,这个包主要是实现对数据库的基本操作。
封装类包entity util启动数据库包,包括配置数据库的一些参数。 还有web页面包
1. 写一个接口,实现操作数据的所有方法
public interface IUserDao {
public User Login(String username,String pwd);
public int addUser(User user);
public int UpdateUser(User user);
public int deletUser(int id);
public ArrayList<User> QueryUserall();
public User QueryUser(int id);
}
2.实现接口类,这个单写在一个包里,这个类实现了接口里的所有方法。包括登录,增删改查数据库的所有方法。
public class UserDaoImpl implements IUserDao {
private Connection conn = null;
DBUtil db ;
public UserDaoImpl(){
db = new DBUtil();//连接数据库
conn = db.getConnection();// 获取连接对象
}
public User Login(String username, String pwd) {
//通过客户端传进来的username pwd查询数据库
String sql = "select * from adduser where username = ? and password = ?";
//定义预定义语句对象 state;
PreparedStatement state;
try {
//获得state对象,检索sql语句
state = conn.prepareStatement(sql);
// 通过state 检索sql语句中的问号,给问号赋值。例如,上面的语句中,有两个问号,第一个问号赋值为username,第二个问号为password
state.setString(1, username);
state.setString(2, pwd);
//执行查询方法,返回ResultSet对象r
ResultSet r = state.executeQuery();
if(r.next()){
//通过对象r.get方法获得此用户的所有数据信息,并封装数据到实体类中。返回这个实体类对象user
User user = new User();
user.setId(r.getInt("id"));
user.setName(r.getString("name"));
user.setUsername(r.getString("username"));
user.setPwd(r.getString("password"));
user.setAge(r.getInt("age"));
user.setSex(r.getString("sex"));
return user;
}
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}finally{
db.closeConn(conn);
}
return null;//如果登录成功返回这个对象,如果查询不成功,返回空值,提示登录 不成功。
}
//通过一个 id查询用户的详细信息
public User QueryUser(int id) {
String sql = "select * from adduser where id = ?";
//获得预定义语句
PreparedStatement state;
try {
state = conn.prepareStatement(sql);
state.setInt(1, id);
ResultSet r = state.executeQuery();
if(r.next()){
User user = new User();
user.setId(r.getInt("id"));
user.setName(r.getString("name"));
user.setUsername(r.getString("username"));
user.setPwd(r.getString("password"));
user.setAge(r.getInt("age"));
user.setSex(r.getString("sex"));
return user;
}
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}finally{
db.closeConn(conn);
}
return null;
}
//查询所有的用户信息
public ArrayList<User> QueryUserall() {
String sql = "select * from adduser";
//获得预定义语句
PreparedStatement state;
ArrayList<User> list = new ArrayList<User>();
try {
state = conn.prepareStatement(sql);
ResultSet r = state.executeQuery();
while(r.next()){
User user = new User();
user.setId(r.getInt("id"));
user.setName(r.getString("name"));
user.setUsername(r.getString("username"));
user.setPwd(r.getString("password"));
user.setAge(r.getInt("age"));
user.setSex(r.getString("sex"));
list.add(user);
}
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}finally{
db.closeConn(conn);
}
return list;
}
// 更新用户数据,传一个对象,更新成功返回1,失败返回0;
public int UpdateUser(User user) {
String sql = "update adduser set name = ?,username = ?,password = ?,sex = ?,age = ? where id = ?";
//获得预定义语句
PreparedStatement state;
int r = 0;
try {
//获得一个操作数据库的对象state,通过state检索上述sql语句的?号,通过setString方法给? 赋值。
state = conn.prepareStatement(sql);
state.setString(1, user.getName());
state.setString(2, user.getUsername());
state.setString(3, user.getPwd());
state.setString(4, user.getSex());
state.setInt(5, user.getAge());
state.setInt(6, user.getId());
r = state.executeUpdate();//执行更新方法,更新成功返回整数,失败返回0。
} catch (SQLException e) {
e.printStackTrace();
}finally{
db.closeConn(conn);
}
return r;
}
public int addUser(User user) {
String sql = "insert into adduser(name,username,password,sex,age) values(?,?,?,?,?)";
//获得预定义语句
PreparedStatement state;
boolean r = false;
try {
state = conn.prepareStatement(sql);
state.setString(1, user.getName());
state.setString(2, user.getUsername());
state.setString(3, user.getPwd());
state.setString(4, user.getSex());
state.setInt(5, user.getAge());
r = state.execute(sql);
} catch (SQLException e) {
e.printStackTrace();
}finally{
db.closeConn(conn);
}
return r?1:0;
}
public int deletUser(int id) {
String sql = "delete from adduser where id = ?";
PreparedStatement state ;
boolean b = false;
try {
state = conn.prepareStatement(sql);
state.setInt(1, id);
b = state.execute();
} catch (Exception e) {
}
return b?1:0;
}
}
第六步:服务器接收客户端数据的方法。
public class AddUserServlet extends HttpServlet {
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
//转换服务器端和客户端的字符编码
request.setCharacterEncoding("utf-8");
response.setCharacterEncoding("utf-8");
response.setContentType("text/html");
//从服务器请求中获得字符输出流
PrintWriter out = response.getWriter();
//得到客户端的参数
String id = request.getParameter("id");
//获得dao的操作对象 并实现查询单个用户的功能
IUserDao userdao = new UserDaoImpl();
User user = userdao.QueryUser(Integer.valueOf(id));
//对返回的user结果进行判断 并发送给客户端
if(user != null){
out.println("姓名:"+user.getName());
out.println("年龄:"+user.getAge());
}else{
out.println("查询不到结果");
}
out.flush();
out.close();
}
// 客户端登录方法---服务端接收用户名和密码后---
public class LoginServlet extends HttpServlet {
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
request.setCharacterEncoding("utf-8");
response.setCharacterEncoding("utf-8");
response.setContentType("text/html");
//获得用户名和密码
String name = request.getParameter("name");
String pwd = request.getParameter("pwd");
System.out.println(name +" 1 "+pwd);
//实例化接口实现类
IUserDao userdao = new UserDaoImpl();
//调用登录方法,登录 成功会返回一个对象,传用户名和密码
User user = userdao.Login(name, pwd);
//获得向客户端的打印流,如查返回一个对象,说明登录成功
PrintWriter out = response.getWriter();
if(user != null){
out.println("登录成功");
}else{
out.println("登录失败");
}
out.flush();
out.close();
}
public void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
}
public void init() throws ServletException {
}
}