热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

【SSH项目实战】国税协同平台18.信息发布管理需求分析CRUD

我们接下来要做一个信息发布管理的功能,首先来看看我们的需求分析:要求信息发布管理原型界面:编辑信息原型界面:2.6.2功能说明信息发布管理:根据信息标题
我们接下来要做一个信息发布管理的功能,首先来看看我们的需求分析:

要求

信息发布管理原型界面:






编辑信息原型界面:






2.6.2功能说明



信息发布管理:

根据信息标题、信息类型进行信息查询;可以在页面中点击“新增”发布信息,点击“删除”进行批量删除信息。列表数据包括信息标题、信息分类、申请人、申请时间、状态、操作;其中操作栏的内容为停用/发布、编辑、删除。当信息的状态为停用时,在操作栏显示发布、编辑、删除,当信息的状态为发布时,操作栏显示停用、编辑、删除。



编辑信息:

填写内容包括信息分类(通知公告、政策速递、纳税指导)、来源、信息标题、信息内容(需要编辑多种格式内容)、备注、申请人、申请时间。



首先我们用图形表达需求,使用流程图,我们使用Edraw Max来绘制流程图:








我们下面先着手来进行模块的开发:

首先编写实体类

package cn.edu.hpu.tax.info.entity;import java.io.Serializable;
import java.sql.Timestamp;
import java.util.HashMap;
import java.util.Map;public class Info implements Serializable{private String infoId;private String type;private String source;private String title;private String content;private String memo;private String creator;private Timestamp createTime;private String state;//状态public static String INFO_STATE_PUBLIC = "1";//发布public static String INFO_STATE_STOP = "0";//停用//信息分类public static String INFO_TYPE_TZGG="tzgg";public static String INFO_TYPE_ZCSD="zcsd";public static String INFO_TYPE_NSZD="nszd";public static Map INFO_TYPE_MAP;static{INFO_TYPE_MAP=new HashMap();INFO_TYPE_MAP.put(INFO_TYPE_TZGG, "通知公告");INFO_TYPE_MAP.put(INFO_TYPE_ZCSD, "政策速递");INFO_TYPE_MAP.put(INFO_TYPE_NSZD, "纳税指导");}public Info(){}public Info(String infoId, String type, String source, String title,String content, String memo, String creator, Timestamp createTime,String state) {super();this.infoId = infoId;this.type = type;this.source = source;this.title = title;this.content = content;this.memo = memo;this.creator = creator;this.createTime = createTime;this.state = state;}//下面是get和set方法,这里省略}


然后使我们的映射文件:

Info.hbm.xml


"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">


之后使我们的Dao层:

package cn.edu.hpu.tax.info.dao;import cn.edu.hpu.tax.core.dao.BaseDao;
import cn.edu.hpu.tax.info.entity.Info;public interface InfoDao extends BaseDao {}


package cn.edu.hpu.tax.info.dao.impl;import cn.edu.hpu.tax.core.dao.impl.BaseDaoImpl;
import cn.edu.hpu.tax.info.dao.InfoDao;
import cn.edu.hpu.tax.info.entity.Info;public class InfoDaoImpl extends BaseDaoImpl implements InfoDao {}


然后使我们的Service层:

package cn.edu.hpu.tax.info.service;import java.io.Serializable;
import java.util.List;import cn.edu.hpu.tax.info.entity.Info;public interface InfoService {//新增public void save(Info entity);//更新public void update(Info enetity);//根据id删除public void delete(Serializable id);//根据id查找public Info findObjectById(Serializable id);//查找列表public List findObjects();
}


package cn.edu.hpu.tax.info.service.impl;import java.io.Serializable;
import java.util.List;import javax.annotation.Resource;import org.springframework.stereotype.Service;import cn.edu.hpu.tax.info.dao.InfoDao;
import cn.edu.hpu.tax.info.entity.Info;@Service("infoService")
public class InfoServiceImpl implements InfoService {@Resourceprivate InfoDao infoDao;@Overridepublic void delete(Serializable id) {infoDao.delete(id);}@Overridepublic Info findObjectById(Serializable id) {return infoDao.findObjectById(id);}@Overridepublic List findObjects() {return infoDao.findObjects();}@Overridepublic void save(Info entity) {infoDao.save(entity);}@Overridepublic void update(Info enetity) {infoDao.update(enetity);}}


然后使我们的Action层:

package cn.edu.hpu.tax.info.action;import java.util.HashSet;
import java.util.List;import javax.annotation.Resource;import cn.edu.hpu.tax.core.action.BaseAction;
import cn.edu.hpu.tax.core.content.Constant;
import cn.edu.hpu.tax.info.entity.Info;
import cn.edu.hpu.tax.info.service.InfoService;import com.opensymphony.xwork2.ActionContext;public class InfoAction extends BaseAction {@Resourceprivate InfoService infoService;private List infoList;private Info info;//列表页面public String listUI() throws Exception{try {//加载分类集合ActionContext.getContext().getContextMap().put("infoTypeMap", Info.INFO_TYPE_MAP);infoList=infoService.findObjects();} catch (Exception e) {throw new Exception(e.getMessage());}return "listUI";}//跳转到新增页面public String addUI(){//加载分类集合ActionContext.getContext().getContextMap().put("infoTypeMap", Info.INFO_TYPE_MAP);//在进入编辑页面的时候传入当前创建时间info=new Info();info.setCreateTime(new Timestamp(new Date().getTime()));return "addUI";}//保存新增public String add(){if(info!=null ){infoService.save(info);}return "list";}//跳转到编辑界面public String editUI(){//加载分类集合ActionContext.getContext().getContextMap().put("infoTypeMap", Info.INFO_TYPE_MAP);if(info!=null && info.getInfoId()!=null){info=infoService.findObjectById(info.getInfoId());}return "editUI";}//保存编辑public String edit(){infoService.update(info);return "list";}//删除public String delete(){if(info!=null && info.getInfoId()!=null){infoService.delete(info.getInfoId());}return "list";}//批量删除public String deleteSelected(){if(selectedRow!=null){for(String id:selectedRow){infoService.delete(id);}}return "list";}public List getInfoList() {return infoList;}public void setInfoList(List InfoList) {this.infoList = InfoList;}public Info getInfo() {return info;}public void setInfo(Info info) {this.info = info;}
}


接下来使我们的配置文件:

info-spring.xml:






info-struts.xml:


/WEB-INF/jsp/tax/info/{1}.jspinfo_listUI



然后将info-struts.xml引入到总struts文件中:





然后把我们美工做好的jsp页面引进来(addUI.jsp/editUI.jsp/listUI.jsp):

listUI.jsp

<%&#64; page contentType&#61;"text/html;charset&#61;UTF-8" language&#61;"java" %>

<%&#64;include file&#61;"/common/header.jsp"%>


信息发布管理
  • 信息标题&#xff1a;
  •   
  • bgcolor&#61;"f8f8f8" >
    信息标题信息分类创建人创建时间状态操作
    "/> " align&#61;"center">停用&#39;)">编辑&#39;)">删除
    总共1条记录&#xff0c;当前第 1 页&#xff0c;共 1 页   上一页  下一页到    





    addUI.jsp

    <%&#64; page contentType&#61;"text/html;charset&#61;UTF-8" language&#61;"java" %>

    <%&#64;include file&#61;"/common/header.jsp"%>


    信息发布管理 - 新增信息
    新增信息
    信息分类&#xff1a;来源&#xff1a;
    信息标题&#xff1a;
    信息内容&#xff1a;
    备注&#xff1a;
    创建人&#xff1a;创建时间&#xff1a;





    editUI.jsp

    <%&#64; page contentType&#61;"text/html;charset&#61;UTF-8" language&#61;"java" %>

    <%&#64;include file&#61;"/common/header.jsp"%>

    信息发布管理 - 修改信息
    修改信息
    信息分类&#xff1a;来源&#xff1a;
    信息标题&#xff1a;
    信息内容&#xff1a;
    备注&#xff1a;
    创建人&#xff1a;创建时间&#xff1a;





    然后在子系统的frame框架的左边列表(left.jap)加入链接:

    信息发布管理



    之后重启服务器测试&#xff1b;








    新增一个信息:




    新增成功:








    编辑信息:




    编辑成功:








    删除信息




    删除成功&#xff01;



    至此我们信息发布管理的基础增删改查完成了&#xff0c;但是我们还没有完成我们的所有需求&#xff0c;下一篇总结继续完成我们的信息发布管理业务的功能。

    转载请注明出处&#xff1a;http://blog.csdn.net/acmman/article/details/49700015


    推荐阅读
    • Iamtryingtomakeaclassthatwillreadatextfileofnamesintoanarray,thenreturnthatarra ... [详细]
    • Spring特性实现接口多类的动态调用详解
      本文详细介绍了如何使用Spring特性实现接口多类的动态调用。通过对Spring IoC容器的基础类BeanFactory和ApplicationContext的介绍,以及getBeansOfType方法的应用,解决了在实际工作中遇到的接口及多个实现类的问题。同时,文章还提到了SPI使用的不便之处,并介绍了借助ApplicationContext实现需求的方法。阅读本文,你将了解到Spring特性的实现原理和实际应用方式。 ... [详细]
    • 前景:当UI一个查询条件为多项选择,或录入多个条件的时候,比如查询所有名称里面包含以下动态条件,需要模糊查询里面每一项时比如是这样一个数组条件:newstring[]{兴业银行, ... [详细]
    • Java太阳系小游戏分析和源码详解
      本文介绍了一个基于Java的太阳系小游戏的分析和源码详解。通过对面向对象的知识的学习和实践,作者实现了太阳系各行星绕太阳转的效果。文章详细介绍了游戏的设计思路和源码结构,包括工具类、常量、图片加载、面板等。通过这个小游戏的制作,读者可以巩固和应用所学的知识,如类的继承、方法的重载与重写、多态和封装等。 ... [详细]
    • Spring源码解密之默认标签的解析方式分析
      本文分析了Spring源码解密中默认标签的解析方式。通过对命名空间的判断,区分默认命名空间和自定义命名空间,并采用不同的解析方式。其中,bean标签的解析最为复杂和重要。 ... [详细]
    • 在说Hibernate映射前,我们先来了解下对象关系映射ORM。ORM的实现思想就是将关系数据库中表的数据映射成对象,以对象的形式展现。这样开发人员就可以把对数据库的操作转化为对 ... [详细]
    • 本文讨论了一个关于cuowu类的问题,作者在使用cuowu类时遇到了错误提示和使用AdjustmentListener的问题。文章提供了16个解决方案,并给出了两个可能导致错误的原因。 ... [详细]
    • 本文介绍了一个在线急等问题解决方法,即如何统计数据库中某个字段下的所有数据,并将结果显示在文本框里。作者提到了自己是一个菜鸟,希望能够得到帮助。作者使用的是ACCESS数据库,并且给出了一个例子,希望得到的结果是560。作者还提到自己已经尝试了使用"select sum(字段2) from 表名"的语句,得到的结果是650,但不知道如何得到560。希望能够得到解决方案。 ... [详细]
    • 本文介绍了Android 7的学习笔记总结,包括最新的移动架构视频、大厂安卓面试真题和项目实战源码讲义。同时还分享了开源的完整内容,并提醒读者在使用FileProvider适配时要注意不同模块的AndroidManfiest.xml中配置的xml文件名必须不同,否则会出现问题。 ... [详细]
    • 本文介绍了iOS数据库Sqlite的SQL语句分类和常见约束关键字。SQL语句分为DDL、DML和DQL三种类型,其中DDL语句用于定义、删除和修改数据表,关键字包括create、drop和alter。常见约束关键字包括if not exists、if exists、primary key、autoincrement、not null和default。此外,还介绍了常见的数据库数据类型,包括integer、text和real。 ... [详细]
    • 本文详细介绍了在ASP.NET中获取插入记录的ID的几种方法,包括使用SCOPE_IDENTITY()和IDENT_CURRENT()函数,以及通过ExecuteReader方法执行SQL语句获取ID的步骤。同时,还提供了使用这些方法的示例代码和注意事项。对于需要获取表中最后一个插入操作所产生的ID或马上使用刚插入的新记录ID的开发者来说,本文提供了一些有用的技巧和建议。 ... [详细]
    • 本文详细介绍了Spring的JdbcTemplate的使用方法,包括执行存储过程、存储函数的call()方法,执行任何SQL语句的execute()方法,单个更新和批量更新的update()和batchUpdate()方法,以及单查和列表查询的query()和queryForXXX()方法。提供了经过测试的API供使用。 ... [详细]
    • Go GUIlxn/walk 学习3.菜单栏和工具栏的具体实现
      本文介绍了使用Go语言的GUI库lxn/walk实现菜单栏和工具栏的具体方法,包括消息窗口的产生、文件放置动作响应和提示框的应用。部分代码来自上一篇博客和lxn/walk官方示例。文章提供了学习GUI开发的实际案例和代码示例。 ... [详细]
    • 多维数组的使用
      本文介绍了多维数组的概念和使用方法,以及二维数组的特点和操作方式。同时还介绍了如何获取数组的长度。 ... [详细]
    • r2dbc配置多数据源
      R2dbc配置多数据源问题根据官网配置r2dbc连接mysql多数据源所遇到的问题pom配置可以参考官网,不过我这样配置会报错我并没有这样配置将以下内容添加到pom.xml文件d ... [详细]
    author-avatar
    easonash_949
    这个家伙很懒,什么也没留下!
    PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
    Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有