【SSH项目实战】国税协同平台-30.投诉受理保存受理信息

2023-11-03 01:18

本文主要是介绍【SSH项目实战】国税协同平台-30.投诉受理保存受理信息,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

上次我们给“投诉受理管理”模块做了多条件查询功能,我们通过流程图来回顾一下这个模块的具体流程:


根据流程图,我们接下来剩下的就是“受理投诉”、“保存投诉信息”、“用户投诉”等功能了。我们不用着急,一项一项的来完成。

我们下面写的就是管理者受理投诉的功能,可以看到我们的列表有这么一项:


我们要给这个受理加一个链接,使之能够进入之前需求分析中要求的受理界面,在受理界面管理者可以填写投诉的回复内容。

首先在Action中编写跳转至受理界面的方法:
[java]  view plain copy
  1. //跳转到受理界面  
  2. public String dealUI(){  
  3.     //加载状态集合  
  4.     ActionContext.getContext().getContextMap().put("complainStateMap", Complain.COMPLAIN_STATE_MAP);  
  5.     if(complain!=null){  
  6.         complain=complainService.findObjectById(complain.getCompId());  
  7.     }  
  8.     return "dealUI";  
  9. }  

因为我们要回复投诉,所以在Action中添加一个回复投诉对象以及get和set方法:
[java]  view plain copy
  1. private ComplainReply reply;  
  2.   
  3. public ComplainReply getReply() {  
  4.     return reply;  
  5. }  
  6.   
  7. public void setReply(ComplainReply reply) {  
  8.     this.reply = reply;  
  9. }  

然后在jsp页面中添加这个超链接:
[html]  view plain copy
  1. <td align="center">  
  2.       <a href="javascript:doDeal('<s:property value='compId'/>')">受理</a>  
  3. </td>  

其中的doDeal的javascript方法如下:
[javascript]  view plain copy
  1. //受理  
  2. function doDeal(compId){  
  3.     document.forms[0].action = "${basePath}tax/complain_dealUI.action?complain.compId=" + compId;  
  4.     document.forms[0].submit();  
  5. }  

