日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 运维知识 > windows >内容正文

windows

纳税服务系统七(投诉管理模块)【显示投诉信息、处理回复、我要投诉、Quartz自动受理、统计图FusionCharts】...

發(fā)布時(shí)間:2023/12/29 windows 47 豆豆
生活随笔 收集整理的這篇文章主要介紹了 纳税服务系统七(投诉管理模块)【显示投诉信息、处理回复、我要投诉、Quartz自动受理、统计图FusionCharts】... 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

投訴受理管理模塊

接下來,就是來開發(fā)我們的投訴受理管理模塊了…..我們來看看原型圖與需求吧:

查詢用戶提交的投訴信息,可以根據(jù)投訴部門(部門A/B)、投訴時(shí)間段、狀態(tài)進(jìn)行查詢。在列表信息中展示投訴標(biāo)題、被投訴部門、被投訴人、投訴時(shí)間、狀態(tài)(待受理、已受理、已失效)、操作;其中操作欄內(nèi)內(nèi)容為“處理”,點(diǎn)擊“處理”則在打開的查詢頁面中查看具體的投訴信息并且可以多次回復(fù)投訴信息;一旦回復(fù)則說明已受理該投訴。

投訴詳細(xì)信息:在本頁面中首先要明顯地展示出當(dāng)前投訴是否已經(jīng)受理;然后再顯示投訴人信息、被投訴信息、受理信息(歷史受理信息)三部分內(nèi)容,并且在頁面中可以無限次的對本次受理進(jìn)行回復(fù)。投訴人信息包括:是否匿名投訴、投訴人單位、投訴人姓名、投訴人手機(jī),如果是匿名投訴,則不顯示投訴人單位、姓名并對手機(jī)號中間4位號碼使用*號代替。被投訴信息包括:投訴時(shí)間、被投訴部門、被投訴人、投訴標(biāo)題、投訴內(nèi)容。受理信息:如果有多次回復(fù)則將多次的回復(fù)信息顯示,顯示內(nèi)容包括回復(fù)時(shí)間、回復(fù)部門、回復(fù)人、受理回復(fù)內(nèi)容;可以再次回復(fù)。

這里寫圖片描述這里寫圖片描述

根據(jù)上面兩張?jiān)蛨D以及文字說明,我們可以發(fā)現(xiàn):一個(gè)投訴信息可對應(yīng)多個(gè)回復(fù)。


在“工作主頁”中點(diǎn)擊“我要投訴”進(jìn)入頁面,添加內(nèi)容包括:投訴標(biāo)題、被投訴部門(部門A/B)、被投訴人、投訴詳情、是否匿名投訴

這里寫圖片描述

關(guān)鍵在于匿名投訴的那一部分,我們該怎么寫….


統(tǒng)計(jì):根據(jù)年度將相應(yīng)年度的每個(gè)月的投訴數(shù)進(jìn)行統(tǒng)計(jì),并以圖表的形式展示在頁面中;在頁面中可以選擇查看當(dāng)前年度及其前4年的投訴數(shù)。在頁面中可以選擇不同的年度,然后頁面展示該年度的曲線統(tǒng)計(jì)圖。

這里寫圖片描述

這個(gè)統(tǒng)計(jì)圖,大概也需要用到組件來生成出來的吧???


自動(dòng)投訴受理:在每個(gè)月月底最后一天對本月之前的投訴進(jìn)行自動(dòng)處理;將投訴信息的狀態(tài)改為 已失效。在后臺(tái)管理中不能對該類型投訴進(jìn)行回復(fù)。

自動(dòng)投訴受理??在每個(gè)月的最后一天判斷投訴信息,程序?qū)ζ渥詣?dòng)受理。。


投訴受理開發(fā)

我們首先來畫一個(gè)流程圖看看它的大概思路是怎么樣的:

這里寫圖片描述

Hibernate逆向工程

我們經(jīng)過上面的分析,知道了:一個(gè)投訴信息可對應(yīng)多個(gè)回復(fù)。是一對多的關(guān)系。我們下面使用powerdesginer來畫出它的概念數(shù)據(jù)模型圖

這里寫圖片描述

生成物理模型圖:

這里寫圖片描述

生成數(shù)據(jù)庫表:

/*==============================================================*//* DBMS name: ? ? ?MySQL 5.0 ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?*//* Created on: ? ? 2017/6/12 19:06:20 ? ? ? ? ? ? ? ? ? ? ? ? ? *//*==============================================================*/drop table if exists complain;drop table if exists complain_reply;/*==============================================================*//* Table: complain ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?*//*==============================================================*/create table complain( ? comp_id ? ? ? ? ? ? ?varchar(32) not null, ? comp_company ? ? ? ? varchar(100), ? comp_name ? ? ? ? ? ?varchar(20), ? comp_mobile ? ? ? ? ?varchar(20), ? is_NM ? ? ? ? ? ? ? ?bool, ? comp_time ? ? ? ? ? ?datetime, ? comp_title ? ? ? ? ? varchar(200) not null, ? to_comp_name ? ? ? ? varchar(20), ? to_comp_dept ? ? ? ? varchar(100), ? comp_content ? ? ? ? text, ? state ? ? ? ? ? ? ? ?varchar(1), ? primary key (comp_id));/*==============================================================*//* Table: complain_reply ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?*//*==============================================================*/create table complain_reply( ? reply_id ? ? ? ? ? ? varchar(32) not null, ? comp_id ? ? ? ? ? ? ?varchar(32) not null, ? replyer ? ? ? ? ? ? ?varchar(20), ? reply_dept ? ? ? ? ? varchar(100), ? reply_time ? ? ? ? ? datetime, ? reply_content ? ? ? ?varchar(300), ? primary key (reply_id));alter table complain_reply add constraint FK_comp_reply foreign key (comp_id) ? ? ?references complain (comp_id) on delete restrict on update restrict;
/* DBMS name: ? ? ?MySQL 5.0 ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?*/
/* Created on: ? ? 2017/6/12 19:06:20 ? ? ? ? ? ? ? ? ? ? ? ? ? */
/*==============================================================*/


drop table if exists complain;

drop table if exists complain_reply;

/*==============================================================*/
/* Table: complain ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?*/
/*==============================================================*/
create table complain
(
? comp_id ? ? ? ? ? ? ?varchar(32) not null,
? comp_company ? ? ? ? varchar(100),
? comp_name ? ? ? ? ? ?varchar(20),
? comp_mobile ? ? ? ? ?varchar(20),
? is_NM ? ? ? ? ? ? ? ?bool,
? comp_time ? ? ? ? ? ?datetime,
? comp_title ? ? ? ? ? varchar(200) not null,
? to_comp_name ? ? ? ? varchar(20),
? to_comp_dept ? ? ? ? varchar(100),
? comp_content ? ? ? ? text,
? state ? ? ? ? ? ? ? ?varchar(1),
? primary key (comp_id)
);

/*==============================================================*/
/* Table: complain_reply ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?*/
/*==============================================================*/
create table complain_reply
(
? reply_id ? ? ? ? ? ? varchar(32) not null,
? comp_id ? ? ? ? ? ? ?varchar(32) not null,
? replyer ? ? ? ? ? ? ?varchar(20),
? reply_dept ? ? ? ? ? varchar(100),
? reply_time ? ? ? ? ? datetime,
? reply_content ? ? ? ?varchar(300),
? primary key (reply_id)
);

alter table complain_reply add constraint FK_comp_reply foreign key (comp_id)
? ? ?references complain (comp_id) on delete restrict on update restrict;

生成實(shí)體與配置文件:

這里寫圖片描述

Intellij idea下生成出來的映射文件是沒有對應(yīng)的關(guān)聯(lián)關(guān)系的。也就是說:一對多或多對多的關(guān)系,它是不會(huì)幫你自動(dòng)生成的【好像是這樣子的】。。。因此,需要我們自己添加Set【如果需要】

? ? ? ?<set name="complainReplies" inverse="true" cascade="save-update,delete" lazy="false" > ? ? ? ? ? ?<key> ? ? ? ? ? ? ? ?<column name="comp_id" length="32" not-null="true" /> ? ? ? ? ? ?</key> ? ? ? ? ? ?<one-to-many class="zhongfucheng.complain.entity.ComplainReply" /> ? ? ? ?</set>
? ? ? ? ? ?<key>
? ? ? ? ? ? ? ?<column name="comp_id" length="32" not-null="true" />
? ? ? ? ? ?</key>
? ? ? ? ? ?<one-to-many class="zhongfucheng.complain.entity.ComplainReply" />
? ? ? ?</set>

編寫dao、service、action

編寫dao、service、action都非常簡單。記得要把模塊的配置文件加載到總配置文件中!

ComplainAction代碼如下:

public class ComplainAction extends BaseAction { ? ?/*************注入Service************************/ ? ?@Autowired ? ?private ComplainService complainServiceImpl; ? ?/************數(shù)據(jù)自動(dòng)封裝,給出setter和getter*************************/ ? ?private Complain complain; ? ?public Complain getComplain() { ? ? ? ?return complain; ? ?} ? ?public void setComplain(Complain complain) { ? ? ? ?this.complain = complain; ? ?} ? ?/************Action中7大方法*************************/ ? ?//拋出Action異常 ? ?public String listUI() throws ServiceException, UnsupportedEncodingException { ? ? ? ?//把狀態(tài)的集合帶過去 ? ? ? ?QueryHelper queryHelper = new QueryHelper(Complain.class, "c"); ? ? ? ?//當(dāng)前頁數(shù)沒有值,那么賦值為1 ? ? ? ?if (currentPageCount == 0) { ? ? ? ? ? ?currentPageCount = 1; ? ? ? ?} ? ? ? ?//把狀態(tài)帶過去給JSP頁面 ? ? ? ?ActionContext.getContext().getContextMap().put("complainStateMap", Complain.COMPLAIN_STATE_MAP); ? ? ? ?pageResult = complainServiceImpl.getPageResult(queryHelper,currentPageCount); ? ? ? ?return "listUI"; ? ?}}class ComplainAction extends BaseAction {

? ?/*************注入Service************************/
? ?@Autowired
? ?private ComplainService complainServiceImpl;
? ?/************數(shù)據(jù)自動(dòng)封裝,給出setter和getter*************************/
? ?private Complain complain;
? ?public Complain getComplain() {
? ? ? ?return complain;
? ?}
? ?public void setComplain(Complain complain) {
? ? ? ?this.complain = complain;
? ?}

? ?/************Action中7大方法*************************/
? ?//拋出Action異常
? ?public String listUI() throws ServiceException, UnsupportedEncodingException {

? ? ? ?//把狀態(tài)的集合帶過去
? ? ? ?QueryHelper queryHelper = new QueryHelper(Complain.class, "c");

? ? ? ?//當(dāng)前頁數(shù)沒有值,那么賦值為1
? ? ? ?if (currentPageCount == 0) {
? ? ? ? ? ?currentPageCount = 1;
? ? ? ?}
? ? ? ?//把狀態(tài)帶過去給JSP頁面
? ? ? ?ActionContext.getContext().getContextMap().put("complainStateMap", Complain.COMPLAIN_STATE_MAP);
? ? ? ?pageResult = complainServiceImpl.getPageResult(queryHelper,currentPageCount);
? ? ? ?return "listUI";
? ?}

}

導(dǎo)入對應(yīng)的JSP頁面…..得到的效果如下:

這里寫圖片描述

條件查詢

我們來看一下條件查詢有幾個(gè):可以根據(jù)投訴的標(biāo)題、投訴的時(shí)間、投訴的狀態(tài)進(jìn)行查詢。

這里寫圖片描述

對于投訴標(biāo)題和投訴的狀態(tài)我們都可以很容易地拿到條件:

? ? ? ?//根據(jù)complain標(biāo)題是否為null來判斷是否是條件查詢。如果complain為空,那么是查詢所有。 ? ? ? ?if (complain != null) { ? ? ? ? ? ?if (org.apache.commons.lang.StringUtils.isNotBlank(complain.getCompTitle())) { ? ? ? ? ? ? ? ?selectCondition = ?URLDecoder.decode(complain.getCompTitle(),"UTF-8"); ? ? ? ? ? ? ? ?complain.setCompTitle(selectCondition); ? ? ? ? ? ? ? ?queryHelper.addCondition(" c.compTitle like ? ", "%" + complain.getCompTitle() + "%"); ? ? ? ? ? ?} ? ? ? ? ? ?//投訴狀態(tài)并不需要編碼,因?yàn)樗⒉皇侵形摹?? ? ? ? ? ?if (org.apache.commons.lang.StringUtils.isNotBlank(complain.getState())) { ? ? ? ? ? ? ? ?queryHelper.addCondition(" c.state like ? ", "%" + complain.getState() + "%"); ? ? ? ? ? ?} ? ? ? ?}
? ? ? ?if (complain != null) {
? ? ? ? ? ?if (org.apache.commons.lang.StringUtils.isNotBlank(complain.getCompTitle())) {
? ? ? ? ? ? ? ?selectCondition = ?URLDecoder.decode(complain.getCompTitle(),"UTF-8");
? ? ? ? ? ? ? ?complain.setCompTitle(selectCondition);
? ? ? ? ? ? ? ?queryHelper.addCondition(" c.compTitle like ? ", "%" + complain.getCompTitle() + "%");
? ? ? ? ? ?}
? ? ? ? ? ?//投訴狀態(tài)并不需要編碼,因?yàn)樗⒉皇侵形摹?/span>
? ? ? ? ? ?if (org.apache.commons.lang.StringUtils.isNotBlank(complain.getState())) {
? ? ? ? ? ? ? ?queryHelper.addCondition(" c.state like ? ", "%" + complain.getState() + "%");
? ? ? ? ? ?}
? ? ? ?}

那么根據(jù)投訴時(shí)間來進(jìn)行查詢,我們要怎么做呢???我們約定時(shí)間是這樣的格式:yyyy-MM-dd HH:mm。這樣的格式Struts2默認(rèn)是不支持解析的,那么我們怎么獲取呢???

有的同學(xué)可能會(huì)想到類型轉(zhuǎn)換器,我們在Struts2的時(shí)候的確是學(xué)過類型轉(zhuǎn)換器。。。但是呢,這種方法并不是最好的。我們可以使用DateUtils工具類來得到日期數(shù)據(jù)!

