【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

相关文章

基于 Cursor 开发 Spring Boot 项目详细攻略

《基于Cursor开发SpringBoot项目详细攻略》Cursor是集成GPT4、Claude3.5等LLM的VSCode类AI编程工具,支持SpringBoot项目开发全流程,涵盖环境配... 目录cursor是什么?基于 Cursor 开发 Spring Boot 项目完整指南1. 环境准备2. 创建

MyBatis分页查询实战案例完整流程

《MyBatis分页查询实战案例完整流程》MyBatis是一个强大的Java持久层框架,支持自定义SQL和高级映射,本案例以员工工资信息管理为例,详细讲解如何在IDEA中使用MyBatis结合Page... 目录1. MyBATis框架简介2. 分页查询原理与应用场景2.1 分页查询的基本原理2.1.1 分

使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解

《使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解》本文详细介绍了如何使用Python通过ncmdump工具批量将.ncm音频转换为.mp3的步骤,包括安装、配置ffmpeg环... 目录1. 前言2. 安装 ncmdump3. 实现 .ncm 转 .mp34. 执行过程5. 执行结

SpringBoot 多环境开发实战(从配置、管理与控制)

《SpringBoot多环境开发实战(从配置、管理与控制)》本文详解SpringBoot多环境配置,涵盖单文件YAML、多文件模式、MavenProfile分组及激活策略,通过优先级控制灵活切换环境... 目录一、多环境开发基础(单文件 YAML 版)(一)配置原理与优势(二)实操示例二、多环境开发多文件版

Three.js构建一个 3D 商品展示空间完整实战项目

《Three.js构建一个3D商品展示空间完整实战项目》Three.js是一个强大的JavaScript库,专用于在Web浏览器中创建3D图形,:本文主要介绍Three.js构建一个3D商品展... 目录引言项目核心技术1. 项目架构与资源组织2. 多模型切换、交互热点绑定3. 移动端适配与帧率优化4. 可

sky-take-out项目中Redis的使用示例详解

《sky-take-out项目中Redis的使用示例详解》SpringCache是Spring的缓存抽象层,通过注解简化缓存管理,支持Redis等提供者,适用于方法结果缓存、更新和删除操作,但无法实现... 目录Spring Cache主要特性核心注解1.@Cacheable2.@CachePut3.@Ca

从原理到实战解析Java Stream 的并行流性能优化

《从原理到实战解析JavaStream的并行流性能优化》本文给大家介绍JavaStream的并行流性能优化:从原理到实战的全攻略,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的... 目录一、并行流的核心原理与适用场景二、性能优化的核心策略1. 合理设置并行度:打破默认阈值2. 避免装箱

Maven中生命周期深度解析与实战指南

《Maven中生命周期深度解析与实战指南》这篇文章主要为大家详细介绍了Maven生命周期实战指南,包含核心概念、阶段详解、SpringBoot特化场景及企业级实践建议,希望对大家有一定的帮助... 目录一、Maven 生命周期哲学二、default生命周期核心阶段详解(高频使用)三、clean生命周期核心阶

Python实战之SEO优化自动化工具开发指南

《Python实战之SEO优化自动化工具开发指南》在数字化营销时代,搜索引擎优化(SEO)已成为网站获取流量的重要手段,本文将带您使用Python开发一套完整的SEO自动化工具,需要的可以了解下... 目录前言项目概述技术栈选择核心模块实现1. 关键词研究模块2. 网站技术seo检测模块3. 内容优化分析模

Java 正则表达式的使用实战案例

《Java正则表达式的使用实战案例》本文详细介绍了Java正则表达式的使用方法,涵盖语法细节、核心类方法、高级特性及实战案例,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要... 目录一、正则表达式语法详解1. 基础字符匹配2. 字符类([]定义)3. 量词(控制匹配次数)4. 边