然后我们看一下美工给我们的dealUI页面(我们要在其中添加需要显示的数据和超链接,下面已经是添加好的):
[html]  view plain copy
  1. <%@ page contentType="text/html;charset=UTF-8" language="java" %>  
  2. <html>  
  3. <head>  
  4.     <%@include file="/common/header.jsp"%>  
  5.     <title>投诉受理管理</title>  
  6. </head>  
  7. <body class="rightBody">  
  8. <form id="form" name="form" action="${basePath }tax/complain_deal.action" method="post" enctype="multipart/form-data">  
  9.     <div class="p_d_1">  
  10.         <div class="p_d_1_1">  
  11.             <div class="content_info">  
  12.     <div class="c_crumbs"><div><b></b><strong>投诉受理管理</strong> - 投诉受理</div></div>  
  13.     <div class="tableH2">投诉详细信息<span style="color:red;">(<s:property value="#complainStateMap[complain.state]"/>)</span></div>  
  14.     <table id="baseInfo" width="100%" align="center" class="list" border="0" cellpadding="0" cellspacing="0"  >  
  15.         <tr><td colspan="2" align="center">投诉人信息</td></tr>  
  16.         <tr>  
  17.             <td class="tdBg" width="250px">是否匿名投诉:</td>  
  18.             <td><s:property value="complain.isNm?'匿名投诉':'非匿名投诉'"/></td>  
  19.         </tr>  
  20.         <tr>  
  21.             <td class="tdBg">投诉人单位:</td>  
  22.             <td>  
  23.             <s:if test="!complain.isNm">  
  24.                 <s:property value="complain.compCompany"/>  
  25.             </s:if>  
  26.             </td>  
  27.         </tr>  
  28.         <tr>  
  29.             <td class="tdBg">投诉人姓名:</td>  
  30.             <td><s:property value="complain.compName"/></td>  
  31.         </tr>  
  32.         <tr>  
  33.             <td class="tdBg">投诉人手机:</td>  
  34.             <td>  
  35.             <s:property value="complain.compMobile"/>  
  36.             </td>  
  37.         </tr>  
  38.         <tr><td colspan="2" align="center">投诉信息</td></tr>  
  39.         <tr>  
  40.             <td class="tdBg">投诉时间:</td>  
  41.             <td>  
  42.                 <s:date name="complain.compTime" format="yyyy-MM-dd HH:mm"/>  
  43.             </td>  
  44.         </tr>  
  45.         <tr>  
  46.             <td class="tdBg">被投诉部门:</td>  
  47.             <td><s:property value="complain.toCompDept"/></td>  
  48.         </tr>  
  49.         <tr>  
  50.             <td class="tdBg">被投诉人:</td>  
  51.             <td><s:property value="complain.toCompName"/></td>  
  52.         </tr>  
  53.         <tr>  
  54.             <td class="tdBg">投诉标题:</td>  
  55.             <td><s:property value="complain.compTitle"/></td>  
  56.         </tr>  
  57.         <tr>  
  58.             <td class="tdBg">投诉内容:</td>  
  59.             <td><s:property value="complain.compContent" escape="false"/></td>  
  60.         </tr>  
  61.         <tr><td colspan="2" align="center">受理信息</td></tr>  
  62.         <tr>  
  63.             <td colspan="2">  
  64.                     <fieldset style="border: solid 1px #c0c0c0;margin-top:5px;">  
  65.                     <legend style="color:green;font-weight:bold;">回复 </legend>  
  66.                         <div style="width:100%; text-align:center;color:#ccc;maring-top:5px;">  
  67.                         回复部门:xxx    
  68.                         回复人:xxx    
  69.                         回复时间:xxx  
  70.                         </div>  
  71.                         <div style="width:100%;maring-top:10px;font-size:13px;padding-left:5px;">  
  72.                         xxx  
  73.                         </div>  
  74.                     </fieldset>  
  75.             </td>  
  76.         </tr>  
  77.        <tr><td colspan="2" align="center">受理操作</td></tr>  
  78.         <tr>  
  79.             <td class="tdBg">回复部门:</td>  
  80.             <td>  
  81.              <s:property value="#session.SYS_USER.dept"/>  
  82.              <s:hidden name="reply.replyDept" value="%{#session.SYS_USER.dept}"/>  
  83.             </td>  
  84.         </tr>  
  85.         <tr>  
  86.             <td class="tdBg">回复人:</td>  
  87.             <td>  
  88.               <s:property value="#session.SYS_USER.name"/>  
  89.               <s:hidden name="reply.replyer" value="%{#session.SYS_USER.name}"/>  
  90.             </td>  
  91.         </tr>  
  92.   
  93.   
  94.         <tr>  
  95.             <td class="tdBg" width="200px">回复内容:</td>  
  96.             <td><s:textarea name="reply.replyContent" cols="90" rows="8" /></td>  
  97.         </tr>  
  98.     </table>  
  99.     <s:hidden name="complain.compId"/>  
  100.     <div class="tc mt20">  
  101.         <input type="submit" class="btnB2" value="保存" />  
  102.               
  103.         <input type="button"  onclick="javascript:history.go(-1)" class="btnB2" value="返回" />  
  104.     </div>  
  105.     </div></div></div>  
  106. </form>  
  107. </body>  
  108. </html>  

上面暂时我们还没有编写的功能取值使用了xxx,后面我们写这块功能的时候在重新完善jsp界面代码。

我们在回复界面回复了用户的投诉之后,要点击保存了,此时我们要对回复进行保存等等一系列操作,所以在Action方法中添加deal()方法来完成这些操作:
[java]  view plain copy
  1. public String deal(){  
  2.     if(complain!=null){  
  3.         Complain tem=complainService.findObjectById(complain.getCompId());  
  4.         //1.更新投诉的状态为已受理  
  5.         if(!Complain.COMPLAIN_STATE_DONE.equals(complain.getState())){//更新状态为 已受理  
  6.             tem.setState(Complain.COMPLAIN_STATE_DONE);  
  7.         }  
  8.           
  9.         //2.保存回复信息  
  10.         if(reply!=null){  
  11.             reply.setComplain(tem);  
  12.             reply.setReplyTime(new Timestamp(new Date().getTime()));  
  13.             tem.getComplainReplies().add(reply);//级联保存回复信息  
  14.         }  
  15.         complainService.update(tem);  
  16.     }  
  17.     return "list";  
  18. }  

