配置tomcat详见上篇文章
导入jar包
导入mysql-connector-java包
新建工程并勾选web application
在src文件夹下新建一个entity文件夹 里面新建一个User.java
``
public class User {
private int id;
private String username;
private String password;
public String toString() {
return “User{” +
“id=” + id +
“, username=’” + username + ‘’’ +
“, password=’” + password + ‘’’ +
‘}’;
}
public int getId() {
return id;
}
public void setId(int id) { this.id = id; } public String getUsername() { return username; } public void setUsername(String username) { this.username = username; } public String getPassword() { return password; } public void setPassword(String password) { this.password = password; }
}
新建一个NewsSystem.java
import java.util.ArrayList;
import java.util.List
public class NewsSystem {
static {
ns=new NewsSystem();
}
private static NewsSystem ns;
private NewsSystem(){}
public static NewsSystem getInstance(){
return ns;
}
public List users=new ArrayList<>();
public static int id_num;
public void addUser(String username,String password,String cfmPwd){
if (password.equals(cfmPwd)){
User u=new User();
u.setId(++id_num);
u.setUsername(username);
u.setPassword(password);
users.add(u);
}else{
System.out.println(“密码不一致”);
}
System.out.println(“目前有”+users.size()+“用户”);
System.out.println(users);
}
}
用户名:
请输入密码:
请确认密码:
`` `` 新建dao文件夹,在其目录下新建baseDao.java和UserDao.java `` package m.jdbc; import java.sql.*; public class baseDao { private Connection conn; //通过connection对象来建立与数据库的连接 private final String DRIVER="com.mysql.jdbc.Driver"; private final String URL="jdbc:mysql://192.168.44.100/kb15"; //mysql的url就是 jdbc:mysql://hostname:port/database private final String USERNAME="root"; private final String PASSWORD="ok"; private Statement stmt; //创建一个statement对象数据库操作对象 public ResultSet rs; public void getConnection(){ try { Class.forName(DRIVER); conn=DriverManager.getConnection(URL,USERNAME,PASSWORD); } catch (SQLException | ClassNotFoundException e) { e.printStackTrace(); } } //增删改 zengshangai public void execute(String sql){ try { stmt=conn.createStatement(); //数据库 Connection.createStatement () 方法用于创建一个 Statement 对象, //封装 SQL 语句发送给数据库,通常用来执行不带参数的 SQL 语句。 boolean b = stmt.execute(sql); //excute()方法返回值:增删改操作成功,返回false;查询操作成功,返回true; System.out.println(b ? "执行失败" : "执行成功"); } catch (SQLException e) { e.printStackTrace(); } } public void update(String sql){ try { stmt=conn.createStatement(); int i = stmt.executeUpdate(sql); //i为执行sql语句后 影响的行数 System.out.println(i>0 ? "成功" : "不成功"); } catch (SQLException e) { e.printStackTrace(); } } //cha public void query(String sql){ try { stmt=conn.createStatement(); rs=stmt.executeQuery(sql); //用于产生单个结果集(ResultSet)的语句 //这个方法常被用来执行 SELECT 语句,执行后返回代表查询结果的ResultSet对象。 } catch (SQLException e) { e.printStackTrace(); } } public void close(){ try { if (stmt!=null){ stmt.close(); } if (conn!=null){ conn.close(); } } catch (SQLException e) { e.printStackTrace(); } } } `` `` import m.jdbc.impl.util.Prop; import java.sql.*; public class UserDao { private Connection conn; //通过connection对象来建立与数据库的连接 private PreparedStatement pst; //创建数据库操作对象 public void getConn()throws Exception{ Class.forName(Prop.getProperty("driver")); //加载驱动 conn= DriverManager.getConnection( Prop.getProperty("url"), Prop.getProperty("name"), Prop.getProperty("pwd")); } public void execute(String sql,Object...params) throws SQLException { pst=conn.prepareStatement(sql); if (params!=null){ for (int i = 0; i<%@ page contentType=“text/html;charset=UTF-8” language=“java” %>
用户名:
密码:
<%Object user=session.getAttribute("user"); %><%@ page import=“m.jdbc.baseDao” %>
<%@ page import=“java.sql.ResultSet” %>
<%@ page import=“com.mysql.jdbc.StringUtils” %>
<%@ page import=“m.jdbc.impl.LoginServiceImpl” %>
<%@ page contentType=“text/html;charset=UTF-8” language=“java” %>
import m.User;
public interface LoginDao {
//1、用姓名密码查询整条记录(主要)
User queryUserByNameAndPwd(String username,String password) throws Exception;
//2、用姓名查密码
String queryPasswordByName(String username);
}
//LoginDaoImpl.java
package m.jdbc.impl;
import m.User;
public interface LoginService {
//业务层主要决定业务逻辑对代码的影响
User login (String username, String password);
}
//LoginService.java
package m.jdbc.impl;
import m.User;
public interface LoginService {
//业务层主要决定业务逻辑对代码的影响
User login (String username, String password);
}
//LoginServiceImpl.java
package m.jdbc.impl;
import com.mysql.jdbc.StringUtils;
import m.User;
import m.jdbc.LoginDao;
public class LoginServiceImpl implements LoginService {
@Override
public User login(String username, String password) {
//1、参数判空
if (StringUtils.isNullOrEmpty(username)||
StringUtils.isNullOrEmpty(password)){
return null;
}
//2、是否符合规则
//3、有哪些特殊要求
//4、接受返回值,判断返回值的范围是否正确
LoginDao dao=new LoginDaoImpl();
User user=null;
try {
user =dao.queryUserByNameAndPwd(username,password);
} catch (Exception e) {
e.printStackTrace();
}
return user;
}
public static String jdbcTest(String username,String password){
LoginService service=new LoginServiceImpl();
User user = service.login(username, password);
System.out.println(user.getUsername());
System.out.println("用户查询成功! "+username+“存在”);
return user.getUsername();
}
public static void main(String[] args) {
LoginService service=new LoginServiceImpl();
User user = service.login(“ssr”, “1”);
System.out.println(user.getUsername());
}
}
//Prop.java文件
package m.jdbc.impl.util;
import java.io.IOException;
import java.util.Properties;
public class Prop {
public static String getProperty(String name){
Properties p=new Properties();
try { p.load(Prop.class.getClassLoader().getResourceAsStream(“db.properties”));
} catch (IOException e) {
e.printStackTrace();
}
return p.getProperty(name);
}
}
//Type.java文件
package m.jdbc.impl.util;
public class Type {
T t;
public String getType(T t){
return t.getClass().getTypeName();
}
}
``
设置如下 Host为你的虚拟机的服务器地址 输入用户与密码
新建一个resources文件夹并将其设为resources root
在其中新建db.properties文件
driver=com.mysql.jdbc.Driver url=jdbc:mysql://192.168.44.100:3306/kb15 name=root pwd=ok
最后点击tomcat运行即可。