struts2的增删改查

来源:互联网 发布:动漫飞机杯推荐 知乎 编辑:程序博客网 时间:2024/04/26 00:30

刚毕业不久,现在公司用的是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。

 

 

 

 

 

 

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