我们来测试一下:
对第一条投诉点击“受理”


然后跳转至这个页面:


我们在回复框里随意输入了一些数据,然后我们点击“保存”。

页面跳转回列表,并且刚刚我们的投诉信息变成了“已受理”状态


我们去数据库中查看,我们的回复信息也已经保存下来


我们下一次完成历史受理信息的显示

以及数据回显功能,当然还有用户编写投诉信息的入口

这篇关于【SSH项目实战】国税协同平台-30.投诉受理保存受理信息的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/334557

相关文章

springboot项目中使用JOSN解析库的方法

《springboot项目中使用JOSN解析库的方法》JSON,全程是JavaScriptObjectNotation,是一种轻量级的数据交换格式,本文给大家介绍springboot项目中使用JOSN... 目录一、jsON解析简介二、Spring Boot项目中使用JSON解析1、pom.XML文件引入依

使用vscode搭建pywebview集成vue项目实践

《使用vscode搭建pywebview集成vue项目实践》:本文主要介绍使用vscode搭建pywebview集成vue项目实践,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录环境准备项目源码下载项目说明调试与生成可执行文件核心代码说明总结本节我们使用pythonpywebv

Java Spring 中的监听器Listener详解与实战教程

《JavaSpring中的监听器Listener详解与实战教程》Spring提供了多种监听器机制,可以用于监听应用生命周期、会话生命周期和请求处理过程中的事件,:本文主要介绍JavaSprin... 目录一、监听器的作用1.1 应用生命周期管理1.2 会话管理1.3 请求处理监控二、创建监听器2.1 Ser

Apache 高级配置实战之从连接保持到日志分析的完整指南

《Apache高级配置实战之从连接保持到日志分析的完整指南》本文带你从连接保持优化开始,一路走到访问控制和日志管理,最后用AWStats来分析网站数据,对Apache配置日志分析相关知识感兴趣的朋友... 目录Apache 高级配置实战:从连接保持到日志分析的完整指南前言 一、Apache 连接保持 - 性

Maven项目中集成数据库文档生成工具的操作步骤

《Maven项目中集成数据库文档生成工具的操作步骤》在Maven项目中,可以通过集成数据库文档生成工具来自动生成数据库文档,本文为大家整理了使用screw-maven-plugin(推荐)的完... 目录1. 添加插件配置到 pom.XML2. 配置数据库信息3. 执行生成命令4. 高级配置选项5. 注意事

Linux查看系统盘和SSD盘的容量、型号及挂载信息的方法

《Linux查看系统盘和SSD盘的容量、型号及挂载信息的方法》在Linux系统中,管理磁盘设备和分区是日常运维工作的重要部分,而lsblk命令是一个强大的工具,它用于列出系统中的块设备(blockde... 目录1. 查看所有磁盘的物理信息方法 1:使用 lsblk(推荐)方法 2:使用 fdisk -l(

eclipse如何运行springboot项目

《eclipse如何运行springboot项目》:本文主要介绍eclipse如何运行springboot项目问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目js录当在eclipse启动spring boot项目时出现问题解决办法1.通过cmd命令行2.在ecl

MQTT SpringBoot整合实战教程

《MQTTSpringBoot整合实战教程》:本文主要介绍MQTTSpringBoot整合实战教程,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考... 目录MQTT-SpringBoot创建简单 SpringBoot 项目导入必须依赖增加MQTT相关配置编写

SpringBoot项目Web拦截器使用的多种方式

《SpringBoot项目Web拦截器使用的多种方式》在SpringBoot应用中,Web拦截器(Interceptor)是一种用于在请求处理的不同阶段执行自定义逻辑的机制,下面给大家介绍Sprin... 目录一、实现 HandlerInterceptor 接口1、创建HandlerInterceptor实

Maven项目打包时添加本地Jar包的操作步骤

《Maven项目打包时添加本地Jar包的操作步骤》在Maven项目开发中,我们经常会遇到需要引入本地Jar包的场景,比如使用未发布到中央仓库的第三方库或者处理版本冲突的依赖项,本文将详细介绍如何通过M... 目录一、适用场景说明​二、核心操作命令​1. 命令格式解析​2. 实战案例演示​三、项目配置步骤​1