struts2的增删改查

刚毕业不久,现在公司用的是spring mvc框架,导致很长时间没有写strust2了,现在都有些忘记了,所以要常复习哦!花了大半天的时候用struts2字了增删改功能

第一步:导jar包

 

第二步,因为struts2也是mvc模式,所以也要在web.xml里配置内,需要配置的内容如下:

 

 

<?xml version="1.0" encoding="UTF-8"?>
<web-app version="2.5"
 xmlns="http://java.sun.com/xml/ns/javaee"
 xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
 xsi:schemaLocation="http://java.sun.com/xml/ns/javaee
 http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd">
  <filter>
   <!-- 过滤器的名字 -->
        <filter-name>struts2</filter-name>
        <!-- 过滤器支持的struts2类 -->
        <filter-class>org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter</filter-class>
    </filter>

    <filter-mapping>
     <!-- 过滤器的名字 -->
        <filter-name>struts2</filter-name>
        <!-- 过滤器拦截文件路径的名字 -->
        <url-pattern>/*</url-pattern>
    </filter-mapping>
  <welcome-file-list>
    <welcome-file>index.jsp</welcome-file>
  </welcome-file-list>
</web-app>

第三步;

建vo 数据库中对应的字段,get set方法 并且在src目录下建一个struts.xml并且配置如下内容:

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE struts PUBLIC
    "-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"
    "http://struts.apache.org/dtds/struts-2.0.dtd">

<struts>


  <package name="default" namespace="/" extends="struts-default">
   <action name="user" class="com.test.Action.UserAction">
    <result name="list" type="redirect">user!findAll</result>
    <result name="success">/list.jsp</result>
    <result name="preUpdate">/update.jsp</result>
   </action>
    </package>
</struts>

 

 

 

第四步:写dao,所有的方法都没有作封装,为了复习以前的知识哦

 

package com.test.Dao;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.List;

import com.test.vo.User;

public class UserDao {

 /**
  * 添加
  * @param user
  */
 public void add(User user){
  Connection conn = null;
  PreparedStatement ps =null;
  try {
   Class.forName("com.mysql.jdbc.Driver");
   conn = DriverManager.getConnection("jdbc:mysql://localhost/test", "root", "root");
   String sql = "insert into user values(null,?,?,?,?,?,?)";
   ps = conn.prepareStatement(sql);
   ps.setString(1, user.getName());
   ps.setString(2, user.getPassword());
   ps.setInt(3, user.getAge());
   ps.setString(4, user.getPhone());
   ps.setString(5, user.getEmail());
   ps.setString(6, user.getQq());
   System.out.println(ps.executeUpdate()+"已保存");
  } catch (ClassNotFoundException e) {
   // TODO Auto-generated catch block
   e.printStackTrace();
  } catch (SQLException e) {
   // TODO Auto-generated catch block
   e.printStackTrace();
  }finally{
   
    
    try {
      if(ps!=null){
      ps.close();
      }
      if(conn!=null){
       conn.close();
       }
     } catch (SQLException e) {
     // TODO Auto-generated catch block
     e.printStackTrace();
    
   }
   
   
  }
  
 }
 
 public List<User> findAll(){
  Connection conn = null;
  PreparedStatement ps =null;
  ResultSet rs =null;
  List<User> list = new ArrayList<User>();
  try {
   Class.forName("com.mysql.jdbc.Driver");
   conn = DriverManager.getConnection("jdbc:mysql://localhost/test", "root", "root");
   String sql="select * from user";
   ps = conn.prepareStatement(sql);
   rs = ps.executeQuery();
   
   while(rs.next()){
    User u = new User();
    u.setId(rs.getInt("id"));
    u.setName(rs.getString("name"));
    u.setPassword(rs.getString("password"));
    u.setAge(rs.getInt("age"));
    u.setPhone(rs.getString("phone"));
    u.setEmail(rs.getString("email"));
    u.setQq(rs.getString("qq"));
    list.add(u);
    
   }
  }catch(Exception e){
   
   e.printStackTrace();
  }finally{
   
   
   try {
    if(rs!=null){
     rs.close();
     }
    if(ps!=null){
    ps.close();
    }
    if(conn!=null){
     conn.close();
     }
   } catch (SQLException e) {
   // TODO Auto-generated catch block
   e.printStackTrace();
  
 }
  }
  
  return list;
 }
 
 /**
  * 删除
  * @param id
  */
 
 
 public void del(int id){
  Connection conn = null;
  PreparedStatement ps = null;
  try {
   Class.forName("com.mysql.jdbc.Driver");
   conn = DriverManager.getConnection("jdbc:mysql://localhost/test", "root", "root");
   String sql = "delete from user where id=?";
   ps = conn.prepareStatement(sql);
   ps.setInt(1, id);
   System.out.println(ps.executeUpdate()+"条数据删除");
   
  } catch (ClassNotFoundException e) {
   // TODO Auto-generated catch block
   e.printStackTrace();
  } catch (SQLException e) {
   // TODO Auto-generated catch block
   e.printStackTrace();
  }finally{
   try {
    if(ps!=null){
    ps.close();
    }
    if(conn!=null){
     conn.close();
     }
   } catch (SQLException e) {
   // TODO Auto-generated catch block
   e.printStackTrace();
  
 }
  }
  
  
 }
 
 /**
  * 预查询
  * @param id
  * @return
  */
 public User perUpdate(int id){
  Connection conn = null;
  PreparedStatement ps = null;
  ResultSet rs = null;
  User u =null;
  try {
   Class.forName("com.mysql.jdbc.Driver");
   conn = DriverManager.getConnection("jdbc:mysql://localhost/test", "root", "root");
   String sql="select * from user where id=?";
   ps = conn.prepareStatement(sql);
   ps.setInt(1, id);
   rs = ps.executeQuery();
   while(rs.next()){
    u =new User();
    u.setId(rs.getInt("id"));
    u.setName(rs.getString("name"));
    u.setPassword(rs.getString("password"));
    u.setAge(rs.getInt("age"));
    u.setPhone(rs.getString("phone"));
    u.setEmail(rs.getString("email"));
    u.setQq(rs.getString("qq"));
   }
  
  } catch (ClassNotFoundException e) {
   // TODO Auto-generated catch block
   e.printStackTrace();
  } catch (SQLException e) {
   // TODO Auto-generated catch block
   e.printStackTrace();
  }
  
  return u;
 }
 
 /**
  * 修改
  * @param id
  */
 public void update(User user){
  Connection conn = null;
  PreparedStatement ps = null;
  try {
   Class.forName("com.mysql.jdbc.Driver");
   conn = DriverManager.getConnection("jdbc:mysql://localhost/test", "root", "root");
   String sql="update user set name=?,password=?,age=?,phone=?,email=?,qq=? where id=?";
   ps = conn.prepareStatement(sql);
   ps.setString(1, user.getName());
   ps.setString(2, user.getPassword());
   ps.setInt(3,user.getAge());
   ps.setString(4, user.getPhone());
   ps.setString(5, user.getEmail());
   ps.setString(6, user.getQq());
   ps.setInt(7, user.getId());
   System.out.println(ps.executeUpdate()+"条数据修改");
  } catch (ClassNotFoundException e) {
   // TODO Auto-generated catch block
   e.printStackTrace();
  } catch (SQLException e) {
   // TODO Auto-generated catch block
   e.printStackTrace();
  }
  
  
  
 }
 
 
 
}

 

第五步:写action   记住action里面的属性一定要有get方法

 

 

 

package com.test.Action;

import java.util.List;

import com.test.Dao.UserDao;
import com.test.vo.User;

public class UserAction {

 private UserDao us = new UserDao();
 private User user;
 private List<User> list;
 private int id;
 
 /**
  * ����û�
  * @return
  */
 public String add(){
  us.add(user);
  return "list";
  
 }
 
 /**
  * 查录所有记录
  * @return
  */
 public String findAll(){
  
  list = us.findAll();
  return "success";
 }
 
 /**
  * 删除
  * @return
  */
 public String del(){
  us.del(id);
  return "list";
  
 }
 
 /**
  * 预修改
  * @return
  */
 
 public String perUpdate(){
  user = us.perUpdate(id);
  return "preUpdate";
 }
 /**
  * 修改
  * @return
  */
 public String update(){
  us.update(user);
  return "list";
  
 }

 
 public UserDao getUs() {
  return us;
 }

 public void setUs(UserDao us) {
  this.us = us;
 }

 public User getUser() {
  return user;
 }

 public void setUser(User user) {
  this.user = user;
 }

 public List<User> getList() {
  return list;
 }

 public void setList(List<User> list) {
  this.list = list;
 }

 public int getId() {
  return id;
 }

 public void setId(int id) {
  this.id = id;
 }
 
 
}

 

第六步;写.jsp页面

 

 

添加页面:

 

 <form action="user!add" method="post">
   用户名:<input type="text" name="user.name" /><br />
  密码:<input tpye="text" name="user.password" /><br />
  年龄:<input type="text" name="user.age" /><br />
  电话:<input type="text" name="user.phone" /><br />
  Email:<input type="text" name="user.email" /><br />
  QQ:<input type="text" name="user.qq" /><br />
  <input type="submit" value="提交" />
  </form>

 

展示页面:

<table border="1">
   <tr>
    <td>姓名</td>
    <td>年龄</td>
    <td>电话s</td>
    <td>Email</td>
    <td>QQ</td>
    <td>详情</td>
   </tr>
    <s:iterator value="list" var="temp">
     <tr>
     <td><s:property value="#temp.name" /></td>
    <td><s:property value="#temp.age" /></td>
    <td><s:property value="#temp.phone" /></td>
    <td><s:property value="#temp.email" /></td>
    <td><s:property value="#temp.qq" /></td>
    <td><a href="user!del?id=<s:property value="#temp.id" />">删除</a><a href="user!perUpdate?id=<s:property value='#temp.id' />">修改</a></td>
     </tr>
    </s:iterator>
   
  </table>

 

 

修改页面:

 

  <form action="user!update" method="post">
  <input type="hidden" name="user.id" value="${user.id }" />
   用户名:<input type="text" name="user.name" value="${user.name }" /><br />
  密码:<input tpye="text" name="user.password" value="${user.password }" /><br />
  年龄:<input type="text" name="user.age" value="${user.age }" /><br />
  电话:<input type="text" name="user.phone" value="${user.phone }" /><br />
  Email:<input type="text" name="user.email" value="${user.email }"/><br />
  QQ:<input type="text" name="user.qq" value="${user.qq }" /><br />
  <input type="submit" value="提交" />
  </form>

 

1.2         运行机制
1)客户端在浏览器中输入一个url地址。
2)这个url请求通过http协议发送给tomcat。
3)tomcat根据url找到对应项目里面的web.xml文件。
4)在web.xml里面会发现有struts2的配置。
5)然后会找到struts2对应的struts.xml配置文件。
6)根据url解析struts.xml配置文件就会找到对应的class。
7)调用完class返回一个字String,根据struts.xml返回到对应的jsp。

 

 

 

 

 

 

想要学习的可以关注我一下哦,我一般写的比较仔细。因为我是一个菜鸟,希望大家多提意见,代码有什么可以优化的地方,希望多提意见~~~~

 

 

 

 

  • 4
    点赞
  • 24
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Struts2 是一个基于 MVC 设计模式的 Web 应用程序框架,可以用于快速开发 Java Web 应用程序,而 MySQL 是一个流行的关系型数据库管理系统,可以存储和管理数据。下面是一个简单的 Struts2 增删改查项目,使用 MySQL 作为后端数据库: 1. 创建数据库 首先需要创建一个名为 "struts2_crud" 的数据库,然后创建一个名为 "users" 的,包含以下字段: id INT(11) PRIMARY KEY AUTO_INCREMENT name VARCHAR(50) email VARCHAR(50) password VARCHAR(50) 2. 配置 Struts2 在项目中的 "WEB-INF" 文件夹下创建一个名为 "struts.xml" 的文件,添加以下内容: ``` <?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE struts PUBLIC "-//Apache Software Foundation//DTD Struts Configuration 2.3//EN" "http://struts.apache.org/dtds/struts-2.3.dtd"> <struts> <constant name="struts.devMode" value="true" /> <package name="default" extends="struts-default"> <action name="list" class="com.example.struts2crud.action.ListAction"> <result name="success">/list.jsp</result> </action> <action name="add" class="com.example.struts2crud.action.AddAction"> <result name="input">/add.jsp</result> <result name="success" type="redirectAction">list</result> </action> <action name="edit" class="com.example.struts2crud.action.EditAction"> <result name="input">/edit.jsp</result> <result name="success" type="redirectAction">list</result> </action> <action name="delete" class="com.example.struts2crud.action.DeleteAction" method="execute"> <result name="success" type="redirectAction">list</result> </action> </package> </struts> ``` 此配置文件定义了四个 action,分别是 "list"、"add"、"edit" 和 "delete"。 3. 创建 Java 类 创建以下四个 Java 类,分别对应上述四个 action: ListAction.java: ``` package com.example.struts2crud.action; import java.util.List; import com.example.struts2crud.dao.UserDAO; import com.example.struts2crud.model.User; import com.opensymphony.xwork2.ActionSupport; public class ListAction extends ActionSupport { private static final long serialVersionUID = 1L; private List<User> userList; public String execute() { try { userList = new UserDAO().getAllUsers(); } catch (Exception e) { e.printStackTrace(); } return SUCCESS; } public List<User> getUserList() { return userList; } public void setUserList(List<User> userList) { this.userList = userList; } } ``` AddAction.java: ``` package com.example.struts2crud.action; import com.example.struts2crud.dao.UserDAO; import com.example.struts2crud.model.User; import com.opensymphony.xwork2.ActionSupport; public class AddAction extends ActionSupport { private static final long serialVersionUID = 1L; private User user; public String execute() { try { new UserDAO().addUser(user); } catch (Exception e) { e.printStackTrace(); } return SUCCESS; } public User getUser() { return user; } public void setUser(User user) { this.user = user; } } ``` EditAction.java: ``` package com.example.struts2crud.action; import com.example.struts2crud.dao.UserDAO; import com.example.struts2crud.model.User; import com.opensymphony.xwork2.ActionSupport; public class EditAction extends ActionSupport { private static final long serialVersionUID = 1L; private User user; public String execute() { try { new UserDAO().updateUser(user); } catch (Exception e) { e.printStackTrace(); } return SUCCESS; } public User getUser() { return user; } public void setUser(User user) { this.user = user; } } ``` DeleteAction.java: ``` package com.example.struts2crud.action; import com.example.struts2crud.dao.UserDAO; import com.opensymphony.xwork2.ActionSupport; public class DeleteAction extends ActionSupport { private static final long serialVersionUID = 1L; private int id; public String execute() { try { new UserDAO().deleteUser(id); } catch (Exception e) { e.printStackTrace(); } return SUCCESS; } public int getId() { return id; } public void setId(int id) { this.id = id; } } ``` 4. 创建 JSP 页面 创建以下三个 JSP 页面: list.jsp: ``` <%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <%@ taglib prefix="s" uri="/struts-tags" %> <html> <head> <title>Struts2 CRUD Example</title> </head> <body> <h2>Users List</h2> <table border="1"> <tr> <th>ID</th> <th>Name</th> <th>Email</th> <th>Password</th> <th>Action</th> </tr> <s:iterator value="userList"> <tr> <td><s:property value="id"/></td> <td><s:property value="name"/></td> <td><s:property value="email"/></td> <td><s:property value="password"/></td> <td> <s:url id="editUrl" action="edit"> <s:param name="user.id" value="%{id}"/> </s:url> <s:url id="deleteUrl" action="delete"> <s:param name="id" value="%{id}"/> </s:url> <s:a href="%{editUrl}">Edit</s:a> <s:a href="%{deleteUrl}">Delete</s:a> </td> </tr> </s:iterator> </table> <br> <s:url id="addUrl" action="add"/> <s:a href="%{addUrl}">Add New User</s:a> </body> </html> ``` add.jsp: ``` <%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <%@ taglib prefix="s" uri="/struts-tags" %> <html> <head> <title>Struts2 CRUD Example</title> </head> <body> <h2>Add New User</h2> <s:form action="add"> <s:textfield name="user.name" label="Name"/> <s:textfield name="user.email" label="Email"/> <s:textfield name="user.password" label="Password"/> <s:submit value="Save"/> </s:form> <br> <s:url id="listUrl" action="list"/> <s:a href="%{listUrl}">Back to List</s:a> </body> </html> ``` edit.jsp: ``` <%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <%@ taglib prefix="s" uri="/struts-tags" %> <html> <head> <title>Struts2 CRUD Example</title> </head> <body> <h2>Edit User</h2> <s:form action="edit"> <s:hidden name="user.id"/> <s:textfield name="user.name" label="Name"/> <s:textfield name="user.email" label="Email"/> <s:textfield name="user.password" label="Password"/> <s:submit value="Save"/> </s:form> <br> <s:url id="listUrl" action="list"/> <s:a href="%{listUrl}">Back to List</s:a> </body> </html> ``` 5. 创建 DAO 类 创建一个名为 "UserDAO.java" 的 DAO 类,用于操作数据库: ``` package com.example.struts2crud.dao; import java.sql.Connection; import java.sql.DriverManager; import java.sql.PreparedStatement; import java.sql.ResultSet; import java.util.ArrayList; import java.util.List; import com.example.struts2crud.model.User; public class UserDAO { public static final String URL = "jdbc:mysql://localhost:3306/struts2_crud"; public static final String USER = "root"; public static final String PASSWORD = "password"; public Connection getConnection() throws Exception { Class.forName("com.mysql.jdbc.Driver"); return DriverManager.getConnection(URL, USER, PASSWORD); } public List<User> getAllUsers() throws Exception { List<User> userList = new ArrayList<>(); String sql = "SELECT * FROM users"; try (Connection conn = getConnection(); PreparedStatement stmt = conn.prepareStatement(sql); ResultSet rs = stmt.executeQuery()) { while (rs.next()) { User user = new User(); user.setId(rs.getInt("id")); user.setName(rs.getString("name")); user.setEmail(rs.getString("email")); user.setPassword(rs.getString("password")); userList.add(user); } } return userList; } public void addUser(User user) throws Exception { String sql = "INSERT INTO users (name, email, password) VALUES (?, ?, ?)"; try (Connection conn = getConnection(); PreparedStatement stmt = conn.prepareStatement(sql)) { stmt.setString(1, user.getName()); stmt.setString(2, user.getEmail()); stmt.setString(3, user.getPassword()); stmt.executeUpdate(); } } public void updateUser(User user) throws Exception { String sql = "UPDATE users SET name = ?, email = ?, password = ? WHERE id = ?"; try (Connection conn = getConnection(); PreparedStatement stmt = conn.prepareStatement(sql)) { stmt.setString(1, user.getName()); stmt.setString(2, user.getEmail()); stmt.setString(3, user.getPassword()); stmt.setInt(4, user.getId()); stmt.executeUpdate(); } } public void deleteUser(int id) throws Exception { String sql = "DELETE FROM users WHERE id = ?"; try (Connection conn = getConnection(); PreparedStatement stmt = conn.prepareStatement(sql)) { stmt.setInt(1, id); stmt.executeUpdate(); } } } ``` 6. 运行项目 将以上代码保存到项目中,然后启动项目,访问 "http://localhost:8080/项目名/list.action" 即可看到用户列。可以点击 "Add New User" 按钮添加新用户,点击 "Edit" 按钮编辑用户信息,点击 "Delete" 按钮删除用户。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值