⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 conn.java

📁 本系统用java+Mysql技术
💻 JAVA
字号:
package chatweb;
import java.sql.*;
import java.io.*;
import java.util.Vector;

public class conn {
  String sDBDriver = "org.gjt.mm.mysql.Driver";
  String sConnStr = "jdbc:mysql://localhost:3306/hoodb";
  String user = "root";
  String pass = "root";
  Connection connect = null;
  ResultSet rs = null;

  public conn() {
    try {
      Class.forName(sDBDriver).newInstance();
    }
    catch(Exception e) {
      System.err.println( "forName:"+e.getMessage());
    }
  }

  public ResultSet executeQuery(String sql) {//主要用于执行查询语句
    rs = null;
    try {
      connect = DriverManager.getConnection(sConnStr,user,pass);
      Statement stmt = connect.createStatement();
      rs = stmt.executeQuery(sql);
    }
    catch(SQLException ex) {
      System.err.println("EXECUTEQUERY:"+ex.getMessage());
    }
    return rs;
  }

  public boolean executeOrder(String sql) {//执行一条SQL语句,插入异常时返回FALSE
    try {
      connect = DriverManager.getConnection(sConnStr,user,pass);
      Statement stmt = connect.createStatement();
  //    stmt.executeQuery(sql);
      stmt.executeUpdate(sql);
    }
    catch(SQLException ex) {
      System.err.println("EXECUTEORDER:"+ex.getMessage());
      return false;
    }
    return true;
  }


  public int register(String regname,String password){//返回1表示注册成功,返回2表示用户名已存在,返回3表示插入异常
    String strSQL="select * from user where username='"+regname+"'";
    ResultSet rs=executeQuery(strSQL);
    try{
      if (rs.next())
        return 2;
    }
    catch(Exception e){
      System.err.println("REGISTER:"+e.getMessage());
      return 3;
    }
    String strIns="insert into  user (username,password,lasttime) Values('"+regname+"','"+password+"',now())";
    try {
      connect = DriverManager.getConnection(sConnStr,user,pass);
      Statement stmt = connect.createStatement();
    //  stmt.executeQuery(strIns);
      stmt.executeUpdate(strIns);
    }
    catch(SQLException ex) {
      System.err.println("REGISTER::"+ex.getMessage());
      return 3;
    }

    return 1;
  }

  public int login(String logname,String password){//返回用户等级表示注册成功;返回-1表示密码错误;返回-2表示用户名错误;返回-3表示数据库操作异常
    try{
      String strSQL="select * from user where username='"+logname+"'";
      ResultSet rs=executeQuery(strSQL);
      if(rs.next()){
        if (!password.equals(rs.getString("password")))
          return -1;
        else{
          executeOrder("update user set lasttime=now() where username='"+logname+"';");
          return rs.getInt("grade");
        }
      }
        else
                return -2;

    }
    catch(Exception e){
      System.err.println("LOGIN:"+e.getMessage());
      return -3;
    }
  }

//Option for message
  public int checkNewMsg(String name){//检查新短信息,返回新短信息的数量
    int newMsgCount=0;
    try{
      String strSQL="select * from message where `to`='"+name+"' and isnew=1";
      ResultSet rs=executeQuery(strSQL);
      while(rs.next()){
        newMsgCount+=1;
      }
    }
    catch(Exception e){
      }
    return newMsgCount;
  }

  public Vector getMsg(String name){//获取短信息
    String strSQL="select * from message where `to`='"+name+"' order by id";
    ResultSet rs=null;
    Vector msgs=new Vector();
    try{
      rs = executeQuery(strSQL);
      while (rs.next()) {
        msg ms=new msg();
        ms.setId(rs.getInt("id"));
        ms.setFromUser(rs.getString("from"));
        ms.setToUser(rs.getString("to"));
        ms.setTitle(rs.getString("title"));
        ms.setContent(rs.getString("content"));
        ms.setIsnew(rs.getBoolean("isnew"));
        ms.setSendTime(rs.getTime("sendtime"));
        ms.setSendDate(rs.getDate("sendtime"));
        msgs.addElement(ms);
      }
    }
    catch(Exception e){

    }
    String strMod="update message set isnew=0 where `to`='"+name+"'";
    executeOrder(strMod);
    return msgs;
  }

  public boolean addMsg(String strFrom,String strTo,String strContent,String strTitle){//添加短信息
    String strCheck="select * from user where username='"+strTo+"'";
    ResultSet rs=executeQuery(strCheck);
    try{
      if(!rs.next())
        return false;
    }
    catch(Exception e){
    }
    String strSQL="INSERT INTO message (`from`, `to`, content, title, sendtime) VALUES ('"+strFrom+"', '"+strTo+"', '"+strContent+"', '"+strTitle+"', now())";
    return executeOrder(strSQL);
  }

  public boolean deleteMsg(int id,String toUser){//删除短信息
    String StrCheck="select * from message where id="+id;
    ResultSet rs=executeQuery(StrCheck);
    try{
      if(rs.next()){
        if(!toUser.equals(rs.getString("to")))
          return false;
      }
    }
    catch(Exception e){
      return false;
    }
    String strSQL="delete from message where id="+id;
    return executeOrder(strSQL);
  }

  public boolean modify(String username,String oldPassword,String newPassword){//修改密码
    String strSQL="update user set password='"+newPassword+"' where username='"+username+"' and password='"+oldPassword+"' and not grade=1";//不允许修改管理员密码
    try {
      connect = DriverManager.getConnection(sConnStr,user,pass);
      Statement stmt = connect.createStatement();
      int updateCount=stmt.executeUpdate(strSQL);
      if(updateCount>0)
        return true;
    }
    catch(SQLException ex) {
      System.err.println("EXECUTEORDER:"+ex.getMessage());
    }
    return false;
  }
}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -