实现服务器与数据库的连接

如何实现服务器与数据库的连接
第一步:先建立数据库,通过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 {
  
 }

}

 


 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值