刚毕业不久,现在公司用的是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。
想要学习的可以关注我一下哦,我一般写的比较仔细。因为我是一个菜鸟,希望大家多提意见,代码有什么可以优化的地方,希望多提意见~~~~