- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章Struts2实现CRUD(增 删 改 查)功能实例代码由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
CRUD是Create(创建)、Read(读取)、Update(更新)和Delete(删除)的缩写,它是普通应用程序的缩影。如果您掌握了某框架的CRUD编写,那么意味可以使用该框架创建普通应用程序了,所以大家使用新框架开发OLTP(Online Transaction Processing)应用程序时,首先会研究一下如何编写CRUD。这类似于大家在学习新编程语言时喜欢编写“Hello World”.
本文旨在讲述Struts 2上的CRUD开发,所以为了例子的简单易懂,我不会花时间在数据库的操作上。取而代之的是一个模拟数据库的哈希表(Hash Map).
具体实现 。
首先,让我们看看的“冒牌”的DAO(Data Access Object,数据访问对象),代码如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
|
package
tutorial.dao;
import
java.util.Collection;
import
java.util.concurrent.ConcurrentHashMap;
import
java.util.concurrent.ConcurrentMap;
import
tutorial.model.Book;
public
class
BookDao {
private
static
final
BookDao instance;
private
static
final
ConcurrentMap<String, Book> data;
static
{
instance =
new
BookDao();
data =
new
ConcurrentHashMap<String, Book>();
data.put(
"978-0735619678"
,
new
Book(
"978-0735619678"
,
"Code Complete, Second Edition"
,
32.99
));
data.put(
"978-0596007867"
,
new
Book(
"978-0596007867"
,
"The Art of Project Management"
,
35.96
));
data.put(
"978-0201633610"
,
new
Book(
"978-0201633610"
,
"Design Patterns: Elements of Reusable Object-Oriented Software"
,
43.19
));
data.put(
"978-0596527341"
,
new
Book(
"978-0596527341"
,
"Information Architecture for the World Wide Web: Designing Large-Scale Web Sites"
,
25.19
));
data.put(
"978-0735605350"
,
new
Book(
"978-0735605350"
,
"Software Estimation: Demystifying the Black Art"
,
25.19
));
}
private
BookDao() {}
public
static
BookDao getInstance() {
return
instance;
}
public
Collection<Book> getBooks() {
return
data.values();
}
public
Book getBook(String isbn) {
return
data.get(isbn);
}
public
void
storeBook(Book book) {
data.put(book.getIsbn(), book);
}
public
void
removeBook(String isbn) {
data.remove(isbn);
}
public
void
removeBooks(String[] isbns) {
for
(String isbn : isbns) {
data.remove(isbn);
}
}
}
|
清单1 src/tutorial/dao/BookDao.java 。
以上代码相信不用解释大家也清楚,我使用ConcurrentMap数据结构存储Book对象,这主要是为了方便检索和保存Book对象;另外,我还将data变量设为静态唯一来模拟应用程序的数据库.
接下来是的数据模型Book类,代码如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
|
package
tutorial.model;
public
class
Book {
private
String isbn;
private
String title;
private
double
price;
public
Book() {
}
public
Book(String isbn, String title,
double
price) {
this
.isbn = isbn;
this
.title = title;
this
.price = price;
}
public
String getIsbn() {
return
isbn;
}
public
void
setIsbn(String isbn) {
this
.isbn = isbn;
}
public
double
getPrice() {
return
price;
}
public
void
setPrice(
double
price) {
this
.price = price;
}
public
String getTitle() {
return
title;
}
public
void
setTitle(String title) {
this
.title = title;
}
}
|
清单2 src/tutorial/model/Book.java 。
Book类有三个属性isbn,、title和price分别代表书籍的编号、名称和价格,其中编号用于唯一标识书籍(相当数据库中的主键).
然后,我们再来看看Action类的代码:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
|
package
tutorial.action;
import
java.util.Collection;
import
tutorial.dao.BookDao;
import
tutorial.model.Book;
import
com.opensymphony.xwork2.ActionSupport;
public
class
BookAction
extends
ActionSupport {
private
static
final
long
serialVersionUID = 872316812305356L;
private
String isbn;
private
String[] isbns;
private
Book book;
private
Collection<Book> books;
private
BookDao dao = BookDao.getInstance();
public
Book getBook() {
return
book;
}
public
void
setBook(Book book) {
this
.book = book;
}
public
String getIsbn() {
return
isbn;
}
public
void
setIsbn(String isbn) {
this
.isbn = isbn;
}
public
String[] getIsbns() {
return
isbns;
}
public
void
setIsbns(String[] isbns) {
this
.isbns = isbns;
}
public
Collection<Book> getBooks() {
return
books;
}
public
void
setBooks(Collection<Book> books) {
this
.books = books;
}
public
String load() {
book = dao.getBook(isbn);
return
SUCCESS;
}
public
String list() {
books = dao.getBooks();
return
SUCCESS;
}
public
String store() {
dao.storeBook(book);
return
SUCCESS;
}
public
String remove() {
if
(
null
!= isbn) {
dao.removeBook(isbn);
}
else
{
dao.removeBooks(isbns);
}
return
SUCCESS;
}
}
|
清单3 src/tutorial/action/BookAction.java 。
BookAction类中属性isbn用于表示待编辑或删除的书籍的编号,属性isbns用于表示多个待删除的书籍的编号数组,属性book表示当前书籍,属性books则表示当前的书籍列表。BookAction有四个Action方法分别是load、list、store和remove,也即是CRUD都集中在BookAction中实现.
再下来是Action的配置代码:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
|
<?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=
"Struts2_CRUD_DEMO"
extends
=
"struts-default"
namespace=
"/Book"
>
<action name=
"List"
class
=
"tutorial.action.BookAction"
method=
"list"
>
<result>List.jsp</result>
</action>
<action name=
"Edit"
class
=
"tutorial.action.BookAction"
method=
"load"
>
<result>Edit.jsp</result>
</action>
<action name=
"Store"
class
=
"tutorial.action.BookAction"
method=
"store"
>
<result type=
"redirect"
>List.action</result>
</action>
<action name=
"Remove"
class
=
"tutorial.action.BookAction"
method=
"remove"
>
<result type=
"redirect"
>List.action</result>
</action>
</
package
>
</struts>
|
清单4 src/struts.xml 。
以上的配置中,我使用了四个Action定义。它们都在“/Book”名值空间内。这样我就可以分别通过“http://localhost:8080/Struts2_CRUD/Book/List.action”、“http://localhost:8080/Struts2_CRUD/Book/Edit.action”、“http://localhost:8080/Struts2_CRUD/Book/Store.action”和“http://localhost:8080/Struts2_CRUD/Book/Remove.action”来调用BookAction的四个Action方法进行CRUD操作。当然,这只是个人喜好,你大可以只定义一个Action(假设其名称为“Book”),之后通过“http://localhost:8080/Struts2_CRUD/Book!list.action”的方式来访问,详细做法请参考《Struts 2.0的Action讲解》。另外,我由于希望在完成编辑或删除之后回到列表页,所以使用类型为redirect(重定向)的result.
下面是列表页面的代码:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
|
<%@ page language=
"java"
contentType=
"text/html; charset=utf-8"
pageEncoding=
"utf-8"
%>
<%@ taglib prefix=
"s"
uri=
"/struts-tags"
%>
<!DOCTYPE html PUBLIC
"-//W3C//DTD XHTML 1.0 Transitional//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"
>
<html xmlns=
"http://www.w3.org/1999/xhtml"
>
<head>
<title>Book List</title>
<style type=
"text/css"
>
table {
border: 1px solid black;
border-collapse: collapse;
}
table thead tr th {
border: 1px solid black;
padding: 3px;
background-color: #cccccc;
}
table tbody tr td {
border: 1px solid black;
padding: 3px;
}
</style>
</head>
<body>
<h2>Book List</h2>
<s:form action=
"Remove"
theme=
"simple"
>
<table cellspacing=
"0"
>
<thead>
<tr>
<th>Select</th>
<th>ISBN</th>
<th>Title</th>
<th>Price</th>
<th>Operation</th>
</tr>
</thead>
<tbody>
<s:iterator value=
"books"
>
<tr>
<td><input type=
"checkbox"
name=
"isbns"
value=
'<s:property value="isbn" />'
/></td>
<td><s:property value=
"isbn"
/></td>
<td><s:property value=
"title"
/></td>
<td>$<s:property value=
"price"
/></td>
<td>
<a href=
'<s:url action="Edit"><s:param name="isbn" value="isbn" /></s:url>'
>
Edit
</a>
<a href=
'<s:url action="Remove"><s:param name="isbn" value="isbn" /></s:url>'
>
Delete
</a>
</td>
</tr>
</s:iterator>
</tbody>
</table>
<s:submit value=
"Remove"
/><a href=
"Edit.jsp"
>Add Book</a>
</s:form>
</body>
</html>
|
清单5 WebContent/Book/List.jsp 。
以上代码,值得注意的是在<s:form>标签,我设置了theme属性为“simple”,这样可以取消其默认的表格布局。之前,有些朋友问我“如果不希望提交按钮放在右边应该怎样做?”,上述做汗是答案之一。当然,更佳的做法自定义一个theme,并将其设为默认应用到整个站点,如此一来就可以得到统一的站点风格。我会在以后的文章中会对此作详细的描述.
编辑或添加书籍的页面代码如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
|
<%@ page language=
"java"
contentType=
"text/html; charset=utf-8"
pageEncoding=
"utf-8"
%>
<%@ taglib prefix=
"s"
uri=
"/struts-tags"
%>
<!DOCTYPE html PUBLIC
"-//W3C//DTD XHTML 1.0 Transitional//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"
>
<html xmlns=
"http://www.w3.org/1999/xhtml"
>
<head>
<title>Book</title>
</head>
<body>
<h2>
<s:
if
test=
"null == book"
>
Add Book
</s:
if
>
<s:
else
>
Edit Book
</s:
else
>
</h2>
<s:form action=
"Store"
>
<s:textfield name=
"book.isbn"
label=
"ISBN"
/>
<s:textfield name=
"book.title"
label=
"Title"
/>
<s:textfield name=
"book.price"
label=
"Price"
/>
<s:submit />
</s:form>
</body>
</html>
|
清单6 WebContent/Book/Edit.jsp 。
如果book为null,则表明该页面用于添加书籍,反之则为编辑页面.
为了方便大家运行示例,我把web.xml的代码也贴出来,如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
|
<?xml version=
"1.0"
encoding=
"UTF-8"
?>
<web-app id=
"WebApp_9"
version=
"2.4"
xmlns=
"http://java.sun.com/xml/ns/j2ee"
xmlns:xsi=
"http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation=
"http://java.sun.com/xml/ns/j2ee http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd"
>
<display-name>Struts
2
Fileupload</display-name>
<filter>
<filter-name>struts2</filter-name>
<filter-
class
>
org.apache.struts2.dispatcher.FilterDispatcher
</filter-
class
>
</filter>
<filter-mapping>
<filter-name>struts2</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
<welcome-file-list>
<welcome-file>index.html</welcome-file>
</welcome-file-list>
</web-app>
|
清单7 WebContent/WEB-INF/web.xml 。
大功告成,下面发布运行应用程序,在浏览器中键入:http://localhost:8080/Struts2_CRUD/Book/List.action,出现如下图所示页面:
清单8 列表页面 。
点击“Add Book”,出现如下图所示页面:
清单9 添加书籍页面 。
后退回到列表页面,点击“Edit”,出现如下图所示页面:
清单10 编辑书籍页面 。
总结 。
本文只是粗略地了介绍Struts 2的CRUD实现方法,所以有很多功能没有实现,如国际化和数据校验等。大家可以在上面例子的基础将其完善,当作练习也不错。有不明白的地方欢迎给我留言,小编会及时回复大家的,在此也非常感谢大家对我网站的支持! 。
最后此篇关于Struts2实现CRUD(增 删 改 查)功能实例代码的文章就讲到这里了,如果你想了解更多关于Struts2实现CRUD(增 删 改 查)功能实例代码的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
本文实例讲述了MySQL学习笔记之数据的增、删、改实现方法。分享给大家供大家参考,具体如下: 1、增加数据 插入代码格式: insert into 表明 [列名…] values (值…)
有时候我们需要扩展一个数组,或者删掉数组的一部分,PHP为扩展和缩小数组提供了一些函数。对于那些希望模仿各种队列实现(FIFO、LIFO)的程序员来说,这些函数可以提供便利。顾名思义,从这些函数的函
作为一个小型的数据存储传递的工具——xml,大家肯定也不陌生,今天就关于xml的一些简单操作做些总结。 这些都是在控制台进行操作的····&m
话不多说,请看代码: ? 1
本文实例讲述了mysql语句实现简单的增、删、改、查操作。分享给大家供大家参考,具体如下: 1、创建db_shop数据库,如果该数据库不存在则创建 ?
使用oracle触发器 实现对某个表的增改删的监控操作,并记录到另一个表中。 代码: 复制代码代码如下: create or replace trigger test_trigge
java连接数据库增、删、改、查工具类 数据库操作工具类,因为各厂家数据库的分页条件不同,目前支持Mysql、Oracle、Postgresql的分页查询 在Postgresql环境测试过了,其他
1、修改数据 复制代码代码如下: DataRow dr =
注册表可以用来进行存储一些程序的信息,例如用户的权限、或者某些值等,可以根据个人需要进行存储和删减。 当前注册表主目录: 引用包 Wesky.Net.OpenTools 1.0.5或
准备工作: 增、删、改、查的方法有很多很多种,这里只展示出常用的几种。 ?
需要5个类: 1.实体类:Person.java 2.抽象类:SQLOperate.java(封装了对数据库的操作) 3.助手类:DBOpenHelper.java(继承SQLiteOpenH
首先是是一个简单的例子,单链表的建立和输出。 程序1.1 复制代码 代码如下: #include<iostream> #include<string> using na
数据库操纵基本流程为: 1、连接数据库服务器 2、选择数据库 3、执行SQL语句 4、处理结果集 5、打印操作信息 其中用到的相关函数有 •resource m
CRUD是Create(创建)、Read(读取)、Update(更新)和Delete(删除)的缩写,它是普通应用程序的缩影。如果您掌握了某框架的CRUD编写,那么意味可以使用该框架创建普通应用程序了
项目结构: 添加页面: &
本文实例讲述了android操作sqlite数据库(增、删、改、查、分页等)及listview显示数据的方法。分享给大家供大家参考,具体如下: 由于刚接触android开发,故此想把学到的基础知识
总括 pandas的索引函数主要有三种: loc 标签索引,行和列的名称 iloc 整型索引(绝对位置索引),绝对意义上的几行几列,起始索引为0 ix 是 iloc 和 loc的合体 at
1. [代码]Mybatis全局配置文件 ? 1
我是一名优秀的程序员,十分优秀!