? ?//先判斷時(shí)間,通過時(shí)間進(jìn)行篩選后,再進(jìn)行l(wèi)ike模糊查詢。那么性能會(huì)好一些 ? ?if (StringUtils.isNotBlank(startTime)) { ? ? ? ?startTime = ?URLDecoder.decode(startTime,"UTF-8"); ? ? ? ?queryHelper.addCondition(" c.compTime >= ? ", DateUtils.parseDate(startTime, new String[]{"yyyy-MM-dd HH:mm"})); ? ?} ? ?if (StringUtils.isNotBlank(endTime)) { ? ? ? ?endTime = ?URLDecoder.decode(endTime,"UTF-8"); ? ? ? ?queryHelper.addCondition(" c.compTime <= ? ", DateUtils.parseDate(endTime, new String[]{"yyyy-MM-dd HH:mm"})); ? ?}
? ?if (StringUtils.isNotBlank(startTime)) {
? ? ? ?startTime = ?URLDecoder.decode(startTime,"UTF-8");
? ? ? ?queryHelper.addCondition(" c.compTime >= ? ", DateUtils.parseDate(startTime, new String[]{"yyyy-MM-dd HH:mm"}));
? ?}

? ?if (StringUtils.isNotBlank(endTime)) {
? ? ? ?endTime = ?URLDecoder.decode(endTime,"UTF-8");
? ? ? ?queryHelper.addCondition(" c.compTime <= ? ", DateUtils.parseDate(endTime, new String[]{"yyyy-MM-dd HH:mm"}));
? ?}

我們在JSP頁面上也使用datepicker組件來讓用戶選擇日期

? ? ? 投訴時(shí)間:<s:textfield id="startTime" name="startTime" cssClass="s_text" ?cssStyle="width:160px;" readonly="true" onfocus="WdatePicker({'skin':'whyGreen','dateFmt':'yyyy-MM-dd HH:mm'});"/> ? ? ? ? ?- ? ? ? ? <s:textfield id="endTime" name="endTime" cssClass="s_text" ?cssStyle="width:160px;" readonly="true" onfocus="WdatePicker({'skin':'whyGreen','dateFmt':'yyyy-MM-dd HH:mm'});"/>
? ? ? ? ?-
? ? ? ? <s:textfield id="endTime" name="endTime" cssClass="s_text" ?cssStyle="width:160px;" readonly="true" onfocus="WdatePicker({'skin':'whyGreen','dateFmt':'yyyy-MM-dd HH:mm'});"/>

受理回復(fù)

提供處理受理的UI界面。根據(jù)id查找投訴的全部信息。

? ?//提供受理的UI ? ?public String dealUI() { ? ? ? ?//把狀態(tài)傳遞過去 ? ? ? ?ActionContext.getContext().getContextMap().put("complainStateMap", Complain.COMPLAIN_STATE_MAP); ? ? ? ?//得到想要受理的記錄 ? ? ? ?if (complain != null) { ? ? ? ? ? ?complain = complainServiceImpl.findObjectById(complain.getCompId()); ? ? ? ?} ? ? ? ?return "dealUI"; ? ?}
? ?public String dealUI() {

? ? ? ?//把狀態(tài)傳遞過去
? ? ? ?ActionContext.getContext().getContextMap().put("complainStateMap", Complain.COMPLAIN_STATE_MAP);

? ? ? ?//得到想要受理的記錄
? ? ? ?if (complain != null) {
? ? ? ? ? ?complain = complainServiceImpl.findObjectById(complain.getCompId());
? ? ? ?}
? ? ? ?return "dealUI";
? ?}

在處理受理的JSP頁面上要把投訴的id給發(fā)送給Action處理。不然在保存信息的時(shí)候,就會(huì)把投訴信息丟失了!。在Action中通過id重新查找回投訴的信息!

? ?//受理 ? ?public String deal() { ? ? ? ?//修改投訴信息的處理狀態(tài) ? ? ? ?if (complain != null) { ? ? ? ? ? ?//查找到信息 ? ? ? ? ? ?complain = complainServiceImpl.findObjectById(complain.getCompId()); ? ? ? ? ? ?//如果狀態(tài)是已處理了,那么就不用再修改了 ? ? ? ? ? ?if (!complain.getState().equals(Complain.COMPLAIN_STATE_DONE)) { ? ? ? ? ? ? ? ?complain.setState(Complain.COMPLAIN_STATE_DONE); ? ? ? ? ? ?} ? ? ? ?} ? ? ? ?//保存回復(fù)的信息 ? ? ? ?if (reply != null) { ? ? ? ? ? ?//更新回復(fù)的日期 ? ? ? ? ? ?reply.setReplyTime(new Timestamp(new Date().getTime())); ? ? ? ? ? ?//把回復(fù)信息添加到投訴信息中【關(guān)聯(lián)關(guān)系】 ? ? ? ? ? ?reply.setComplain(complain); ? ? ? ? ? ?complain.getComplainReplies().add(reply); ? ? ? ?} ? ? ? ?//級聯(lián)更新 ? ? ? ?complainServiceImpl.update(complain); ? ? ? ?return "list"; ? ?}
? ?public String deal() {

? ? ? ?//修改投訴信息的處理狀態(tài)
? ? ? ?if (complain != null) {
? ? ? ? ? ?//查找到信息
? ? ? ? ? ?complain = complainServiceImpl.findObjectById(complain.getCompId());
? ? ? ? ? ?//如果狀態(tài)是已處理了,那么就不用再修改了
? ? ? ? ? ?if (!complain.getState().equals(Complain.COMPLAIN_STATE_DONE)) {
? ? ? ? ? ? ? ?complain.setState(Complain.COMPLAIN_STATE_DONE);
? ? ? ? ? ?}
? ? ? ?}
? ? ? ?//保存回復(fù)的信息
? ? ? ?if (reply != null) {
? ? ? ? ? ?//更新回復(fù)的日期
? ? ? ? ? ?reply.setReplyTime(new Timestamp(new Date().getTime()));

? ? ? ? ? ?//把回復(fù)信息添加到投訴信息中【關(guān)聯(lián)關(guān)系】
? ? ? ? ? ?reply.setComplain(complain);
? ? ? ? ? ?complain.getComplainReplies().add(reply);
? ? ? ?}

? ? ? ?//級聯(lián)更新
? ? ? ?complainServiceImpl.update(complain);

? ? ? ?return "list";
? ?}

顯示回復(fù)信息

我們在處理投訴的時(shí)候,應(yīng)該把回復(fù)的歷史信息給處理的人看…..

把回復(fù)的信息遍歷出來。

? ? ? ?<s:iterator value="complain.complainReplies" status="st"> ? ? ? ?<tr> ? ? ? ? ? ?<%--得到所有回復(fù)的信息--%> ? ? ? ? ? ?<td colspan="2"> ? ? ? ? ? ? ? ? ? ?<fieldset style="border: solid 1px #c0c0c0;margin-top:5px;"><legend style="color:green;font-weight:bold;"> ? ? ? ? ? ? ? ? ? ? ? ?回復(fù)<s:property ? ? ? ? ? ? ? ? ? ? ? ? ? ?value="#st.count"/> &nbsp;</legend> ? ? ? ? ? ? ? ? ? ? ? ?<div style="width:100%; text-align:center;color:#ccc;maring-top:5px;"> ? ? ? ? ? ? ? ? ? ? ? ?回復(fù)部門:<s:property value="replyDept"/> ? ? ? ? ? ? ? ? ? ? ? ?回復(fù)人:<s:property value="replyer"/> ? ? ? ? ? ? ? ? ? ? ? ?回復(fù)時(shí)間:<s:date name="replyTime" format="yyyy-MM-dd HH:mm"/> ? ? ? ? ? ? ? ? ? ? ? ?</div> ? ? ? ? ? ? ? ? ? ? ? ?<div style="width:100%;maring-top:10px;font-size:13px;padding-left:5px;"><s:property value="replyContent"/></div> ? ? ? ? ? ? ? ? ? ?</fieldset> ? ? ? ? ? ?</td> ? ? ? ?</tr> ? ? ? ?</s:iterator>
? ? ? ?<tr>
? ? ? ? ? ?<%--得到所有回復(fù)的信息--%>

? ? ? ? ? ?<td colspan="2">

? ? ? ? ? ? ? ? ? ?<fieldset style="border: solid 1px #c0c0c0;margin-top:5px;"><legend style="color:green;font-weight:bold;">
? ? ? ? ? ? ? ? ? ? ? ?回復(fù)<s:property
? ? ? ? ? ? ? ? ? ? ? ? ? ?value="#st.count"/>
&nbsp;</legend>
? ? ? ? ? ? ? ? ? ? ? ?<div style="width:100%; text-align:center;color:#ccc;maring-top:5px;">
? ? ? ? ? ? ? ? ? ? ? ?回復(fù)部門:<s:property value="replyDept"/>
? ? ? ? ? ? ? ? ? ? ? ?回復(fù)人:<s:property value="replyer"/>
? ? ? ? ? ? ? ? ? ? ? ?回復(fù)時(shí)間:<s:date name="replyTime" format="yyyy-MM-dd HH:mm"/>
? ? ? ? ? ? ? ? ? ? ? ?</div>
? ? ? ? ? ? ? ? ? ? ? ?<div style="width:100%;maring-top:10px;font-size:13px;padding-left:5px;"><s:property value="replyContent"/></div>
? ? ? ? ? ? ? ? ? ?</fieldset>

? ? ? ? ? ?</td>
? ? ? ?</tr>
? ? ? ?</s:iterator>

現(xiàn)在有一個(gè)問題,就是我們使用的是set集合,它所有的回復(fù)信息并不是按照順序來排列的。我們可以在hbm配置文件中指定我們set集合的順序

這里寫圖片描述

那么在顯示的時(shí)候,我們的回復(fù)順序就不會(huì)被搞亂了。

匿名投訴

在需求中,我們已經(jīng)看到了,如果投訴的人是匿名投訴的,那么我們不能顯示該投訴人的名字、部門。他的號碼應(yīng)該設(shè)置成1372342類型的

其實(shí)我們只要在顯示對應(yīng)值的前面判斷該投訴人是否是匿名投訴就行了。

? ? ? ?<td> ? ? ? ? ? ?<s:if test="%{complain.isNm==0}"> ? ? ? ? ? ? ? ?<%--138****2342類型--%> ? ? ? ? ? ? ? ?<s:property value="complain.compMobile"/> ? ? ? ? ? ?</s:if> ? ? ? ? ? ?<s:else> ? ? ? ? ? ? ? ?<s:property value="%{complain.compMobile.substring(0,3)+'****'+complain.compMobile.substring(7,11)}"/> ? ? ? ? ? ?</s:else> ? ? ? ?</td>
? ? ? ? ? ?<s:if test="%{complain.isNm==0}">
? ? ? ? ? ? ? ?<%--138****2342類型--%>
? ? ? ? ? ? ? ?<s:property value="complain.compMobile"/>
? ? ? ? ? ?</s:if>
? ? ? ? ? ?<s:else>
? ? ? ? ? ? ? ?<s:property value="%{complain.compMobile.substring(0,3)+'****'+complain.compMobile.substring(7,11)}"/>
? ? ? ? ? ?</s:else>
? ? ? ?</td>

我要投訴二級聯(lián)動(dòng)

用戶可以在首頁上通過“我要投訴”超鏈接對工作人員進(jìn)行投訴..當(dāng)然了,用戶點(diǎn)擊“我要投訴”超鏈接的時(shí)候,應(yīng)該在新的頁面上給出對應(yīng)的頁面,所以指定target為“_blank”..

我們在指定部門的時(shí)候,下拉菜單應(yīng)該在后臺(tái)給出對應(yīng)的的員工。這就需要我們用到ajax進(jìn)行二級菜單的二級聯(lián)動(dòng)了。

我們在返回JSON格式有兩種方式:第一種就是沒有使用Struts2框架的時(shí)候,
使用三個(gè)開發(fā)包c(diǎn)ommons-beanutils-1.8.0,ezmorph-1.0.6,json-lib-2.3-jdk15。使用JSONObject對象來構(gòu)建JSON字符串,使用流對象返回給瀏覽器。

我們?nèi)绻褂昧薙truts2框架的話,直接導(dǎo)入:struts2-json-plugin-2.3.20這么一個(gè)開發(fā)包,并且在配置文件中指定繼承json-defalut包,返回的類型是JSON的話。那么Struts2框架就會(huì)自動(dòng)幫我們在該Action中所擁有g(shù)etter方法的屬性就生成JSON格式返回給瀏覽器。。。當(dāng)然了,我們可能不想Struts2把全部帶有g(shù)etter的屬性都生成JSON返回給瀏覽器,我們只要在返回JSON類型上指定參數(shù)root,就可以指定生成哪一個(gè)屬性自動(dòng)生成JSON字符串返回給瀏覽器了。

這里寫圖片描述

當(dāng)然了,無論是沒有使用Struts2框架,還是有使用Struts2框架,我們都是有過Demo的。詳情請參考博文:http://blog.csdn.net/hon_3y/article/details/72468761和http://blog.csdn.net/hon_3y/article/details/72480126

另外,我們手動(dòng)訪問Acttion給出對應(yīng)的參數(shù),就可以看到服務(wù)器返回的JSON是什么了。最后我們使用HiJson這樣的工具,就可以把返回的JSON進(jìn)行格式化。

這里寫圖片描述

那么,我們的代碼是這樣的:

使用ajax返回服務(wù)器。

? ? ? ?function doSelectDept() { ? ? ? ? ? ?var $dept = $("#toCompDept option:selected").val(); ? ? ? ? ? ?//初始化清空 ? ? ? ? ? if($dept =="0"){ ? ? ? ? ? ? ? $("#toCompName").empty(); ? ? ? ? ? ?} ? ? ? ? ? ?$.ajax({ ? ? ? ? ? ? ? ?type: "post", ? ? ? ? ? ? ? ?url: "${basePath}sys/home_getUserJson.action", ? ? ? ? ? ? ? ?data: {"dept":$dept}, ? ? ? ? ? ? ? ?dataType: "json", ? ? ? ? ? ? ? ?success: function (data) { ? ? ? ? ? ? ? ? ? ?if("success" == data.msg){ ? ? ? ? ? ? ? ? ? ? ? ?var toCompName = $("#toCompName"); ? ? ? ? ? ? ? ? ? ? ? ?toCompName.empty(); ? ? ? ? ? ? ? ? ? ? ? ?$.each(data.userList, function(index, user){ ? ? ? ? ? ? ? ? ? ? ? ? ? ?toCompName.append("<option value='" + user.name + "'>" + user.name + "</option>"); ? ? ? ? ? ? ? ? ? ? ? ?}); ? ? ? ? ? ? ? ? ? ?} else {alert("獲取被投訴人列表失敗!");} ? ? ? ? ? ? ? ?}, ? ? ? ? ? ? ? ?error: function () { ? ? ? ? ? ? ? ? ? ?alert("失敗咯") ? ? ? ? ? ? ? ?} ? ? ? ? ? ?}); ? ? ? ?}
? ? ? ? ? ?var $dept = $("#toCompDept option:selected").val();

? ? ? ? ? ?//初始化清空
? ? ? ? ? if($dept =="0"){
? ? ? ? ? ? ? $("#toCompName").empty();
? ? ? ? ? ?}

? ? ? ? ? ?$.ajax({
? ? ? ? ? ? ? ?type: "post",
? ? ? ? ? ? ? ?url: "${basePath}sys/home_getUserJson.action",
? ? ? ? ? ? ? ?data: {"dept":$dept},
? ? ? ? ? ? ? ?dataType: "json",
? ? ? ? ? ? ? ?success: function (data) {
? ? ? ? ? ? ? ? ? ?if("success" == data.msg){
? ? ? ? ? ? ? ? ? ? ? ?var toCompName = $("#toCompName");
? ? ? ? ? ? ? ? ? ? ? ?toCompName.empty();
? ? ? ? ? ? ? ? ? ? ? ?$.each(data.userList, function(index, user){
? ? ? ? ? ? ? ? ? ? ? ? ? ?toCompName.append("<option value='" + user.name + "'>" + user.name + "</option>");
? ? ? ? ? ? ? ? ? ? ? ?});
? ? ? ? ? ? ? ? ? ?} else {alert("獲取被投訴人列表失敗!");}
? ? ? ? ? ? ? ?},
? ? ? ? ? ? ? ?error: function () {
? ? ? ? ? ? ? ? ? ?alert("失敗咯")
? ? ? ? ? ? ? ?}
? ? ? ? ? ?});
? ? ? ?}

使用一個(gè)Map集合裝載這些數(shù)據(jù),Struts2自動(dòng)把Map集合的數(shù)據(jù)轉(zhuǎn)成是JSON格式的,返回給瀏覽器。

? ?private Map<String, Object> return_map; ? ?public Map<String, Object> getReturn_map() { ? ? ? ?return return_map; ? ?} ? ? ?public String getUserJson() { ? ? ? ? ? ?//得到帶過來的dept ? ? ? ? ? ?String dept = ServletActionContext.getRequest().getParameter("dept"); ? ? ? ? ? ?if (dept != null) { ? ? ? ? ? ? ? ?//根據(jù)部門查詢所有的員工 ? ? ? ? ? ? ? ?QueryHelper queryHelper = new QueryHelper(User.class, "u"); ? ? ? ? ? ? ? ?queryHelper.addCondition(" u.dept like ? ", "%" +dept); ? ? ? ? ? ? ? ?//2、根據(jù)部門查詢用戶列表 ? ? ? ? ? ? ? ?return_map = new HashMap(); ? ? ? ? ? ? ? ?return_map.put("msg", "success"); ? ? ? ? ? ? ? ?return_map.put("userList", userServiceImpl.findObjects(queryHelper)); ? ? ? ? ? ?} ? ? ? ? ? ?return "success"; ? ? ? ?}

? ?public Map<String, Object> getReturn_map() {
? ? ? ?return return_map;
? ?}

? ? ?public String getUserJson() {
? ? ? ? ? ?//得到帶過來的dept
? ? ? ? ? ?String dept = ServletActionContext.getRequest().getParameter("dept");
? ? ? ? ? ?if (dept != null) {
? ? ? ? ? ? ? ?//根據(jù)部門查詢所有的員工
? ? ? ? ? ? ? ?QueryHelper queryHelper = new QueryHelper(User.class, "u");
? ? ? ? ? ? ? ?queryHelper.addCondition(" u.dept like ? ", "%" +dept);

? ? ? ? ? ? ? ?//2、根據(jù)部門查詢用戶列表
? ? ? ? ? ? ? ?return_map = new HashMap();
? ? ? ? ? ? ? ?return_map.put("msg", "success");
? ? ? ? ? ? ? ?return_map.put("userList", userServiceImpl.findObjects(queryHelper));
? ? ? ? ? ?}

? ? ? ? ? ?return "success";
? ? ? ?}

我要投訴保存信息

我們在投訴的內(nèi)容上添加上富文本框,讓用戶可以在文本域上傳上圖片….

加上一個(gè)富文本框是非常簡單的,只要導(dǎo)入對應(yīng)的js文件,在textarea上寫上ueditor的id就可以完成效果了。。。

? ?<script type="text/javascript" charset="utf-8" src="${basePath}js/ueditor/ueditor.config.js"></script> ? ?<script type="text/javascript" charset="utf-8" src="${basePath}js/ueditor/ueditor.all.min.js"> </script> ? ?<script type="text/javascript" charset="utf-8" src="${basePath}js/ueditor/lang/zh-cn/zh-cn.js"></script> ? ?<script type="text/javascript"> ? ? ? ?//配置ueditor的根路徑 ? ? ? ?var UEDITOR_HOME_URL = "${basePath}js/ueditor/"; ? ? ? ?var ue = UE.getEditor('editor'); ? ?</script> ? ? <td><s:textarea id="editor" name="comp.compContent" cssStyle="width:90%;height:160px;"/></td>"utf-8" src="${basePath}js/ueditor/ueditor.config.js"></script>
? ?<script type="text/javascript" charset="utf-8" src="${basePath}js/ueditor/ueditor.all.min.js"> </script>
? ?<script type="text/javascript" charset="utf-8" src="${basePath}js/ueditor/lang/zh-cn/zh-cn.js"></script>
? ?<script type="text/javascript">
? ? ? ?//配置ueditor的根路徑
? ? ? ?var UEDITOR_HOME_URL = "${basePath}js/ueditor/";
? ? ? ?var ue = UE.getEditor('editor');
? ?</script>

? ? <td><s:textarea id="editor" name="comp.compContent" cssStyle="width:90%;height:160px;"/></td>

再次觀察我們的投訴頁面,表單里面的值只有是被投訴人的信息,投訴人的信息是沒有的。于是我們在表單中把投訴人的信息通過隱藏域?qū)⑵涮砑舆M(jìn)去….

? ?<s:hidden name="comp.compCompany" value="%{#session.SYS_USER.dept}"></s:hidden> ? ?<s:hidden name="comp.compName" value="%{#session.SYS_USER.name}"></s:hidden> ? ?<s:hidden name="comp.compMobile" value="%{#session.SYS_USER.mobile}"></s:hidden></s:hidden>
? ?<s:hidden name="comp.compName" value="%{#session.SYS_USER.name}"></s:hidden>
? ?<s:hidden name="comp.compMobile" value="%{#session.SYS_USER.mobile}"></s:hidden>

那我們保存“我要投訴”信息的流程應(yīng)該是怎么樣的呢???為了達(dá)到更好的用戶體驗(yàn),我們應(yīng)該先把提示用戶數(shù)據(jù)已經(jīng)保存起來了,然后刷新父窗口,接著把“我要投訴”本頁面給關(guān)閉了。這樣用戶看起來,就覺得他的操作已經(jīng)是成功了!

下面是整個(gè)“我要投訴”操作的時(shí)序圖:

這里寫圖片描述

代碼:

? ?public void saveComplain() { ? ? ? ?try { ? ? ? ? ? ?if (comp != null) { ? ? ? ? ? ? ? ?//把投訴的缺少的信息補(bǔ)全 ? ? ? ? ? ? ? ?comp.setState(Complain.COMPLAIN_STATE_UNDONE); ? ? ? ? ? ? ? ?comp.setCompTime(new Timestamp(new Date().getTime())); ? ? ? ? ? ? ? ?//調(diào)用service保存 ? ? ? ? ? ? ? ?complainServiceImpl.save(comp); ? ? ? ? ? ? ? ?//告訴瀏覽器保存信息成功了。 ? ? ? ? ? ? ? ?ServletActionContext.getResponse().getWriter().write("success"); ? ? ? ? ? ?} ? ? ? ?} catch (IOException e) { ? ? ? ? ? ?e.printStackTrace(); ? ? ? ?} ? ?}

? ? ? ?try {
? ? ? ? ? ?if (comp != null) {
? ? ? ? ? ? ? ?//把投訴的缺少的信息補(bǔ)全
? ? ? ? ? ? ? ?comp.setState(Complain.COMPLAIN_STATE_UNDONE);
? ? ? ? ? ? ? ?comp.setCompTime(new Timestamp(new Date().getTime()));

? ? ? ? ? ? ? ?//調(diào)用service保存
? ? ? ? ? ? ? ?complainServiceImpl.save(comp);

? ? ? ? ? ? ? ?//告訴瀏覽器保存信息成功了。
? ? ? ? ? ? ? ?ServletActionContext.getResponse().getWriter().write("success");
? ? ? ? ? ?}
? ? ? ?} catch (IOException e) {
? ? ? ? ? ?e.printStackTrace();
? ? ? ?}


? ?}

提示用戶已經(jīng)投訴成功,把父窗口刷新,本頁面關(guān)閉。

function saveComplain() { ? ? ? ? ? ?$.ajax({ ? ? ? ? ? ? ? ?url: "${basePath}sys/home_saveComplain.action", ? ? ? ? ? ? ? ?/*將整個(gè)表單的屬性轉(zhuǎn)成是JSON*/ ? ? ? ? ? ? ? ?data: $("form").serialize(), ? ? ? ? ? ? ? ?type: "post", ? ? ? ? ? ? ? ?success: function (backdata) { ? ? ? ? ? ? ? ? ? ?if(backdata == "success"){ ? ? ? ? ? ? ? ? ? ? ? ?//告訴用戶,保存成功了。 ? ? ? ? ? ? ? ? ? ? ? ?alert("投訴成功!!!"); ? ? ? ? ? ? ? ? ? ? ? ?//把父窗口刷新 ? ? ? ? ? ? ? ? ? ? ? ?window.opener.parent.location.reload(true); ? ? ? ? ? ? ? ? ? ? ? ?//把本頁面關(guān)閉 ? ? ? ? ? ? ? ? ? ? ? ?window.close(); ? ? ? ? ? ? ? ? ? ?} ? ? ? ? ? ? ? ?}, ? ? ? ? ? ? ? ?error:function () { ? ? ? ? ? ? ? ? ? ?alert("保存投訴信息失敗了!"); ? ? ? ? ? ? ? ?} ? ? ? ? ? ?}); ? ? ? ?}
? ? ? ? ? ?$.ajax({
? ? ? ? ? ? ? ?url: "${basePath}sys/home_saveComplain.action",
? ? ? ? ? ? ? ?/*將整個(gè)表單的屬性轉(zhuǎn)成是JSON*/
? ? ? ? ? ? ? ?data: $("form").serialize(),
? ? ? ? ? ? ? ?type: "post",
? ? ? ? ? ? ? ?success: function (backdata) {

? ? ? ? ? ? ? ? ? ?if(backdata == "success"){
? ? ? ? ? ? ? ? ? ? ? ?//告訴用戶,保存成功了。
? ? ? ? ? ? ? ? ? ? ? ?alert("投訴成功!!!");
? ? ? ? ? ? ? ? ? ? ? ?//把父窗口刷新
? ? ? ? ? ? ? ? ? ? ? ?window.opener.parent.location.reload(true);
? ? ? ? ? ? ? ? ? ? ? ?//把本頁面關(guān)閉
? ? ? ? ? ? ? ? ? ? ? ?window.close();
? ? ? ? ? ? ? ? ? ?}

? ? ? ? ? ? ? ?},
? ? ? ? ? ? ? ?error:function () {
? ? ? ? ? ? ? ? ? ?alert("保存投訴信息失敗了!");
? ? ? ? ? ? ? ?}
? ? ? ? ? ?});


? ? ? ?}

投訴受理的三圈問題

在信息管理模塊的時(shí)候,我們就提出了三圈的問題了。何為三圈問題呢???就是當(dāng)我們使用條件查詢出數(shù)據(jù)的時(shí)候,再對查詢出的數(shù)據(jù)進(jìn)行操作【修改、保存】,當(dāng)保存完之后回到列表顯示頁面上的時(shí)候,查詢條件就會(huì)丟失掉了。也就是說,我們原來查詢出的數(shù)據(jù)不見了。

首先,我們在Action中使用兩個(gè)變量把有可能成為查詢條件的變量記住:

? ?/************三圈問題數(shù)據(jù)回顯*************************/ ? ?private String compTitle; ? ?private String state; ? ?public String getCompTitle() { ? ? ? ?return compTitle; ? ?} ? ?public void setCompTitle(String compTitle) { ? ? ? ?this.compTitle = compTitle; ? ?} ? ?public String getState() { ? ? ? ?return state; ? ?} ? ?public void setState(String state) { ? ? ? ?this.state = state; ? ?}
? ?private String compTitle;
? ?private String state;
? ?public String getCompTitle() {
? ? ? ?return compTitle;
? ?}
? ?public void setCompTitle(String compTitle) {
? ? ? ?this.compTitle = compTitle;
? ?}
? ?public String getState() {
? ? ? ?return state;
? ?}
? ?public void setState(String state) {
? ? ? ?this.state = state;
? ?}

接著,在跳轉(zhuǎn)到處理投訴頁面的JSP上的時(shí)候,把查詢條件的數(shù)據(jù)查詢出來,把它賦值給變量。然后使用request域?qū)ο蟀褦?shù)據(jù)發(fā)給JSP頁面

? ? ? ? ? ?//把查詢條件帶過去給JSP頁面 ? ? ? ? ? ?ActionContext.getContext().getContextMap().put("compTitle", complain.getCompTitle()); ? ? ? ? ? ?ActionContext.getContext().getContextMap().put("state", complain.getState()); ? ? ? ? ? ?ActionContext.getContext().getContextMap().put("startTime", startTime); ? ? ? ? ? ?ActionContext.getContext().getContextMap().put("endTime", endTime);
? ? ? ? ? ?ActionContext.getContext().getContextMap().put("compTitle", complain.getCompTitle());
? ? ? ? ? ?ActionContext.getContext().getContextMap().put("state", complain.getState());
? ? ? ? ? ?ActionContext.getContext().getContextMap().put("startTime", startTime);
? ? ? ? ? ?ActionContext.getContext().getContextMap().put("endTime", endTime);

然后在處理投訴頁面的JSP上,通過隱藏域把數(shù)據(jù)給回Action。。Action在重定向到listUI頁面的時(shí)候,就通過配置文件,把參數(shù)帶過去:

? ? ? ? ? ?<!--返回列表展示頁面,重定向到列表展示--> ? ? ? ? ? ?<result name="list" type="redirectAction"> ? ? ? ? ? ? ? ?<param name="actionName">complain_listUI</param> ? ? ? ? ? ? ? ?<param name="complain.state">${state}</param> ? ? ? ? ? ? ? ?<param name="complain.compTitle">${compTitle}</param> ? ? ? ? ? ? ? ?<param name="endTime">${startTime}</param> ? ? ? ? ? ? ? ?<param name="startTime">${startTime}</param> ? ? ? ? ? ? ? ?<param name="encode">true</param> ? ? ? ? ? ?</result>
? ? ? ? ? ?<result name="list" type="redirectAction">
? ? ? ? ? ? ? ?<param name="actionName">complain_listUI</param>
? ? ? ? ? ? ? ?<param name="complain.state">${state}</param>
? ? ? ? ? ? ? ?<param name="complain.compTitle">${compTitle}</param>
? ? ? ? ? ? ? ?<param name="endTime">${startTime}</param>
? ? ? ? ? ? ? ?<param name="startTime">${startTime}</param>
? ? ? ? ? ? ? ?<param name="encode">true</param>
? ? ? ? ? ?</result>

這樣一來,我們的查詢條件就沒有丟失了。當(dāng)我們操作完數(shù)據(jù)的時(shí)候,我們的查詢出來的數(shù)據(jù)還是原來那部分。


Quartz自動(dòng)受理

回到我們的需求:

自動(dòng)投訴受理:在每個(gè)月月底最后一天對本月之前的投訴進(jìn)行自動(dòng)處理;將投訴信息的狀態(tài)改為 已失效。在后臺(tái)管理中不能對該類型投訴進(jìn)行回復(fù)。

這個(gè)需求需求我們要怎么弄呢????要在每個(gè)月底最后一天對本月之前的投訴進(jìn)行自動(dòng)處理。。。。

記得我們以前在學(xué)習(xí)Java基礎(chǔ)的時(shí)候?qū)W過了一個(gè)Timer這么一個(gè)類,可以用規(guī)定的頻率來執(zhí)行我們的代碼。。。使用起來是非常簡單的:

這里寫圖片描述這里寫圖片描述

但是呢,要精確到每個(gè)月的月底,這就需要我們?nèi)藶槿ヅ袛鄷r(shí)間了,這就非常不方便了。

因此,我們引入了另一個(gè)非常好用的框架:Quartz


Quartz

這是一個(gè)優(yōu)秀的開源任務(wù)調(diào)度框架“quartz”,可以簡單理解成他是Timer的升級版….Spring集成了該框架…

快速入門

我們要使用它,就要導(dǎo)入其開發(fā)包:quartz-1.8.6.jar,和Spring對其支持的開發(fā)包:org.springframework.context.support-3.0.2.RELEASE

使用它的步驟是十分簡單的,可分成三個(gè)步驟:

1、制定任務(wù)信息 bean

2、制定任務(wù)執(zhí)行時(shí)機(jī)(執(zhí)行觸發(fā)器) bean

3、設(shè)置任務(wù)調(diào)度工廠 bean

jobDetail任務(wù)詳細(xì)信息

1、jobDetail 任務(wù)詳細(xì)信息;包括調(diào)用哪個(gè)類;類中的哪個(gè)方法;執(zhí)行時(shí)是否可并行執(zhí)行任務(wù)

? <!-- 1、制定任務(wù)信息信息 --> ? <bean id="jobDetail1" class="org.springframework.scheduling.quartz.MethodInvokingJobDetailFactoryBean"> ? ? ? ? ? ? ?<!-- 設(shè)置執(zhí)行對象 --> ? ? ? ? ? ? ?<property name="targetObject" ref="quartzTask"></property> ? ? ? ? ? ? ?<!-- 設(shè)置執(zhí)行對象中對應(yīng)的執(zhí)行方法 --> ? ? ? ? ? ? ?<property name="targetMethod" value="doSimpleTriggerTask"></property> ? ? ? ? ? ? ?<!-- 是否可以同步執(zhí)行;不可同步執(zhí)行 --> ? ? ? ? ? ? ?<property name="concurrent" value="false"></property> ? </bean> ? <bean id="jobDetail2" class="org.springframework.scheduling.quartz.MethodInvokingJobDetailFactoryBean"> ? ? ? ? ? ? ?<!-- 設(shè)置執(zhí)行對象 --> ? ? ? ? ? ? ?<property name="targetObject" ref="quartzTask"></property> ? ? ? ? ? ? ?<!-- 設(shè)置執(zhí)行對象中對應(yīng)的執(zhí)行方法 --> ? ? ? ? ? ? ?<property name="targetMethod" value="doCronTriggerTask"></property> ? ? ? ? ? ? ?<!-- 是否可以同步執(zhí)行;不可同步執(zhí)行 --> ? ? ? ? ? ? ?<property name="concurrent" value="false"></property> ? </bean>
? <bean id="jobDetail1" class="org.springframework.scheduling.quartz.MethodInvokingJobDetailFactoryBean">
? ? ? ? ? ? ?<!-- 設(shè)置執(zhí)行對象 -->
? ? ? ? ? ? ?<property name="targetObject" ref="quartzTask"></property>
? ? ? ? ? ? ?<!-- 設(shè)置執(zhí)行對象中對應(yīng)的執(zhí)行方法 -->
? ? ? ? ? ? ?<property name="targetMethod" value="doSimpleTriggerTask"></property>
? ? ? ? ? ? ?<!-- 是否可以同步執(zhí)行;不可同步執(zhí)行 -->
? ? ? ? ? ? ?<property name="concurrent" value="false"></property>
? </bean>
? <bean id="jobDetail2" class="org.springframework.scheduling.quartz.MethodInvokingJobDetailFactoryBean">
? ? ? ? ? ? ?<!-- 設(shè)置執(zhí)行對象 -->
? ? ? ? ? ? ?<property name="targetObject" ref="quartzTask"></property>
? ? ? ? ? ? ?<!-- 設(shè)置執(zhí)行對象中對應(yīng)的執(zhí)行方法 -->
? ? ? ? ? ? ?<property name="targetMethod" value="doCronTriggerTask"></property>
? ? ? ? ? ? ?<!-- 是否可以同步執(zhí)行;不可同步執(zhí)行 -->
? ? ? ? ? ? ?<property name="concurrent" value="false"></property>
? </bean>
這里寫圖片描述

trigger任務(wù)調(diào)度觸發(fā)器

2、trigger 任務(wù)調(diào)度觸發(fā)器;主要用于定義jobDetail什么時(shí)候執(zhí)行。觸發(fā)器最常用的有兩種:簡單觸發(fā)器SimpleTrigger 和 任務(wù)觸發(fā)器CronTrigger 。SimpleTrigger和jdk的timer類似,只能指定任務(wù)執(zhí)行以什么樣的頻率執(zhí)行,但無法制定精確的執(zhí)行時(shí)間。CronTrigger則既可以執(zhí)行簡單觸發(fā)器所制定的以頻率來執(zhí)行的時(shí)間,也可以制定復(fù)雜的時(shí)間計(jì)劃來執(zhí)行

? <!-- 2、制定任務(wù)執(zhí)行時(shí)機(jī)(任務(wù)執(zhí)行觸發(fā)器) --> ? <bean id="simplerTrigger" class="org.springframework.scheduling.quartz.SimpleTriggerBean"> ? ? ? ? ? <!-- 設(shè)置任務(wù)詳細(xì) --> ? ? ? ? ? <property name="jobDetail" ref="jobDetail1"></property> ? ? ? ? ? <!-- 設(shè)置任務(wù)延遲執(zhí)行時(shí)間 ;延遲2秒執(zhí)行--> ? ? ? ? ? <property name="startDelay" value="2000"></property> ? ? ? ? ? <!-- 設(shè)置任務(wù)執(zhí)行頻率;執(zhí)行頻率為每4秒執(zhí)行一下 --> ? ? ? ? ? <property name="repeatInterval" value="2000"></property> ? </bean> ? <bean id="cronTrigger" class="org.springframework.scheduling.quartz.CronTriggerBean"> ? ? ? ?<!-- 設(shè)置任務(wù)詳細(xì) --> ? ? ? ? ? <property name="jobDetail" ref="jobDetail2"></property> ? ? ? ? ? <!-- 設(shè)置任務(wù)執(zhí)行時(shí)機(jī),cron表達(dá)式 --> ? ? ? ? ? <property name="cronExpression" value="* * * 18c * ?"></property> ? </bean>
? <bean id="simplerTrigger" class="org.springframework.scheduling.quartz.SimpleTriggerBean">
? ? ? ? ? <!-- 設(shè)置任務(wù)詳細(xì) -->
? ? ? ? ? <property name="jobDetail" ref="jobDetail1"></property>
? ? ? ? ? <!-- 設(shè)置任務(wù)延遲執(zhí)行時(shí)間 ;延遲2秒執(zhí)行-->
? ? ? ? ? <property name="startDelay" value="2000"></property>
? ? ? ? ? <!-- 設(shè)置任務(wù)執(zhí)行頻率;執(zhí)行頻率為每4秒執(zhí)行一下 -->
? ? ? ? ? <property name="repeatInterval" value="2000"></property>
? </bean>

? <bean id="cronTrigger" class="org.springframework.scheduling.quartz.CronTriggerBean">
? ? ? ?<!-- 設(shè)置任務(wù)詳細(xì) -->
? ? ? ? ? <property name="jobDetail" ref="jobDetail2"></property>
? ? ? ? ? <!-- 設(shè)置任務(wù)執(zhí)行時(shí)機(jī),cron表達(dá)式 -->
? ? ? ? ? <property name="cronExpression" value="* * * 18c * ?"></property>
? </bean>
這里寫圖片描述

這里我們著重要了解表達(dá)式怎么寫:秒 分 時(shí) 日 月 周 年【日和周不能同時(shí)出現(xiàn)】

這里寫圖片描述

schedulerFactory 任務(wù)調(diào)度工廠

schedulerFactory 任務(wù)調(diào)度工廠;用于調(diào)度各個(gè)任務(wù)觸發(fā)器。

任務(wù)調(diào)度工廠可以調(diào)度多個(gè)任務(wù)同時(shí)進(jìn)行

? <!-- 3、設(shè)置調(diào)度工廠 --> ? <bean class="org.springframework.scheduling.quartz.SchedulerFactoryBean"> ? ? ? ? ? <property name="triggers"> ? ? ? ? ? ? ? <list> ? ? ? ? ? ? ? ? ? <!-- <ref bean="simplerTrigger"/> --> ? ? ? ? ? ? ? ? ? <ref bean="cronTrigger"/> ? ? ? ? ? ? ? </list> ? ? ? ? ? </property> ? </bean>
? <bean class="org.springframework.scheduling.quartz.SchedulerFactoryBean">
? ? ? ? ? <property name="triggers">
? ? ? ? ? ? ? <list>
? ? ? ? ? ? ? ? ? <!-- <ref bean="simplerTrigger"/> -->
? ? ? ? ? ? ? ? ? <ref bean="cronTrigger"/>
? ? ? ? ? ? ? </list>
? ? ? ? ? </property>
? </bean>
這里寫圖片描述

自動(dòng)受理

回到我們的需求,我們已經(jīng)大概了解了Quartz這么一個(gè)開源框架使用了。我們就可以在每個(gè)月的最后一天中去執(zhí)行我們對應(yīng)的代碼就行了。

在Spring配置文件中加入Quartz框架….

我們在Service中執(zhí)行對應(yīng)的代碼

? ?<!-- 1、制定任務(wù)信息信息 --> ? ?<bean id="jobDetail1" class="org.springframework.scheduling.quartz.MethodInvokingJobDetailFactoryBean"> ? ? ? ?<!-- 設(shè)置執(zhí)行對象 --> ? ? ? ?<property name="targetObject" ref="complainServiceImpl"></property> ? ? ? ?<!-- 設(shè)置執(zhí)行對象中對應(yīng)的執(zhí)行方法 --> ? ? ? ?<property name="targetMethod" value="doTask"></property> ? ? ? ?<!-- 是否可以同步執(zhí)行;不可同步執(zhí)行 --> ? ? ? ?<property name="concurrent" value="false"></property> ? ?</bean> ? ?<!-- 2、制定任務(wù)執(zhí)行時(shí)機(jī)(任務(wù)執(zhí)行觸發(fā)器) --> ? ?<bean id="cronTrigger" class="org.springframework.scheduling.quartz.CronTriggerBean"> ? ? ? ?<!-- 設(shè)置任務(wù)詳細(xì) --> ? ? ? ?<property name="jobDetail" ref="jobDetail1"></property> ? ? ? ?<!-- 設(shè)置任務(wù)執(zhí)行時(shí)機(jī),cron表達(dá)式 --> ? ? ? ?<property name="cronExpression" value="10 10 2 L * ?"></property> ? ?</bean> ? ?<!-- 3、設(shè)置調(diào)度工廠 --> ? ?<bean class="org.springframework.scheduling.quartz.SchedulerFactoryBean"> ? ? ? ?<property name="triggers"> ? ? ? ? ? ?<list> ? ? ? ? ? ? ? ?<ref bean="cronTrigger"/> ? ? ? ? ? ?</list> ? ? ? ?</property> ? ?</bean></beans>
? ?<bean id="jobDetail1" class="org.springframework.scheduling.quartz.MethodInvokingJobDetailFactoryBean">
? ? ? ?<!-- 設(shè)置執(zhí)行對象 -->
? ? ? ?<property name="targetObject" ref="complainServiceImpl"></property>
? ? ? ?<!-- 設(shè)置執(zhí)行對象中對應(yīng)的執(zhí)行方法 -->
? ? ? ?<property name="targetMethod" value="doTask"></property>
? ? ? ?<!-- 是否可以同步執(zhí)行;不可同步執(zhí)行 -->
? ? ? ?<property name="concurrent" value="false"></property>
? ?</bean>

? ?<!-- 2、制定任務(wù)執(zhí)行時(shí)機(jī)(任務(wù)執(zhí)行觸發(fā)器) -->
? ?<bean id="cronTrigger" class="org.springframework.scheduling.quartz.CronTriggerBean">
? ? ? ?<!-- 設(shè)置任務(wù)詳細(xì) -->
? ? ? ?<property name="jobDetail" ref="jobDetail1"></property>
? ? ? ?<!-- 設(shè)置任務(wù)執(zhí)行時(shí)機(jī),cron表達(dá)式 -->
? ? ? ?<property name="cronExpression" value="10 10 2 L * ?"></property>
? ?</bean>

? ?<!-- 3、設(shè)置調(diào)度工廠 -->
? ?<bean class="org.springframework.scheduling.quartz.SchedulerFactoryBean">
? ? ? ?<property name="triggers">
? ? ? ? ? ?<list>
? ? ? ? ? ? ? ?<ref bean="cronTrigger"/>
? ? ? ? ? ?</list>
? ? ? ?</property>
? ?</bean>
</beans>

查詢出未處理和是本月前的記錄,修改成是失效的。

? ?@Override ? ?public void doTask() { ? ? ? ?//查詢所有待受理的信息 ? ? ? ?QueryHelper queryHelper = new QueryHelper(Complain.class, "c"); ? ? ? ?queryHelper.addCondition(" ?c.state=?", Complain.COMPLAIN_STATE_UNDONE); ? ? ? ?//只要在本月之前 ? ? ? ?Calendar calendar = Calendar.getInstance(); ? ? ? ?calendar.set(Calendar.DAY_OF_MONTH, 1); ? ? ? ?calendar.set(Calendar.HOUR_OF_DAY, 0); ? ? ? ?calendar.set(Calendar.MINUTE, 0); ? ? ? ?calendar.set(Calendar.SECOND, 0); ? ? ? ?queryHelper.addCondition(" c.compTime <?", calendar.getTime()); ? ? ? ?//拿到本月之前所有未處理的數(shù)據(jù) ? ? ? ?List<Complain> complains = findObjects(queryHelper); ? ? ? ?//將數(shù)據(jù)全部改成是失效的了。 ? ? ? ?for (Complain complain : complains) { ? ? ? ? ? ?complain.setState(Complain.COMPLAIN_STATE_INVALID); ? ? ? ?} ? ?}}
? ?public void doTask() {

? ? ? ?//查詢所有待受理的信息
? ? ? ?QueryHelper queryHelper = new QueryHelper(Complain.class, "c");
? ? ? ?queryHelper.addCondition(" ?c.state=?", Complain.COMPLAIN_STATE_UNDONE);

? ? ? ?//只要在本月之前
? ? ? ?Calendar calendar = Calendar.getInstance();
? ? ? ?calendar.set(Calendar.DAY_OF_MONTH, 1);
? ? ? ?calendar.set(Calendar.HOUR_OF_DAY, 0);
? ? ? ?calendar.set(Calendar.MINUTE, 0);
? ? ? ?calendar.set(Calendar.SECOND, 0);
? ? ? ?queryHelper.addCondition(" c.compTime <?", calendar.getTime());

? ? ? ?//拿到本月之前所有未處理的數(shù)據(jù)
? ? ? ?List<Complain> complains = findObjects(queryHelper);

? ? ? ?//將數(shù)據(jù)全部改成是失效的了。
? ? ? ?for (Complain complain : complains) {
? ? ? ? ? ?complain.setState(Complain.COMPLAIN_STATE_INVALID);
? ? ? ?}
? ?}
}

如果已經(jīng)失效了,那么我們就不讓管理員對其進(jìn)行回復(fù)了。

? ? ?<s:if test="state!=2"> <a href="javascript:doDeal('<s:property value='compId'/>')">受理</a></s:if><a href="javascript:doDeal('<s:property value='compId'/>')">受理</a></s:if>
這里寫圖片描述

統(tǒng)計(jì)圖Fusionchart

我們在投訴模塊中還有一個(gè)功能沒有實(shí)現(xiàn):

統(tǒng)計(jì):根據(jù)年度將相應(yīng)年度的每個(gè)月的投訴數(shù)進(jìn)行統(tǒng)計(jì),并以圖表的形式展示在頁面中;在頁面中可以選擇查看當(dāng)前年度及其前4年的投訴數(shù)。在頁面中可以選擇不同的年度,然后頁面展示該年度的曲線統(tǒng)計(jì)圖。

我們到目前為止是沒有學(xué)過任何的統(tǒng)計(jì)圖的工具的,那么我們要怎么解決這個(gè)功能呢???我們有另外的組件來把統(tǒng)計(jì)圖顯示出來:FusionCharts

FusionCharts 是使用javascript 實(shí)現(xiàn)統(tǒng)計(jì)圖表的js組件;其官網(wǎng)地址:http://www.fusioncharts.com。

具體的是怎么操作的可以看官方文檔,我們以項(xiàng)目的需求來完成對應(yīng)的功能就行了。


FusionCharts使用

FusionCharts安裝

首先,我們要把對應(yīng)的JS文檔加入到我們的項(xiàng)目中:

引入Demo

我們只要根據(jù)修改Demo的值就可以實(shí)現(xiàn)出我們想要的效果了。

需求分析

再次回到我們的需求原型圖,我們看看是怎么樣的:

這里寫圖片描述

根據(jù)不同的年份,就顯示出不同的統(tǒng)計(jì)圖數(shù)據(jù)…..這明顯就用到了ajax技術(shù)。 ?因此可以確定下來,我們的前端就是用ajax進(jìn)行交互,渲染出對應(yīng)的統(tǒng)計(jì)圖的。

我們的后端就是根據(jù)不同的年份,去獲取不同的年份每個(gè)月的數(shù)據(jù),返回給瀏覽器

前端分析

我們的需求是得讓我們顯示近5年的統(tǒng)計(jì)圖…于是下拉框是我們近5年的….

我們雖然是可以把option中的數(shù)據(jù)寫死,但是呢,如果過了一年的話,那么我們的數(shù)據(jù)是不會(huì)同步的。當(dāng)我在2017年寫的時(shí)候,到2018年,頁面顯示還是2017年的數(shù)據(jù)….所以這明顯是不合理的….

要想近5年是動(dòng)態(tài)產(chǎn)生的,就不能夠把數(shù)據(jù)寫死….于是我們可以在JSP頁面上得到當(dāng)前年的值,根據(jù)當(dāng)前年就非常容易推出近5年的數(shù)據(jù)了…

于是我們又可以使用到Calendar這個(gè)日歷類了…

在JSP頁面得到當(dāng)前年的數(shù)據(jù),并裝載到list集合中

? ?Calendar calendar = Calendar.getInstance(); ? ?//得到當(dāng)前年的值 ? ?int ?year = calendar.get(Calendar.YEAR); ? ?//把年份用一個(gè)集合裝載 ? ?List yearList = new ArrayList(); ? ?//獲取近5年的值 ? ?for(int i =0; i<5; i++) { ? ? ? ?yearList.add(i, year--); ? ?} ? ?request.setAttribute("yearList", yearList); ? ?request.setAttribute("year", year);
? ?//得到當(dāng)前年的值
? ?int ?year = calendar.get(Calendar.YEAR);

? ?//把年份用一個(gè)集合裝載
? ?List yearList = new ArrayList();

? ?//獲取近5年的值
? ?for(int i =0; i<5; i++) {
? ? ? ?yearList.add(i, year--);
? ?}
? ?request.setAttribute("yearList", yearList);
? ?request.setAttribute("year", year);

在Struts的select標(biāo)簽中把這個(gè)集合迭代出來

<s:select id="year" list="#request.yearList" onchange="doAnnualStatistic()"></s:select></s:select>

下面是我們的效果:

這里寫圖片描述

接著,我們發(fā)現(xiàn)FusionCharts這個(gè)組件,想要把數(shù)據(jù)顯示在統(tǒng)計(jì)圖表中,我們的JSON數(shù)據(jù)的格式是需要這樣的

這里寫圖片描述

還有值得注意的地方是,一進(jìn)入頁面中需要加載當(dāng)前年度的投訴統(tǒng)計(jì)數(shù)

? ?<script> ? ? ? ?//頁面一加載就執(zhí)行方法 ? ? ? ?$(function () { ? ? ? ? ? ?doAnnualStatistic(); ? ? ? ?}); ? ? ? ?//根據(jù)年份獲取投訴數(shù) ? ? ? ?function doAnnualStatistic() { ? ? ? ? ? ?//獲取當(dāng)前年份 ? ? ? ? ? ?var $year = $("#year option:selected").val(); ? ? ? ? ? ?//一進(jìn)來,如果沒有選擇任何的年數(shù),就顯示當(dāng)前年份的 ? ? ? ? ? ?if($year=="" || $year==undefined) { ? ? ? ? ? ? ? $year = "${year}"; ? ? ? ? ? ?} ? ? ? ? ? ?//2、統(tǒng)計(jì)年度投訴數(shù)據(jù)并展示圖表 ? ? ? ? ? ?$.ajax({ ? ? ? ? ? ? ? ?url: "${basePath}complain/complain_getAnnualStatisticData.action", ? ? ? ? ? ? ? ?type: "post", ? ? ? ? ? ? ? ?dataType: "json", ? ? ? ? ? ? ? ?data: {"year",$year}, ? ? ? ? ? ? ? ?success: function (backData) { ? ? ? ? ? ? ? ? ? ?if(backData!=null && backData!=""){ ? ? ? ? ? ? ? ? ? ? ? ?var revenueChart = new FusionCharts({ ? ? ? ? ? ? ? ? ? ? ? ? ? ?"type": "line", ? ? ? ? ? ? ? ? ? ? ? ? ? ?"renderAt": "chartContainer", ? ? ? ? ? ? ? ? ? ? ? ? ? ?"width": "600", ? ? ? ? ? ? ? ? ? ? ? ? ? ?"height": "400", ? ? ? ? ? ? ? ? ? ? ? ? ? ?"dataFormat": "json", ? ? ? ? ? ? ? ? ? ? ? ? ? ?"dataSource": { ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?"chart": { ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?"caption": "年度統(tǒng)計(jì)投訴數(shù)", ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?"xAxisName": "月 ? 份", ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?"yAxisName": "投 ?訴 數(shù)", ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?"theme": "fint" ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?}, ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?"data":backData.chartData ? ? ? ? ? ? ? ? ? ? ? ? ? ?} ? ? ? ? ? ? ? ? ? ? ? ?}); ? ? ? ? ? ? ? ? ? ? ? ?revenueChart.render(); ? ? ? ? ? ? ? ? ? ?} ? ? ? ? ? ? ? ?}, ? ? ? ? ? ? ? ?error:function () { ? ? ? ? ? ? ? ? ? ?alert("統(tǒng)計(jì)投訴數(shù)失敗!"); ? ? ? ? ? ? ? ?} ? ? ? ? ? ?}); ? ? ? ?} ? ?</script>
? ? ? ?//頁面一加載就執(zhí)行方法
? ? ? ?$(function () {
? ? ? ? ? ?doAnnualStatistic();
? ? ? ?});


? ? ? ?//根據(jù)年份獲取投訴數(shù)
? ? ? ?function doAnnualStatistic() {
? ? ? ? ? ?//獲取當(dāng)前年份
? ? ? ? ? ?var $year = $("#year option:selected").val();

? ? ? ? ? ?//一進(jìn)來,如果沒有選擇任何的年數(shù),就顯示當(dāng)前年份的
? ? ? ? ? ?if($year=="" || $year==undefined) {
? ? ? ? ? ? ? $year = "${year}";
? ? ? ? ? ?}
? ? ? ? ? ?//2、統(tǒng)計(jì)年度投訴數(shù)據(jù)并展示圖表
? ? ? ? ? ?$.ajax({
? ? ? ? ? ? ? ?url: "${basePath}complain/complain_getAnnualStatisticData.action",
? ? ? ? ? ? ? ?type: "post",
? ? ? ? ? ? ? ?dataType: "json",
? ? ? ? ? ? ? ?data: {"year",$year},
? ? ? ? ? ? ? ?success: function (backData) {
? ? ? ? ? ? ? ? ? ?if(backData!=null && backData!=""){
? ? ? ? ? ? ? ? ? ? ? ?var revenueChart = new FusionCharts({
? ? ? ? ? ? ? ? ? ? ? ? ? ?"type": "line",
? ? ? ? ? ? ? ? ? ? ? ? ? ?"renderAt": "chartContainer",
? ? ? ? ? ? ? ? ? ? ? ? ? ?"width": "600",
? ? ? ? ? ? ? ? ? ? ? ? ? ?"height": "400",
? ? ? ? ? ? ? ? ? ? ? ? ? ?"dataFormat": "json",
? ? ? ? ? ? ? ? ? ? ? ? ? ?"dataSource": {
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?"chart": {
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?"caption": "年度統(tǒng)計(jì)投訴數(shù)",
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?"xAxisName": "月 ? 份",
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?"yAxisName": "投 ?訴 數(shù)",
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?"theme": "fint"
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?},
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?"data":backData.chartData
? ? ? ? ? ? ? ? ? ? ? ? ? ?}
? ? ? ? ? ? ? ? ? ? ? ?});
? ? ? ? ? ? ? ? ? ? ? ?revenueChart.render();
? ? ? ? ? ? ? ? ? ?}
? ? ? ? ? ? ? ?},
? ? ? ? ? ? ? ?error:function () {
? ? ? ? ? ? ? ? ? ?alert("統(tǒng)計(jì)投訴數(shù)失敗!");
? ? ? ? ? ? ? ?}
? ? ? ? ? ?});
? ? ? ?}
? ?</script>

后端分析

我們的后端就是根據(jù)年份,獲取對應(yīng)的值,返回一個(gè)JSON格式給瀏覽器,那就行了…

但是呢,我們還有其他的細(xì)節(jié)需要考慮:今年是2017年7月,但是在查詢年度投訴數(shù)是要把整個(gè)年的信息查詢出來,8-12月的投訴數(shù)肯定是沒有的。那么我們會(huì)將還沒到的時(shí)間設(shè)置成“”,如果在2016年的某月是沒有投訴數(shù)的,我們應(yīng)該將其替換成0,而不是“"….

在action中,我們得獲取到用戶傳遞過來的年份,我們調(diào)用service、dao層的方法獲取該年度對應(yīng)每個(gè)月的投訴數(shù),轉(zhuǎn)換成JSON格式輸出就行了。

我們知道前端需要的JSON格式是一個(gè)對象數(shù)組,最終目的就是數(shù)組:Struts2框架在最后解析的時(shí)候,會(huì)把集合解析成是數(shù)組。對象數(shù)組在java編程語言就是List集合中嵌套著Map集合。

在后端中,還有一個(gè)難點(diǎn),就是我們的SQL語句該怎么寫????我們要從數(shù)據(jù)庫查詢的是該年份每個(gè)月的投訴數(shù)….

通過該年而查詢每個(gè)月,我們可以很快地想到要用到分組查詢。但是還有一個(gè)問題,我們在進(jìn)行分組查詢的時(shí)候,如果表中是沒有1月或2月等數(shù)組的話,分組查詢出來的數(shù)據(jù)是沒有這些月份的。而我們的統(tǒng)計(jì)圖是需要所有月份的數(shù)據(jù)的。咋看一下,我們是需要把查詢出來的數(shù)據(jù)做循環(huán)判斷,得看看有沒有該月份,如果沒有該月份還得把數(shù)據(jù)填充進(jìn)去。。還得判斷該月份是不是本年度的….這樣想一下就覺得麻煩了……

select month(comp_time) as '月份',count(*) '總數(shù)'from complainwhere year(comp_time)=?group by month(comp_time)month(comp_time) as '月份',count(*) '總數(shù)'
from complain
where year(comp_time)=?
group by month(comp_time)
這里寫圖片描述

再次回到前面分析的,如果本年度的月份還沒有到,那么將該月的數(shù)據(jù)設(shè)置為“”,如果是其他年份的的月份查出的數(shù)據(jù)為null,那么我們應(yīng)該把這些月份的投訴數(shù)設(shè)置為0而不是”“…..

但是呢,我們現(xiàn)在有一個(gè)辦法,可以在查詢的時(shí)候,不管該月份有沒有數(shù)據(jù),都得顯示出來….這就是左外連接

于是我們自己手動(dòng)生成一張擁有12個(gè)月份的數(shù)據(jù)表,跟我們的投訴表進(jìn)行左外連接…

這里寫圖片描述 ? ?select imonth, count(comp_id) ? ?from t_month left join complain on imonth=month(comp_time) ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?and year(comp_time)=2017 ? ?group by imonth ? ?order by imonth;count(comp_id)
? ?from t_month left join complain on imonth=month(comp_time)
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?and year(comp_time)=2017
? ?group by imonth
? ?order by imonth;
這里寫圖片描述

上面的sql語句的查詢效率是有點(diǎn)低的,我們改造一下,改成是子查詢:

select imonth,c2from t_month left join (select month(comp_time) c1, count(comp_id) c2 from complain where year(comp_time)=? group by month(comp_time)) ton imonth = c1order by imonth;
from t_month left join (select month(comp_time) c1, count(comp_id) c2 from complain where year(comp_time)=? group by month(comp_time)) t
on imonth = c1
order by imonth;

代碼實(shí)現(xiàn)

dao層根據(jù)年份查詢出每個(gè)月份的投訴數(shù)據(jù)

? ?/** ? ? * ? ? * @param year 根據(jù)年獲取數(shù)據(jù) ? ? * @return ?返回的是一個(gè)列表數(shù)組 ? ? */ ? ?@Override ? ?public List<Object[]> getAnnualStatisticByYear(int year) { ? ? ? ?//拼接SQL語句 ? ? ? ?StringBuffer buffer = new StringBuffer(); ? ? ? ?buffer.append(" SELECT imonth,c2 ") ? ? ? ?.append(" FROM t_month") ? ? ? ?.append(" LEFT JOIN (SELECT month(comp_time) c1, count(comp_id) c2 FROM complain WHERE YEAR(comp_time)=? GROUP BY MONTH(comp_time)) t") ? ? ? ?.append(" ON imonth = c1") ? ? ? ?.append(" ORDER BY imonth;"); ? ? ? ?SQLQuery sqlQuery = getSession().createSQLQuery(buffer.toString()); ? ? ? ?sqlQuery.setParameter(0, year); ? ? ? ?List<Object[]> list = sqlQuery.list(); ? ? ? ?return list; ? ?}
? ?@Override
? ?public List<Object[]> getAnnualStatisticByYear(int year) {


? ? ? ?//拼接SQL語句
? ? ? ?StringBuffer buffer = new StringBuffer();
? ? ? ?buffer.append(" SELECT imonth,c2 ")
? ? ? ?.append(" FROM t_month")
? ? ? ?.append(" LEFT JOIN (SELECT month(comp_time) c1, count(comp_id) c2 FROM complain WHERE YEAR(comp_time)=? GROUP BY MONTH(comp_time)) t")
? ? ? ?.append(" ON imonth = c1")
? ? ? ?.append(" ORDER BY imonth;");
? ? ? ?SQLQuery sqlQuery = getSession().createSQLQuery(buffer.toString());
? ? ? ?sqlQuery.setParameter(0, year);

? ? ? ?List<Object[]> list = sqlQuery.list();
? ? ? ?return list;
? ?}

service層拿到Dao層的數(shù)據(jù),判斷是否是本年度的,如果是本年度的,那么還沒有到的月份的數(shù)據(jù)就設(shè)置為”“,如果已經(jīng)過的了月份,如果沒有數(shù)據(jù)就設(shè)置為0.

返回一個(gè)List集合嵌套著Map集合,就可以給前臺(tái)解析了。

? ?@Override ? ?public List getAnnualStatisticByYear(int year) { ? ? ? ?List<Object[]> annualStatisticByYear = complainDao.getAnnualStatisticByYear(year); ? ? ? ?List<Map> returnList = new ArrayList<>(); ? ? ? ?//得到本年度和本月份 ? ? ? ?int curYear = Calendar.getInstance().get(Calendar.YEAR); ? ? ? ?//Calerdar月份從0開始, ? ? ? ?int curMonth = Calendar.getInstance().get(Calendar.MONTH)+1; ? ? ? ?//使用Map集合裝載著數(shù)據(jù) ? ? ? ?Map<String,Object> map = null; ? ? ? ?for (Object[] objects : annualStatisticByYear) { ? ? ? ? ? ?map = new HashedMap(); ? ? ? ? ? ?//得到月份 ? ? ? ? ? ?Integer month = Integer.valueOf(objects[0] + ""); ? ? ? ? ? ?map.put("label", month + "月"); ? ? ? ? ? ?if (curYear == year) { //是本年度,那么看看月份是否大于本月份 ? ? ? ? ? ? ? ?if (month > curMonth) { ? ? ? ? ? ? ? ? ? ?//將數(shù)據(jù)設(shè)置為"" ? ? ? ? ? ? ? ? ? ?map.put("value", ""); ? ? ? ? ? ? ? ?} else { ? ? ? ? ? ? ? ? ? ?if (objects[1] != null) { ? ? ? ? ? ? ? ? ? ? ? ?map.put("value", objects[1]); ? ? ? ? ? ? ? ? ? ?} else { ? ? ? ? ? ? ? ? ? ? ? ?map.put("value", "0"); ? ? ? ? ? ? ? ? ? ?} ? ? ? ? ? ? ? ?} ? ? ? ? ? ?}else {//不是本年度 ? ? ? ? ? ? ? ?if (objects[1] != null) { ? ? ? ? ? ? ? ? ? ?map.put("value", objects[1]); ? ? ? ? ? ? ? ?} else { ? ? ? ? ? ? ? ? ? ?map.put("value", "0"); ? ? ? ? ? ? ? ?} ? ? ? ? ? ?} ? ? ? ? ? ?returnList.add(map); ? ? ? ?} ? ? ? ?return returnList; ? ?}
? ?public List getAnnualStatisticByYear(int year) {

? ? ? ?List<Object[]> annualStatisticByYear = complainDao.getAnnualStatisticByYear(year);

? ? ? ?List<Map> returnList = new ArrayList<>();

? ? ? ?//得到本年度和本月份
? ? ? ?int curYear = Calendar.getInstance().get(Calendar.YEAR);
? ? ? ?//Calerdar月份從0開始,
? ? ? ?int curMonth = Calendar.getInstance().get(Calendar.MONTH)+1;

? ? ? ?//使用Map集合裝載著數(shù)據(jù)
? ? ? ?Map<String,Object> map = null;
? ? ? ?for (Object[] objects : annualStatisticByYear) {
? ? ? ? ? ?map = new HashedMap();
? ? ? ? ? ?//得到月份
? ? ? ? ? ?Integer month = Integer.valueOf(objects[0] + "");
? ? ? ? ? ?map.put("label", month + "月");
? ? ? ? ? ?if (curYear == year) { //是本年度,那么看看月份是否大于本月份
? ? ? ? ? ? ? ?if (month > curMonth) {
? ? ? ? ? ? ? ? ? ?//將數(shù)據(jù)設(shè)置為""
? ? ? ? ? ? ? ? ? ?map.put("value", "");
? ? ? ? ? ? ? ?} else {
? ? ? ? ? ? ? ? ? ?if (objects[1] != null) {
? ? ? ? ? ? ? ? ? ? ? ?map.put("value", objects[1]);
? ? ? ? ? ? ? ? ? ?} else {
? ? ? ? ? ? ? ? ? ? ? ?map.put("value", "0");
? ? ? ? ? ? ? ? ? ?}
? ? ? ? ? ? ? ?}
? ? ? ? ? ?}else {//不是本年度
? ? ? ? ? ? ? ?if (objects[1] != null) {
? ? ? ? ? ? ? ? ? ?map.put("value", objects[1]);
? ? ? ? ? ? ? ?} else {
? ? ? ? ? ? ? ? ? ?map.put("value", "0");
? ? ? ? ? ? ? ?}
? ? ? ? ? ?}
? ? ? ? ? ?returnList.add(map);
? ? ? ?}
? ? ? ?return returnList;
? ?}

action層把service層的數(shù)據(jù)封裝到Map集合中,嵌套ajax解析Map集合,得到的就是對象數(shù)組了。

? ?//返回JSON格式的數(shù)據(jù),這里我們就直接用Struts2框架來返回對應(yīng)的數(shù)據(jù)就行了。 ? ?public String getAnnualStatisticData() { ? ? ? ?//獲取用戶傳遞過來的年份 ? ? ? ?String str_year = ServletActionContext.getRequest().getParameter("year"); ? ? ? ?if (str_year != null) { ? ? ? ? ? ?int year = Integer.valueOf(str_year); ? ? ? ? ? ?//根據(jù)年份去獲取每個(gè)月的投訴數(shù) ? ? ? ? ? ?map.put("msg", "success"); ? ? ? ? ? ?map.put("chartData", complainServiceImpl.getAnnualStatisticByYear(year)); ? ? ? ?} ? ? ? ?return "getAnnualStatisticData"; ? ?}
? ?public String getAnnualStatisticData() {

? ? ? ?//獲取用戶傳遞過來的年份
? ? ? ?String str_year = ServletActionContext.getRequest().getParameter("year");
? ? ? ?if (str_year != null) {
? ? ? ? ? ?int year = Integer.valueOf(str_year);
? ? ? ? ? ?//根據(jù)年份去獲取每個(gè)月的投訴數(shù)
? ? ? ? ? ?map.put("msg", "success");
? ? ? ? ? ?map.put("chartData", complainServiceImpl.getAnnualStatisticByYear(year));
? ? ? ?}
? ? ? ?return "getAnnualStatisticData";
? ?}

前臺(tái)把年份提交給Action,解析出后臺(tái)返回的數(shù)據(jù),渲染成折線圖….

function doAnnualStatistic() { ? ? ? ? ? ?//獲取當(dāng)前年份 ? ? ? ? ? ?var $year = $("#year option:selected").val(); ? ? ? ? ? ?//一進(jìn)來,如果沒有選擇任何的年數(shù),就顯示當(dāng)前年份的 ? ? ? ? ? ?if($year=="" || $year==undefined) { ? ? ? ? ? ? ? $year = "${year}"; ? ? ? ? ? ?} ? ? ? ? ? ?//2、統(tǒng)計(jì)年度投訴數(shù)據(jù)并展示圖表 ? ? ? ? ? ?$.ajax({ ? ? ? ? ? ? ? ?url: "${basePath}complain/complain_getAnnualStatisticData.action", ? ? ? ? ? ? ? ?type: "post", ? ? ? ? ? ? ? ?dataType: "json", ? ? ? ? ? ? ? ?data: {"year":$year}, ? ? ? ? ? ? ? ?success: function (backData) { ? ? ? ? ? ? ? ? ? ?if(backData!=null && backData!=""){ ? ? ? ? ? ? ? ? ? ? ? ?var revenueChart = new FusionCharts({ ? ? ? ? ? ? ? ? ? ? ? ? ? ?"type": "line", ? ? ? ? ? ? ? ? ? ? ? ? ? ?"renderAt": "chartContainer", ? ? ? ? ? ? ? ? ? ? ? ? ? ?"width": "600", ? ? ? ? ? ? ? ? ? ? ? ? ? ?"height": "400", ? ? ? ? ? ? ? ? ? ? ? ? ? ?"dataFormat": "json", ? ? ? ? ? ? ? ? ? ? ? ? ? ?"dataSource": { ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?"chart": { ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?"caption": "年度統(tǒng)計(jì)投訴數(shù)", ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?"xAxisName": "月 ? 份", ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?"yAxisName": "投 ?訴 數(shù)", ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?"theme": "fint" ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?}, ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?"data":backData.chartData ? ? ? ? ? ? ? ? ? ? ? ? ? ?} ? ? ? ? ? ? ? ? ? ? ? ?}); ? ? ? ? ? ? ? ? ? ? ? ?revenueChart.render(); ? ? ? ? ? ? ? ? ? ?} ? ? ? ? ? ? ? ?}, ? ? ? ? ? ? ? ?error:function () { ? ? ? ? ? ? ? ? ? ?alert("統(tǒng)計(jì)投訴數(shù)失敗!"); ? ? ? ? ? ? ? ?} ? ? ? ? ? ?}); ? ? ? ?}
? ? ? ? ? ?//獲取當(dāng)前年份
? ? ? ? ? ?var $year = $("#year option:selected").val();

? ? ? ? ? ?//一進(jìn)來,如果沒有選擇任何的年數(shù),就顯示當(dāng)前年份的
? ? ? ? ? ?if($year=="" || $year==undefined) {
? ? ? ? ? ? ? $year = "${year}";
? ? ? ? ? ?}
? ? ? ? ? ?//2、統(tǒng)計(jì)年度投訴數(shù)據(jù)并展示圖表
? ? ? ? ? ?$.ajax({
? ? ? ? ? ? ? ?url: "${basePath}complain/complain_getAnnualStatisticData.action",
? ? ? ? ? ? ? ?type: "post",
? ? ? ? ? ? ? ?dataType: "json",
? ? ? ? ? ? ? ?data: {"year":$year},
? ? ? ? ? ? ? ?success: function (backData) {
? ? ? ? ? ? ? ? ? ?if(backData!=null && backData!=""){
? ? ? ? ? ? ? ? ? ? ? ?var revenueChart = new FusionCharts({
? ? ? ? ? ? ? ? ? ? ? ? ? ?"type": "line",
? ? ? ? ? ? ? ? ? ? ? ? ? ?"renderAt": "chartContainer",
? ? ? ? ? ? ? ? ? ? ? ? ? ?"width": "600",
? ? ? ? ? ? ? ? ? ? ? ? ? ?"height": "400",
? ? ? ? ? ? ? ? ? ? ? ? ? ?"dataFormat": "json",
? ? ? ? ? ? ? ? ? ? ? ? ? ?"dataSource": {
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?"chart": {
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?"caption": "年度統(tǒng)計(jì)投訴數(shù)",
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?"xAxisName": "月 ? 份",
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?"yAxisName": "投 ?訴 數(shù)",
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?"theme": "fint"
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?},
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?"data":backData.chartData
? ? ? ? ? ? ? ? ? ? ? ? ? ?}
? ? ? ? ? ? ? ? ? ? ? ?});
? ? ? ? ? ? ? ? ? ? ? ?revenueChart.render();
? ? ? ? ? ? ? ? ? ?}
? ? ? ? ? ? ? ?},
? ? ? ? ? ? ? ?error:function () {
? ? ? ? ? ? ? ? ? ?alert("統(tǒng)計(jì)投訴數(shù)失敗!");
? ? ? ? ? ? ? ?}
? ? ? ? ? ?});
? ? ? ?}

總結(jié)

如果文章有錯(cuò)的地方歡迎指正,大家互相交流。習(xí)慣在微信看技術(shù)文章,想要獲取更多的Java資源的同學(xué),可以關(guān)注微信公眾號:Java3y


總結(jié)

以上是生活随笔為你收集整理的纳税服务系统七(投诉管理模块)【显示投诉信息、处理回复、我要投诉、Quartz自动受理、统计图FusionCharts】...的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。

亚洲精品www久久久久久 | 婷婷成人在线 | 综合久久久久久久 | 狠狠的干狠狠的操 | 亚洲最新精品 | 深夜男人影院 | 91精品小视频 | 国产成人在线播放 | 最新av网址在线 | 91福利视频免费观看 | 又黄又网站 | 男女全黄一级一级高潮免费看 | 色网免费观看 | 国产96av | 亚洲精品免费在线视频 | 天天综合成人网 | 中国一级片在线 | 干干日日 | 91精品国产92久久久久 | 夜色资源站wwwcom | 亚洲一区网 | 成人永久免费 | 人人草网站 | a电影在线观看 | 日韩av在线网站 | 色激情五月| 亚一亚二国产专区 | 91看片在线免费观看 | 天天射天天干天天爽 | 美女网站色免费 | 成人性生交视频 | 激情综合网五月激情 | 日日躁天天躁 | 99久久精品久久久久久动态片 | 久久国产精彩视频 | 五月激情亚洲 | 中文字幕av免费 | 国产无遮挡又黄又爽在线观看 | 久久国产精品视频免费看 | 五月婷婷精品 | 亚洲女裸体 | 国产又黄又爽无遮挡 | 在线亚洲小视频 | 久久草在线视频国产 | 五月婷婷久久综合 | av夜夜操| 97在线免费观看视频 | 亚洲一区二区黄色 | 色婷婷激情电影 | 伊人黄色网 | 在线看免费| 久久久久国产精品厨房 | 久热国产视频 | 亚洲视频一区二区三区在线观看 | av成人在线观看 | 成人羞羞视频在线观看免费 | 精品一区精品二区 | 国产福利精品视频 | 日韩一级电影网站 | 成人av网址大全 | 免费视频久久久久久久 | 国产成人亚洲在线观看 | 91传媒91久久久 | 果冻av在线 | 国产一区免费视频 | 亚洲www天堂com | 黄网站色 | 久草久热 | 成人久久精品视频 | 日日干夜夜干 | 在线视频一二三 | 日韩视频欧美视频 | 欧美日韩精品免费观看视频 | 欧美一区二区三区免费看 | 天天插视频 | 开心色激情网 | 亚洲一区二区三区在线看 | 在线91网| 麻豆国产电影 | 亚洲国产片色 | 国产精品毛片一区二区 | 亚洲第一久久久 | 九九电影在线 | av在线a| 国产一区二区三区视频在线 | 国产精品无av码在线观看 | 久久激情视频 久久 | 亚洲另类视频 | 亚洲 欧美 91 | 色综合天天爱 | 成人97视频一区二区 | 免费观看的黄色片 | 91黄在线看 | 成人xxxx | 色婷婷电影 | 在线免费看片 | 四虎影视精品成人 | 亚洲日本一区二区在线 | 亚洲国产精品久久久久 | 麻豆va一区二区三区久久浪 | 国产首页| 国产美女精品在线 | 福利一区二区 | 在线观看一级片 | 91av小视频| av免费观看高清 | av中文字幕剧情 | 国产精品久久久av | 日韩高清免费无专码区 | 久久久久久久久精 | 最近日本mv字幕免费观看 | 深夜免费福利在线 | 99久久精品国产观看 | 一区二区三区国产精品 | 国产伦精品一区二区三区无广告 | 亚洲美女在线一区 | 一区二区在线电影 | 久久涩视频 | 日韩精品一区二区三区丰满 | 91女子私密保健养生少妇 | 91精品一区二区在线观看 | 天天操人人要 | 探花国产在线 | 久久99精品国产 | 深夜免费福利在线 | 精品国产精品国产偷麻豆 | 日本在线观看中文字幕 | 日日添夜夜添 | 成人黄色电影在线观看 | 欧美日韩高清一区二区三区 | 五月婷婷综合色拍 | 最近字幕在线观看第一季 | 久久久久久久久综合 | 操碰av| 午夜精品久久久久久久99无限制 | 毛片一级免费一级 | 97人人超| 国产免费成人av | 国产在线精 | 99福利片 | 亚洲区视频在线 | 欧美久久久 | 麻豆国产精品永久免费视频 | 欧美一级视频一区 | 国产精品专区在线观看 | 日日干夜夜骑 | 高清一区二区三区 | 男女免费视频观看 | 黄色成人影院 | 国产传媒中文字幕 | 日日激情 | av资源在线看 | 中文字幕乱码在线播放 | 久久99精品国产99久久 | 玖玖视频网 | 国产精品久久影院 | 成年人毛片在线观看 | 久久的色 | 欧洲一区二区在线观看 | 亚洲一区二区三区四区精品 | 麻豆果冻剧传媒在线播放 | 免费网站黄 | 午夜av电影院 | 日韩精品最新在线观看 | 久久免费电影网 | 在线 国产一区 | 日韩在线免费电影 | 91精品在线免费观看 | 91最新网址在线观看 | 久热av在线| 亚洲精品66 | 亚洲免费公开视频 | 手机在线日韩视频 | 久久成人免费视频 | 少妇bbw搡bbbb搡bbb | 日韩av手机在线看 | 麻豆传媒视频观看 | 婷婷色影院| 999色视频 | 久精品视频在线观看 | 日韩理论在线播放 | 日韩欧美视频免费在线观看 | 国产精品午夜免费福利视频 | 久久久精品网站 | 97精品在线观看 | 日韩午夜电影网 | 一区二三国产 | 九九国产精品视频 | 国产美女免费视频 | 毛片在线播放网址 | 91在线视频免费观看 | 全久久久久久久久久久电影 | 日韩在线一区二区免费 | 国产精品久久久久亚洲影视 | 91av资源网| 亚洲午夜在线视频 | 免费a级大片 | 天天色天天色 | 综合激情婷婷 | 香蕉看片| av资源在线看| 亚洲成人av一区二区 | 国产91精品久久久久久 | 亚洲激情国产精品 | 99久久精品一区二区成人 | av高清一区 | 亚洲精品色视频 | 婷婷亚洲综合五月天小说 | 国产日韩在线播放 | 一级一片免费看 | 成人一级电影在线观看 | 免费av大片 | 国产视频色 | 国内精品视频免费 | 国产精品美女www爽爽爽视频 | 麻豆av一区二区三区在线观看 | 亚洲视频资源在线 | 亚洲精品www.| 四虎永久免费在线观看 | 国产午夜av | 天天综合色天天综合 | 午夜精品一区二区三区免费视频 | 夜夜天天干 | 色资源网免费观看视频 | 久久久www成人免费毛片 | 国产91影院 | 国产99久久 | 999男人的天堂 | 日韩影视精品 | 九七视频在线 | 国产一区91 | 韩日色视频 | 亚洲精品美女在线观看播放 | 日本久久91 | 美女视频网 | 亚洲视频在线播放 | 粉嫩av一区二区三区入口 | 国产精品一区二区在线观看免费 | 国产精品久久久久国产a级 激情综合中文娱乐网 | 国产精品久久久久久久久久不蜜月 | 国产精品视频你懂的 | 成人免费 在线播放 | 91久久精品一区二区三区 | 久草在线精品观看 | 九九九热 | av丝袜在线 | 在线国产不卡 | 日韩一区二区三区高清免费看看 | 日韩爱爱网站 | 草久在线播放 | 日韩在线精品一区 | 久草在线视频新 | 日韩sese| 999精品 | 亚洲欧洲日韩 | 波多野结衣视频一区二区三区 | www五月天婷婷 | 热久久在线视频 | 丁香婷婷射| 成人片在线播放 | 天天干夜夜夜 | 国产精品久久久久久久久久久久久 | 狠狠的日日| 欧美性极品xxxx做受 | 欧美日韩午夜 | 黄色影院在线免费观看 | 日日草av | 亚洲免费在线观看视频 | 一区二区视频在线播放 | 人人看97 | 中文字幕123区 | 精品在线观看一区二区三区 | 一区二区三区四区免费视频 | 免费av网站在线看 | 天天操天天摸天天爽 | 青草视频在线 | 亚洲一级黄色av | 2019精品手机国产品在线 | 色婷婷导航 | 黄色一级免费 | 亚洲综合激情网 | 日日夜夜操操操操 | 久久免费大片 | 最近中文字幕高清字幕在线视频 | 性色av免费在线观看 | 久久精品—区二区三区 | 91丨九色丨高潮丰满 | 日韩高清免费观看 | 色97在线| 91毛片在线 | 欧美精品一区二区免费 | 天天操天天能 | 999精品在线| 日韩二区在线观看 | 国产综合福利在线 | 成人一级黄色片 | 午夜免费在线观看 | 久久精品99国产国产精 | 一区二区三区在线电影 | 中文字幕资源站 | 一区二区三区四区免费视频 | 九九综合久久 | 99热手机在线| 91av在线电影 | 丁香综合av | 国产亚洲综合精品 | 97超碰在线久草超碰在线观看 | 在线亚洲小视频 | www.亚洲激情.com | 激情网在线观看 | 色综合天天狠天天透天天伊人 | 99婷婷狠狠成为人免费视频 | 91av视频网站| 国产色a在线观看 | 亚洲免费观看在线视频 | 国产精品一区二区免费视频 | 成人免费在线观看入口 | 在线视频国产区 | 97电影手机版| 婷婷丁香色 | 国产精品地址 | 精品国产91亚洲一区二区三区www | 麻豆影视网站 | 欧美精品一区二区三区四区在线 | 西西人体4444www高清视频 | 久久人人添人人爽添人人88v | 在线久久| 国产精品久久一区二区三区不卡 | 国产在线精 | 激情视频综合网 | 久久黄色小说 | 日韩中文字幕免费 | 婷婷成人综合 | 99久久久国产精品免费99 | 美女在线观看网站 | 国产精品网红直播 | 国产精品 日韩精品 | 日韩免费网站 | 久久激情五月丁香伊人 | 91xav| 中文乱幕日产无线码1区 | 亚洲欧美视屏 | 久草视频在线资源站 | 黄色大全免费网站 | 99热都是精品 | 精品国产免费人成在线观看 | 激情综合色综合久久 | 在线三级播放 | 香蕉网站在线观看 | 丁香导航 | 99久久精品无码一区二区毛片 | 久久久久国产一区二区三区四区 | 在线观看免费成人av | 99精品在线免费视频 | 久草视频在线资源 | 999亚洲国产996395 | 97视频免费在线看 | 国产视频日韩 | 最近中文字幕免费视频 | 国产精品自拍在线 | 日韩理论影院 | 三级a视频 | av黄网站 | 中文字幕 二区 | 中文字幕在线观看不卡 | 久久国产精彩视频 | 日韩成人在线一区二区 | 玖玖精品视频 | 婷婷激情av| 激情网五月天 | www久久| 欧美精品免费视频 | 亚洲精品国精品久久99热一 | 手机色在线 | 激情久久久久久久久久久久久久久久 | 亚洲午夜精品久久久久久久久 | 久草在线免费看视频 | 高清久久久 | 蜜臀aⅴ精品一区二区三区 久久视屏网 | 一区二区三区福利 | 人人澡超碰碰 | 不卡视频一区二区三区 | 亚洲精品系列 | 国产精品9区| 日韩亚洲在线视频 | 五月婷婷视频 | 天天爱天天操天天爽 | 黄色精品一区 | 久久歪歪 | 麻豆国产电影 | 久草在线视频免费资源观看 | 国产精品第7页 | 91九色自拍 | 夜夜操综合网 | 免费精品国产 | 免费午夜视频在线观看 | 一区二区三区视频在线 | 国产不卡精品视频 | 在线观看片 | 国产精品欧美精品 | 国产一二三四在线观看视频 | 九色在线视频 | 国产成人亚洲在线观看 | 亚洲欧美婷婷六月色综合 | 欧美性大战 | 97视频网址 | 18女毛片| 五月婷婷视频在线 | 天天爽天天射 | 久久草在线视频国产 | 亚洲精品成人免费 | 偷拍区另类综合在线 | 我爱av激情网 | 久久社区视频 | 激情视频91| 日韩色综合| 欧美久久久久 | 一区二区三区久久精品 | 国产精品一区二区三区观看 | 久久久久久久久久久久久9999 | 日韩av专区 | 97爱| 激情网在线观看 | 五月综合色婷婷 | 99视频在线免费看 | www成人精品 | 国产午夜精品理论片在线 | 91av超碰| 久久激情视频免费观看 | 综合网伊人 | 欧美日韩国产精品一区 | 麻豆视传媒官网免费观看 | 欧美精品做受xxx性少妇 | 成人电影毛片 | 久久国产片 | 久久 一区 | 亚洲手机天堂 | 99精品免费久久久久久久久 | 中文字幕视频一区 | 国产色视频一区二区三区qq号 | 国产精品女同一区二区三区久久夜 | 99精品在线看 | 黄色国产精品 | 人人澡澡人人 | 色婷婷av一区 | 天天天天射| 三级动图 | 蜜臀久久99精品久久久久久网站 | 成人av免费电影 | 久久丁香 | 日本h视频在线观看 | 亚洲91精品在线观看 | 国产精品久久久久久久久久久久午夜 | 国产精品成人av在线 | 亚洲天堂网视频 | 午夜久久视频 | 日韩精品在线免费观看 | 四虎成人免费观看 | 香蕉久草在线 | 免费日韩电影 | 中文字幕在线人 | 在线之家官网 | 91在线播放综合 | 狠狠色2019综合网 | 免费中午字幕无吗 | 超碰在线日韩 | 久久国产精彩视频 | 五月天伊人网 | 九九视频这里只有精品 | 91精品视频在线免费观看 | 91在线看 | 久久久国产精品电影 | av黄色国产 | 美女视频黄在线观看 | 国产精品毛片久久蜜 | 狠狠色丁香婷婷综合久久片 | 久草国产在线 | 欧美日韩不卡在线观看 | 特级毛片在线免费观看 | 国产一级免费观看视频 | 1000部国产精品成人观看 | 激情网色 | 国产一级免费播放 | 久草免费在线视频 | 黄色录像av | 成人精品国产 | 黄p网站在线观看 | 五月天婷婷综合 | 久久久国产精品网站 | 久久久久网站 | 久久爱992xxoo | 日韩成人黄色av | 五月婷丁香 | 亚洲精品国产精品国自产观看浪潮 | 欧美污在线观看 | 91亚洲精品久久久蜜桃 | 亚洲天堂精品视频 | 狠狠的日日 | 午夜精品久久久久久久久久 | 在线观看亚洲精品视频 | 久久久久久久免费看 | 天天爱综合 | 黄网站app在线观看免费视频 | 亚洲片在线观看 | 婷婷激情综合网 | 国产九九九精品视频 | 亚洲视频综合在线 | 99久久精品国产一区二区三区 | 国产123av| 精品一区二区三区在线播放 | 日韩美视频 | 久久精品www人人爽人人 | 91av视屏| 免费精品在线视频 | 成人午夜免费剧场 | 久久精品高清视频 | 色综合网| 伊人色综合久久天天网 | 久久久国产精品麻豆 | 国产综合小视频 | 看av免费网站 | 天天玩天天干 | 久草在线手机观看 | 亚洲黄网站 | 91精品国自产在线偷拍蜜桃 | 九九热视频在线 | av在线免费观看网站 | 精品一区二区在线免费观看 | 国产精品黑丝在线观看 | 深爱激情五月综合 | av中文资源在线 | 国产在线播放一区 | 天天爽夜夜爽人人爽曰av | 欧美精品免费视频 | 夜夜干夜夜| 色婷婷免费视频 | 久久在线免费视频 | av三级av | 欧美成人精品欧美一级乱 | 国产精品一区二区三区电影 | 国产精品久久久久久久午夜 | 色五月情| 亚洲高清视频一区二区三区 | 精品一区二区三区久久 | 精品久久久久久久久久久院品网 | 久久综合久久鬼 | 国产精品久久久久久av | 91成熟丰满女人少妇 | 综合久久网站 | 久久久久一区二区三区四区 | 美女视频黄是免费的 | 久草网视频 | 丁香六月激情婷婷 | 国产伦精品一区二区三区免费 | 在线91av| 国产精品福利在线播放 | 国产99中文字幕 | 曰本三级在线 | 成人av动漫在线 | 麻豆视频国产 | 亚洲精品国偷自产在线99热 | 婷婷综合 | 91精品毛片| 99久久日韩精品视频免费在线观看 | 久久露脸国产精品 | 91精品人成在线观看 | 9色在线视频 | 在线成人免费电影 | 久久综合九色综合欧美就去吻 | 久久精品亚洲综合专区 | 91传媒激情理伦片 | 亚洲精品日韩在线观看 | 91九色最新地址 | 亚洲最新毛片 | 97人人人人 | 超碰在线97国产 | 国产精品视频线看 | 黄色aaa级片 | 天堂av在线中文在线 | 国产亚洲精品久久久久久久久久久久 | 国产成人一级 | 超碰成人免费电影 | 亚洲国产三级在线观看 | 精品国产美女在线 | 精品国产一区二区三区久久影院 | 亚洲国产资源 | 91免费观看 | 欧美日韩免费在线观看视频 | 日本午夜在线亚洲.国产 | 久久久精品免费看 | 99久久精品国产一区二区成人 | 欧美一级裸体视频 | 香蕉影视app | 色99色| av免费看网站 | 精品一区二区电影 | 日批网站在线观看 | 久久91久久久久麻豆精品 | 欧美一级久久久久 | 精品国产视频在线观看 | 久久精品视频国产 | av+在线播放在线播放 | 欧美色一色 | 又爽又黄又无遮挡网站动态图 | 一区二区三区韩国免费中文网站 | 国产精品视频999 | 性色av一区二区三区在线观看 | 成年在线观看 | 亚洲国产精品成人va在线观看 | 婷婷久久久 | 视频一区二区精品 | 国产精品va在线播放 | 黄网站大全 | 国产一级黄色片免费看 | 人人玩人人添人人 | 免费看片网址 | 色婷婷成人网 | 激情五月婷婷综合 | 99精品在线免费在线观看 | 亚洲欧美精品一区二区 | 四虎影视成人精品 | 亚洲精品在线视频观看 | 色是在线视频 | 91av在线免费 | 亚洲欧美视频在线播放 | 久久伊99综合婷婷久久伊 | 91av在线视频免费观看 | 9在线观看免费高清完整版 玖玖爱免费视频 | 99国产情侣在线播放 | 精品久久久久久久 | 久久电影色| 久久精品这里精品 | 久国产在线播放 | www.夜夜操| 欧美久草视频 | 亚洲成人av一区 | 日本在线成人 | 一区二区视频免费在线观看 | 91激情视频在线 | 国产成人福利在线 | 一区二区三区高清在线 | 亚洲精品国产第一综合99久久 | 天堂麻豆 | 日韩三级免费观看 | 狠狠色丁香久久婷婷综 | 丁香六月婷 | 欧美视频99 | 激情久久影院 | av一区二区三区在线观看 | 久草免费在线观看 | 国产 日韩 欧美 在线 | 黄色免费观看网址 | 欧美精品在线一区 | 欧美日韩不卡在线观看 | 免费成人在线网站 | 免费色视频 | 国产麻豆视频在线观看 | 久久 地址 | 欧美日韩国产在线精品 | 国产呻吟在线 | www.成人精品 | 国产成人黄色网址 | 日韩在线视频免费看 | 国产91aaa| 久久久久久久久久网 | 人人澡人人模 | 97电院网手机版 | 亚洲粉嫩av | 精品在线观看免费 | 国产精品国内免费一区二区三区 | 成人av网站在线播放 | 日本精品视频免费观看 | 瑞典xxxx性hd极品 | 久久超| 91亚洲精品久久久蜜桃网站 | 国产91成人在在线播放 | 色综合夜色一区 | 西西4444www大胆视频 | 天天伊人狠狠 | 91九色成人蝌蚪首页 | 亚洲成人国产精品 | 精品视频久久久 | 日韩欧美在线观看一区二区 | 亚洲国产欧美一区二区三区丁香婷 | 免费美女av | 日韩毛片精品 | 69精品在线观看 | 成人黄色电影在线播放 | 国产精品女人久久久久久 | 欧美男同视频网站 | 精品国产91亚洲一区二区三区www | 中文字幕丰满人伦在线 | 亚洲日本va在线观看 | 午夜av在线电影 | 免费在线观看av片 | 国产精品成人一区二区三区 | 午夜精品久久久久久久99无限制 | 日韩特黄一级欧美毛片特黄 | 狠狠狠色丁香婷婷综合激情 | 69国产精品视频免费观看 | 国产精品大尺度 | 91精品国产高清自在线观看 | 91在线视频在线观看 | 在线观看日韩免费视频 | 亚洲国产三级在线 | 天天操夜夜看 | 久久久夜色 | 黄色特一级片 | 久久久国产精品一区二区中文 | 中文字幕在线色 | 麻豆精品国产传媒 | www.成人sex| 亚洲国产精品500在线观看 | 精品毛片在线 | 久久久视频在线 | 在线观看精品视频 | 91在线视频免费观看 | 99性视频 | 久久久噜噜噜久久久 | 在线看片中文字幕 | 欧美日韩另类在线 | 婷婷亚洲综合五月天小说 | 永久精品视频 | 干 操 插 | 国产精品视频免费看 | 久久男人视频 | 中国老女人日b | 久久免费黄色大片 | 久久爽久久爽久久av东京爽 | 99热这里有精品 | 亚洲午夜精品久久久久久久久 | 在线有码中文字幕 | 国产va在线| 九九在线高清精品视频 | 天天天天综合 | 欧美夫妻性生活电影 | 欧美精品v国产精品v日韩精品 | 99久久99久久精品国产片 | 日本夜夜草视频网站 | 日韩毛片久久久 | 亚洲国产精久久久久久久 | 国产成人91| 亚洲欧洲精品在线 | 亚洲一区久久久 | 黄色小说在线免费观看 | 99精品视频在线 | 国产美女视频黄a视频免费 久久综合九色欧美综合狠狠 | 免费看一级一片 | 欧美性生活久久 | 欧美一级视频免费 | 97av在线| 久久久免费观看完整版 | 最近中文国产在线视频 | 免费看黄在线 | 国产综合香蕉五月婷在线 | 日韩成人高清在线 | 97超碰人人干 | 日韩在线无 | 国产黄色免费 | 精品99视频 | 丁香花在线观看免费完整版视频 | 久久在线精品视频 | 免费色网| 亚洲最大成人网4388xx | 日韩电影中文字幕在线 | 婷婷国产v亚洲v欧美久久 | 久久五月婷婷丁香 | 色综合久久久久久久 | 久久久亚洲影院 | 天天拍天天操 | 免费观看久久 | 亚洲精品1234区 | 国产美女主播精品一区二区三区 | bbb搡bbb爽爽爽 | 中文字幕第一页在线 | 免费观看黄| 日韩在线观看 | 97免费视频在线 | 国产99久久久精品 | 日韩久久电影 | 中文字幕视频免费观看 | 亚洲天堂网视频在线观看 | 久久久久久电影 | 区一区二在线 | 久草在 | 亚洲精品网页 | 毛片网在线观看 | 最近中文字幕mv | 97在线精品国自产拍中文 | 一区二区亚洲精品 | 国产999精品久久久久久 | 天天天综合网 | 国产区第一页 | 亚洲精品视频网站在线观看 | 免费网站色 | 色在线免费 | 99超碰在线播放 | 精品久久毛片 | bbbbb女女女女女bbbbb国产 | 久久97超碰 | 综合精品久久久 | 久久久久久久久久免费 | 精品国产自在精品国产精野外直播 | 亚洲男女精品 | www.色五月| 国产成人精品综合久久久 | 欧美激情视频久久 | av免费观看高清 | 亚洲成aⅴ人在线观看 | 国产不卡在线看 | 色99之美女主播在线视频 | 天天操天天干天天插 | 天天干天天射天天插 | 久久久久国产精品午夜一区 | av在线精品| 久草色在线观看 | 毛片网站在线观看 | 91 中文字幕 | 91久久偷偷做嫩草影院 | 精品一区二区三区久久 | 爱色婷婷| 亚洲理论片在线观看 | 91精品久久久久久久久久久久久 | a级免费观看 | 91视频免费看网站 | 中文字幕在线看 | 久久污视频 | 欧美午夜精品久久久久久孕妇 | 毛片在线播放网址 | 伊人影院在线观看 | 日韩在线播放欧美字幕 | 亚洲少妇天堂 | 97色婷婷 | 91最新网址在线观看 | 国产一级二级在线播放 | 黄色在线看网站 | 91麻豆精品91久久久久同性 | 99爱国产精品 | 国产精品一区二区三区视频免费 | 天天干天天操天天操 | 国产欧美精品一区aⅴ影院 99视频国产精品免费观看 | 992tv又爽又黄的免费视频 | 久在线 | 久久国产精品99久久久久久丝袜 | 久久在视频 | 日日干 天天干 | 久久中文字幕导航 | 91视频久久 | 激情久久小说 | 国产一区二区综合 | 免费在线色电影 | av在线看网站| 免费av成人在线 | 国产在线观看你懂得 | 久久久久免费精品 | 天天狠狠干 | 免费网址在线播放 | 国产91精品一区二区麻豆网站 | 欧美成人xxxxx| 天天爽夜夜爽人人爽曰av | 久久免费激情视频 | 麻豆传媒视频在线播放 | 久久久受www免费人成 | 免费91麻豆精品国产自产在线观看 | 色吊丝在线永久观看最新版本 | 久久久成人精品 | 日本中文字幕网址 | 中文有码在线视频 | 成人av一级片 | 天天看天天干 | 亚洲综合激情 | 在线观看色网 | 999久久久久久久久久久 | 日韩在线高清视频 | 久久艹99| 国产精品毛片一区视频播不卡 | 制服丝袜亚洲 | 亚洲国产精品电影 | 国产伦精品一区二区三区在线 | japanesexxxhd奶水 国产一区二区在线免费观看 | 久草在线费播放视频 | 日韩网站一区 | 中文字幕韩在线第一页 | 91手机在线看片 | 国产 中文 日韩 欧美 | 91视频在线国产 | 免费亚洲一区二区 | 天天草夜夜 | 日韩欧美一区二区三区黑寡妇 | 国产在线久久久 | 天天曰天天干 | 九九久久影院 | 麻豆影视在线播放 | 狠狠狠狠狠狠狠狠 | 97超级碰碰碰视频在线观看 | 国产一区二三区好的 | 国产一区二区三区高清播放 | 日韩毛片在线一区二区毛片 | 成片免费观看视频 | 香蕉精品在线观看 | 一区二区三区电影在线播 | avwww在线| 亚洲网站在线 | 精品成人在线 | 91精品国自产在线 | 久久久九色精品国产一区二区三区 | 激情在线网址 | 久草视频在线资源站 | 久久tv视频| 超碰人人在 | 成人av直播 | 亚洲精品玖玖玖av在线看 | 亚洲一区 av | 97福利在线 | 日韩小视频网站 | 在线欧美小视频 | 国产在线观看你懂得 | 手机在线看片日韩 | 久草视频在线播放 | 亚洲精品乱码白浆高清久久久久久 | 88av色 | 日韩精品在线免费播放 | 亚洲三级在线播放 | 国产精品久久亚洲 | 久久亚洲国产精品 | 性色av一区二区三区在线观看 | 国产精品色视频 | 女人高潮特级毛片 | 久久avav| 伊甸园永久入口www 99热 精品在线 | 91精品推荐 | 亚洲一区二区三区四区在线视频 | 国产成人亚洲精品自产在线 | 日韩在线在线 | 精品国产三级a∨在线欧美 免费一级片在线观看 | 九色激情网 | 激情影音先锋 | 亚洲成人精品在线 | 久久久久久高潮国产精品视 | 人人干人人上 | 久久99热这里只有精品国产 | 亚洲国产丝袜在线观看 | 久久99视频免费 | 亚洲天堂自拍视频 | 五月天网站在线 | 久久狠狠婷婷 | 免费在线观看亚洲视频 | 亚洲高清久久久 | 久久国产电影院 | 91亚色免费视频 | 国产精品短视频 | 亚洲九九九 | 国产精品久久久久久久久久不蜜月 | 欧美性超爽 | 成人福利av | 日韩影视大全 | 视频在线精品 | 亚洲春色奇米影视 | 在线综合 亚洲 欧美在线视频 | 国产精品久久久久久一区二区三区 | 亚洲国产成人精品电影在线观看 | 久久国产手机看片 | 亚洲黄色一级电影 | 91亚州 | 国产资源在线播放 | 伊人宗合网 | 欧美亚洲精品一区 | 97国产情侣爱久久免费观看 | 永久精品视频 | 最新国产视频 | 色婷婷一 | 国产精品高潮呻吟久久av无 | 欧美性色综合 | 欧美在线aaa | 欧美日韩不卡一区二区 | 国产亚洲精品av | 国产精品一区二区在线免费观看 | 亚洲精品乱码久久久久v最新版 | 国产一级二级三级在线观看 | 国产亚洲成av片在线观看 | 午夜精品一区二区三区免费视频 | 在线一二区 | 久久av网| 欧美另类交在线观看 | 在线观看日本高清mv视频 | 亚洲精品美女久久 | 国产在线观看,日本 | 毛片的网址 | 成人午夜剧场在线观看 | 96看片| 日女人电影| 久久免费激情视频 | 日韩av不卡播放 | 狠狠做深爱婷婷综合一区 | 欧美人操人| 免费看黄色91 | 欧美性视频网站 | 国产vs久久 |