首页 > 编程语言 > 详细

spring mvc 实战化项目之三板斧

时间:2016-11-20 13:19:35      阅读:362      评论:0      收藏:0      [点我收藏+]

接上文希望从一张表(tb_role_info 用户角色表)的CRUD展开spring mvc的项目实战化魅力。

开发技术选型:spring mvc+freemarker+bootstrap+mybatis+mysql。

项目目录结构:
技术分享

 (1)业务表 tb_role_info

-- ----------------------------
-- Table structure for `tb_role_info` 用户角色表
-- ----------------------------
DROP TABLE IF EXISTS `tb_role_info`;
CREATE TABLE `tb_role_info` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `role_name` varchar(32) NOT NULL DEFAULT ‘‘ COMMENT 角色名称,
  `role_mark` varchar(255) DEFAULT ‘‘ COMMENT 角色备注,
  `creater_id` int(11) NOT NULL DEFAULT 0 COMMENT 记录创建者id,
  `created_at` timestamp NULL DEFAULT NULL COMMENT 创建日期,
  `updated_at` timestamp NULL DEFAULT NULL COMMENT 更新日期,
  `time_stamp` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT 记录更新时间戳,
  PRIMARY KEY (`id`),
  KEY `tb_role_info_index` (`id`,`role_name`,`creater_id`) USING BTREE
) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8 COMMENT=角色信息表;

 

(2)业务界面 role.html

<!DOCTYPE html>
<html>
<head>
    <#include "header.html" />
    <link rel="stylesheet" type="text/css" href="../assets/backend/plugs/bootstrap-table/src/bootstrap-table.css?v=${version}"/>
</head>
<body> 
    <#include "navbar.html" />
    <div id="page-container">
             <!-- BEGIN SIDEBAR -->
       <#include "menu.html" />
    <!-- END SIDEBAR -->
        <!-- BEGIN RIGHTBAR -->
        <!-- END RIGHTBAR -->
        <div id="page-content">
            <div id="wrap">
                <div id="page-heading">
                    <ol class="breadcrumb">
                        <li><a href="#" title="icons">系统管理</a></li>
                        <li class="active">角色信息</li>
                    </ol>
                </div>
                <!-- container 内容显示区域begin-->
                <div class="container">
                    <div class=‘data_loading‘></div>
                   <div class="row">
                           <div class="col-xs-9" id="panel_list">
                            <div class="panel panel-gray">
                                <div class="panel-heading">
                                    <h4>
                                            角色信息 
                                        
                                    </h4>
                                    <div class="options">
                                          <div class="btn-group" id="table_tools_bar">
                                            <button type="button" class="btn btn-default dropdown-toggle btn-tools" data-toggle="dropdown" title="定制列显示"><i class="fa fa-th-list"></i> <span class="caret"></span></button>
                                            <button id="btn_role_refresh" type="button" class="btn btn-default btn-tools" title="角色刷新"><i class="fa fa-refresh"></i></button>
                                            <button id="btn_role_search" type="button" class="btn btn-default btn-tools" title="角色查询"><i class="fa fa-search"></i></button>
                                        </div>
                                    </div>
                                    <div class="options options-groups">
                                        <a href="javascript:;" id="btn_role_delete" title="角色删除" style="display:none;"><i class="fa fa-times"></i> 删除</a> 
                                        <a data-toggle="modal" href="#modalDialog" id="btn_role_edit" title="角色编辑"><i class="fa fa-edit"></i> 编辑</a> 
                                        <a data-toggle="modal" href="#modalDialog" id="btn_role_add" title="角色添加"><i class="fa fa-pencil"></i> 添加</a> 
                                    </div>
                                </div>
                                <div class="panel-body">
                                    
                                    <div class="table-responsive">
                                        <table id="table_role"></table>
                                    </div>
                                    <!-- add/edit modal-begin -->
                                    <div id="modalDialog" class="modal fade md-trigger"
                                        data-modal="md-fade-in-scale-up"
                                        tabindex="-1" 
                                        role="dialog" 
                                        aria-labelledby="modalLabel" 
                                        data-keyboard="true"
                                        data-backdrop="static" 
                                        aria-hidden="true">

                                        <div id="modalBox" class="modal-dialog">
                                            <div class="modal-content">
                                                <div class="modal-header">
                                                    <button type="button" class="close" data-dismiss="modal" aria-hidden="true">
                                                        ×</button>
                                                    <h4 class="modal-title" id="modalLabel"></h4>
                                                </div>
                                                <div class="modal-body">
                                                    <form id="modalForm" class="form-horizontal" role="form" enctype="multipart/form-data">
                                                        <!-- 隐藏值存放区域  begin-->
                                                        <input name="id" id="form_hidden_id" type="hidden">
                                                         <!-- 隐藏值存放区域 end-->
                                                        <div class="form-group">
                                                            <label for="form_txt_roleName" class="col-sm-2 control-label">角色名称</label>
                                                            <div class="col-sm-7">
                                                              <input id="form_txt_roleName" name="roleName" maxlength="32" placeholder="角色名称最多32个字符" required="" type="text" class="form-control">
                                                            </div>
                                                            <div class="col-sm-3">
                                                                <p class="help-block">角色名称必填!</p>
                                                            </div>
                                                        </div>
                                                        <div class="form-group">
                                                            <label for="form_txt_roleName" class="col-sm-2 control-label">角色权限</label>
                                                            <div class="col-sm-10">
                                                             <table id="table_module" class="table table-bordered">
                                                                    <thead>
                                                                        <tr>
                                                                            <th width="2%" style="padding: 10px">
                                                                            
                                                                            </th>
                                                                            <th width="28%" style="padding: 10px">
                                                                                模块
                                                                            </th>
                                                                                <th width="30%" style="padding: 10px">
                                                                                功能
                                                                            </th>
                                                                                <th width="30%" style="padding: 10px">
                                                                                动作
                                                                            </th>
                                                                        </tr>
                                                                    </thead>
                                                                    <#if moduleList??>
                                                                    <tbody>
                                                                    <#list moduleList as module> 
                                                                            <#if module.id==1 && user[‘userRoleId‘]!=1>
                                                                              
                                                                            <#else> 
                                                                                <tr>
                                                                                    <td>
                                                                                        <input type="checkbox" id="power_${module.id}" name="mod_${module.id}" value="${module.id}" onclick="checkModule(${module.id});" />
                                                                                    </td>
                                                                                    <td>
                                                                                        ${module.moduleCnName}
                                                                                    </td>
                                                                                    <td>
                                                                                        <table width="100%">
                                                                                            <#if module.children??> 
                                                                                                <#list module.children as child> 
                                                                                            <tr>
                                                                                                <td width="6%"><input type="checkbox" id="power_${child.id}" name="fun_${module.id}" value="${child.id}" onclick="checkFun(${module.id});" /></td>
                                                                                                <td width="94%">${child.moduleCnName}</td>
                                                                                            </tr>
                                                                                                </#list>
                                                                                            </#if>
                                                                                         </table>
                                                                                  </td>
                                                                                    <td>
                                                                                         <table width="100%">
                                                                                            <#if module.children??> 
                                                                                                <#list module.children as child> 
                                                                                                    <#if child.children??> 
                                                                                                            <#list child.children as subChild>
                                                                                                             <tr>
                                                                                                                <td width="6%"><input type="checkbox" id="power_${subChild.id}" name="act_${child.id}" value="${subChild.id}"  onclick="checkAction(${child.id});"/></td>
                                                                                                                <td width="94%">${subChild.moduleCnName}</td>
                                                                                                             </tr>
                                                                                                            </#list>
                                                                                                     </#if> 
                                                                                                </#list>
                                                                                            </#if>
                                                                                         </table>
                                                                                    </td>
                                                                                </tr>
                                                                            </#if>
                                                                         </#list>
                                                                    </tbody>
                                                                  </#if>
                                                                </table>
                                                            </div>
                                                        </div>
                                                        <div class="form-group">
                                                            <label for="form_txt_roleMark" class="col-sm-2 control-label">
                                                                角色描述</label>
                                                            <div class="col-sm-10">
                                                                    <textarea  id="form_txt_roleMark" name="roleMark" maxlength="255" placeholder="角色描述最多255个字符" class="form-control autosize"></textarea>
                                                            </div>
                                                        </div>
                                                    </form>
                                                </div>
                                                <div class="modal-footer">
                                                    <button id="btn_modal_save" type="button" class="btn btn-primary">
                                                        确定</button>
                                                    <button type="button" class="btn btn-default" data-dismiss="modal">
                                                        取消</button>
                                                </div>
                                            </div>
                                            <!-- /.modal-content -->
                                        </div>
                                        <!-- /.modal-dialog -->
                                    </div>
                                  <!-- add/edit modal-end -->

                                </div>
                            </div>
                        </div>
                        
                        
                        <div class="col-xs-3" id="panel_search"  style="display: none">
                            <div class="panel panel-gray">
                                <div class="panel-heading">
                                    <h4>
                                            角色查询 
                                    </h4>
                                </div>
                                <div class="panel-body">
                                    <form class="form-horizontal">
                                       <div class="row">
                                           <div class="col-md-12">
                                                <div class="form-group">
                                                     <label for="search_txt_roleName" class="col-sm-4 control-label">角色名称</label>
                                                    <div class="col-sm-8">
                                                       <input id="search_txt_roleName"  type="text" class="form-control" placeholder="请输入关键字...">
                                                    </div>
                                                </div>
                                            </div>
                                        </div>
                                    </form>
                                </div>
                                <div class="panel-footer">
                                    <div class="row">
                                        <div class="col-sm-12 col-sm-offset-3">
                                            <div class="btn-toolbar">
                                                <button id="btn_submit_search" class="btn-primary btn">确定</button>
                                               <button id="btn_cancel_search" class="btn-default btn">取消</button>
                                            </div>
                                        </div>
                                    </div>
                                </div>  
                            </div>
                      </div> 
                        
                        
                        
                   </div>
                </div>
                <!-- container 内容显示区域end-->
            </div>
            <!--wrap -->
        </div>
    </div>
    <!-- page-container -->
    <!-- page-content -->
   <#include "footer.html" />
</body>
</html>
<script type="text/javascript" charset="utf-8" src="../assets/backend/plugs/bootstrap-table/src/bootstrap-table.js?v=${version}"></script>
<script type="text/javascript" charset="utf-8" src="../assets/backend/plugs/bootstrap-table/src/locale/bootstrap-table-zh-CN.js?v=${version}"></script>
<script type="text/javascript" charset="utf-8" src="../assets/backend/js/sys_role.js?v=${version}"></script>

 (3)业务界面逻辑 sys_role.js

/**
* sys_role
* 角色信息
* @author steven9801@163.com
* @date 2015-11-19
*/
(function ($) {
    $(document).ready(function () {
        /**
        * 初始化
        */
        init();
        /**
        * 新建模态
        */
        $(‘#btn_role_add‘).click(function () {
            addModal()
        });
        /**
        * 编辑模态
        */
        $(‘#btn_role_edit‘).click(function () {
            var rowList = dataGrid.bootstrapTable(‘getSelections‘);
            var length = rowList.length;
            if (length == 0) {
                warningBox(‘请选择编辑对象.‘);
                return false;
            }
            if (length > 1) {
                warningBox(‘只能编辑一项.‘);
                return false;
            }
            editModal(rowList[0]);
        });
        /**
        * 保存动作
        */
        $(‘#btn_role_save‘).click(function () {
            switch (dialogType) {
                case ‘add‘:
                    onAdd();
                    break;
                case ‘edit‘:
                    onEdit();
                    break;
                default:
                    break;
            }
        });
        /**
        * 删除
        */
        $(‘#btn_role_delete‘).click(function () {
            onDelete();
        });
        //-----------------常规事件----------begin-------//
        /**
        * 刷新
        */
        $(‘#btn_role_refresh‘).click(function () {
            dataGrid.bootstrapTable(‘destroy‘);
            loadGrid();
        });
        /**
        * 展开
        */
        $(‘#btn_search_expand‘).click(function () {
            $(this).html(‘‘);
            if(!searchStatus){
                 $(‘#search_more_panel‘).show(‘slow‘);
                 $(this).html(‘<i class="fa fa-angle-double-down"></i>‘);
                 searchStatus = true;
             }
             else{
                 $(‘#search_more_panel‘).hide(‘slow‘);
                 $(this).html(‘<i class="fa fa-angle-double-up"></i>‘);
                 searchStatus = false;
             }
             return false;
        });
        /**
        * 提交查询
        */
        $(‘#btn_search_save‘).click(function () {
            dataGrid.bootstrapTable(‘destroy‘);
            bindGrid(function (params) {
                var roleName = $(‘#search_txt_roleName‘).val();
                role.pageSize = params.pageSize;
                role.pageStart = params.pageSize * (params.pageNumber - 1);
                role.sortName = params.sortName;
                role.sortOrder = params.sortOrder;
                if (roleName.length > 0) {
                    role.roleName = roleName;
                }
                return JSON.stringify(role);
            });
        });

        //-----------------常规事件----------end-------//
    });
})(jQuery);
/**
* 全局变量
*/
//--------------------------全局变量区---------------------------//
var dataGrid = null; //列表对象
var dialogType = ‘add‘;
var role = {};
var lock = false; //防止重复提交
var searchStatus = false; //查询面板状态
//--------------------------全局变量区---------------------------//
/**
* 初始化
*/
function init() {
    loadGrid();
    $("#form_modal .modal-body").css({ height: "650px", overflowX: "hidden", overflowY: "auto" });
    $(‘textarea.autosize‘).autosize({ append: "\n" });
};
/**
* 
* 加载列表
* 
*/
function loadGrid() {
    bindGrid(function (params) {
        return JSON.stringify({
            pageSize: params.pageSize,
            pageStart: params.pageSize * (params.pageNumber - 1),
            sortName: params.sortName,
            sortOrder: params.sortOrder
        });
    });
    return false;
};



/**
* 绑定列表
*/
function bindGrid(callBack) {
    dataGrid = $(‘#role_table‘).bootstrapTable({
        method: ‘POST‘,
        contentType: ‘application/json;charset=utf-8‘,
        url: ‘../admin/role‘,
        height: 500,
        striped: true,
        pagination: true,
        sidePagination: ‘server‘,
        pageSize: 25,
        pageList: [25, 50, 100, 200],
        showExport: true,
        sortName: ‘createdAt‘,
        sortOrder: ‘desc‘,
        minimunCountColumns: 2,
        formatLoadingMessage: function () {
            return ‘<img src="../backend/images/loading.gif"/>‘;
        },
        queryParams: callBack,
        columns:
        [
        { field: ‘state‘, checkbox: true },
        { field: ‘roleName‘, title: ‘角色名称‘, align: ‘left‘, valign: ‘middle‘, sortable: true },
        { field: ‘createdAt‘, title: ‘创建时间‘, align: ‘center‘, valign: ‘middle‘, sortable: true },
        { field: ‘operate‘, title: ‘操作‘, align: ‘left‘, valign: ‘middle‘, sortable: false, formatter: operateFormatter, events: operateEvents }
        ]
    });
};

/**
* 格式化操作列
* 
*/
function operateFormatter(value, row, index) {
    var content = [];
    content.push(‘ <a class="view" data-toggle="modal" href="#form_modal" title="角色查看"><i class="fa fa-eye"></i></a>‘);
    content.push(‘ <a class="edit" data-toggle="modal" href="#form_modal" title="角色编辑"><i class="fa fa-edit"></i></a>‘);
    content.push(‘ <a class="delete" href="javascript:void(0)" title="角色删除"><i class="fa fa-times"></i></a>‘);
    return content.join(‘‘);
};

/**
* 操作列事件
*/
window.operateEvents = {
    ‘click .view‘: function (e, value, row, index) {
        viewModal(row);
        return false;
    },
    ‘click .edit‘: function (e, value, row, index) {
        editModal(row);
        return false;
    },
    ‘click .delete‘: function (e, value, row, index) {
        if (lock) return false;
        lock = true;
        if (userToken.id != row.createrId) {
            lock = false;
            warningBox(‘对不起,您无权删除该角色.‘);
            return false;
        }
        var ids = [];
        ids.push(row.id);
        var params = {};
        params.ids = ids;
        deleteModal(params);
    }
};

/**
* 显示模态
*/
function showModal(action, title, width) {
    dialogType = action;
    $(‘.modal-footer‘).show();
    $(‘#form_modal #form_modal_title‘).html(title);
    $(‘#form_modal_dialog‘).css({ width: width });
    $(‘select,textarea,input‘).prop(‘disabled‘, false);
    $(‘#back-to-top‘).trigger(‘click‘);
    return false;
};

/**
* 绑定模态
*/
function bindModal(row) {

    $(‘#form_hidden_id‘).val(row.id);
    $(‘#form_hidden_createrId‘).val(row.createrId);
    $(‘#form_txt_roleName‘).val(row.roleName);
    $(‘#form_txt_roleMark‘).val(row.roleMark);

    $("input[id^=‘power_‘]").removeAttr("checked");
    var moduleIdList = row.moduleIdList;
    for (var i in moduleIdList) {
        var id = moduleIdList[i];
        $("input[id=‘power_" + id + "‘]").prop("checked", true);
    }
};

/**
* 查看模态
*/
function viewModal(row) {
    showModal(‘view‘, ‘角色查看‘, ‘60%‘);
    bindModal(row);
    $(‘select,textarea,input:not(.fixed-table-container input)‘).prop(‘disabled‘, true);
    $(‘#search_panel select,#search_panel input‘).prop(‘disabled‘, false);
    $(‘#table_tools_bar‘).find(‘input‘).prop(‘disabled‘, false);
    $(‘.modal-footer‘).hide();
    return false;
};

/**
* 编辑模态
*/
function editModal(row) {
    role = row;
    if (userToken.id != row.createrId) {
        pauseModal(‘#form_modal‘);
        warningBox(‘对不起,您无权编辑该角色.‘);
        return false;
    }
    showModal(‘edit‘, ‘角色编辑‘, ‘60%‘);
    bindModal(row);
    return false;
};

/**
* 新建模态
*/
function addModal() {
    showModal(‘add‘, ‘角色新建‘, ‘60%‘);
    $(‘input[type=text],input[type=hidden],input[type=number],textarea‘).val(‘‘);
    $(‘select option‘).eq(0).prop(‘selected‘, true);
    $("input[id^=‘power_‘]").prop(‘checked‘, false);
    return false;
};

/**
* 验证表单
*/
function checkForm() {
    if (lock) return false;
    lock = true;
    var roleName = $("#form_txt_roleName").val();
    if (roleName.length == 0) {
        warningBox("角色名称不能为空.");
        lock = false;
        return false;
    }

    if (roleName.length > 32) {
        warningBox("角色名称最多32个字符.");
        lock = false;
        return false;
    }

    if ($("input[id^=‘power_‘]:checkbox:checked").length == 0) {
        warningBox("请选择权限.");
        lock = false;
        return false;
    }


    var roleMark = $("#form_txt_roleMark").val();
    if (roleMark.length > 255) {
        warningBox("角色描述最多255个字符.");
        lock = false;
        return false;
    }

    var moduleIdList = [];
    $("input[id^=‘power_‘]:checkbox:checked").each(function () {
        var id = parseInt($(this).val());
        moduleIdList.push(id);
    });

    role.roleName = roleName;
    role.roleMark = roleMark;
    role.moduleIdList = moduleIdList;
    return true;
};

/**
* 角色添加
*/
function onAdd() {
    if (!checkForm()) {
        return false;
    }
    $(‘.data-loading‘).show();
    var task = new DelayedTask(function () {
        $.ajax({
            cache: false,
            type: "POST",
            dataType: "json",
            contentType: "application/json;charset=utf-8",
            url: "../admin/role.add",
            data: JSON.stringify(role),
            timeout: 30000,
            success: function (data) {
                if (data) {
                    $(".data-loading").hide();
                    var code = data.code;
                    if (code != 0) {
                        dangerBox(data.message);
                        lock = false;
                        return false;
                    }
                    lock = false;
                    $(‘#form_modal‘).modal(‘hide‘)
                    successBox(‘角色新建成功.‘);
                    $(‘#btn_role_refresh‘).trigger(‘click‘);
                }
                return false;
            },
            error: function (e) {
                if (e.status == 404) {
                    window.location = "../404.html";
                }
                else if (e.status == 500) {
                    window.location = "../500.html";
                }
            }
        });
    });
    task.delay(500);
    return false;
};

/**
* 角色编辑
*/
function onEdit() {
    if (!checkForm()) {
        return false;
    }
    $(‘.data-loading‘).show();
    var task = new DelayedTask(function () {
        $.ajax({
            cache: false,
            type: "POST",
            dataType: "json",
            contentType: "application/json;charset=utf-8",
            url: "../admin/role.edit",
            data: JSON.stringify(role),
            timeout: 30000,
            success: function (data) {
                if (data) {
                    $(".data-loading").hide();
                    var code = data.code;
                    if (code != 0) {
                        dangerBox(data.message);
                        lock = false;
                        return false;
                    }

                    lock = false;
                    $(‘#form_modal‘).modal(‘hide‘)
                    successBox(‘角色编辑成功.‘);
                    $(‘#btn_role_refresh‘).trigger(‘click‘);
                }
                return false;
            },
            error: function (e) {
                if (e.status == 404) {
                    window.location = "../404.html";
                }
                else if (e.status == 500) {
                    window.location = "../500.html";
                }
            }
        });
    });
    task.delay(500);
    return false;
};

/**
* 角色删除
*/
function onDelete() {
    if (lock) return false;
    lock = true;
    var ids = [];
    var rowList = dataGrid.bootstrapTable(‘getSelections‘);
    var length = rowList.length;
    if (length == 0) {
        warningBox(‘请选择删除对象.‘);
        lock = false;
        return false;
    }
    var flag = false;
    for (var i in rowList) {
        var row = rowList[i];
        var createrId = row.createrId;
        if (userToken.id != createrId) {
            flag = true;
        }
        var id = row.id;
        ids.push(id);
    }
    if (flag) {
        warningBox(‘对不起,您无权删除该角色.‘);
        lock = false;
        return false;
    }
    var params = {};
    params.ids = ids;
    deleteModal(ids);
    return false;
};

/**
* 删除模态
*/
function deleteModal(ids) {
    confirmBox(‘您确定要删除吗?!‘, function (result) {
        if (result) {
            $(‘.data-loading‘).show();
            $.ajax({
                cache: false,
                type: ‘POST‘,
                dataType: ‘json‘,
                contentType: ‘application/json;charset=utf-8‘,
                url: ‘../admin/role.delete‘,
                data: JSON.stringify(ids),
                timeout: 30000,
                success: function (data) {
                    if (data) {
                        $(‘.data-loading‘).hide();
                        var code = data.code;
                        if (code != 0) {
                            dangerBox(data.message);
                            lock = false;
                            return false;
                        }
                        lock = false;
                        successBox(‘角色删除成功.‘);
                        $(‘#btn_role_refresh‘).trigger(‘click‘);
                    }
                    return false;
                },
                error: function (e) {
                    if (e.status == 404) {
                        window.location = ‘../404.html‘;
                    }
                    else if (e.status == 500) {
                        window.location = ‘../500.html‘;
                    }
                }
            });
        }
        else {
            lock = false;
        }
    });
    return false;
};



/**
* 选择模块
*/
function checkModule(moduleId) {
    $("input[name=‘fun_" + moduleId + "‘]").each(function () {
        if ($(this).is(":checked") == true) {
            $(this).prop("checked", false)
        }
        else {
            $(this).prop("checked", true);
        }
    });

};
/**
* 选择功能
*/
function checkFun(moduleId) {
    var funLength = $("input[name=‘fun_" + moduleId + "‘]:checkbox:checked").length;
    if (funLength != 0) {
        $("input[name=‘mod_" + moduleId + "‘]").prop("checked", true);
    }
    else {
        $("input[name=‘mod_" + moduleId + "‘]").prop("checked", false);
    }
};

/**
* 选择动作
*/
function checkAction(funId) {
    var actLength = $("input[name=‘act_" + funId + "‘]:checkbox:checked").length;
    if (actLength != 0) {
        $("input[id=‘power_" + funId + "‘]").prop("checked", true);
    }
    else {
        $("input[id=‘power_" + funId + "‘]").prop("checked", false);
    }

};

4)业务控制器 RoleController.java

package com.hwabao.controller;

import java.util.ArrayList;
import java.util.List;

import javax.servlet.http.HttpServletRequest;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.ResponseBody;
import org.springframework.web.servlet.ModelAndView;

import com.hwabao.common.CommanUtil;
import com.hwabao.common.EntityGrid;
import com.hwabao.common.SessionValidate;
import com.hwabao.model.ModuleInfo;
import com.hwabao.model.RoleInfo;
import com.hwabao.model.RoleModule;
import com.hwabao.model.UserInfo;
import com.hwabao.service.IModuleInfoService;
import com.hwabao.service.IRoleInfoService;
import com.hwabao.service.IRoleModuleService;
import com.hwabao.service.ITransactionalService;

/**
 * 
* @ClassName: RoleController 
* @Description: 角色控制器
* @author steven9801@163.com 
* @date 2015-4-21 下午04:36:24 
*
 */
@Controller
@RequestMapping("/admin")
public class RoleController extends BaseController
{
    private static final Logger logger = LoggerFactory.getLogger(RoleController.class);
    
    @Autowired
    private HttpServletRequest request;

    @Autowired
    private IRoleInfoService roleInfoService;
    @Autowired
    private IModuleInfoService moduleInfoService;
    @Autowired
    private IRoleModuleService roleModuleService;
    @Autowired
    private ITransactionalService transactionalService;
    /**
     * 角色界面
     */
    @SessionValidate(comment="角色界面")
    @RequestMapping(value = "/role", method = RequestMethod.GET)
    public ModelAndView index() throws Exception
    {
        UserInfo user =  this.appContext.getCurrentUser(request);
        if(user!=null)
        {
            ModelAndView mv = this.handlerModelView(user,"backend/role");
            ModuleInfo model = new ModuleInfo();
            model.moduleSortAsc();
            List<ModuleInfo> list = moduleInfoService.selectModuleInfo(model);
            List<ModuleInfo> moduleList = this.toObjectModuleTree(list,0);
            mv.addObject("moduleList", moduleList);
            return  mv;
        }
        return this.handlerModelView("backend/login"); 
    }

    
    @SessionValidate(comment="角色列表")
    @RequestMapping(value = "/role", method = RequestMethod.POST)
    @ResponseBody
    public String grid(@RequestBody RoleInfo roleInfo) throws Exception
    {
        UserInfo user =  this.appContext.getCurrentUser(request);
        if(user==null)
        {
            return this.handlerSuccessMessage("../admin/login");
        }
    
        try 
        {
            RoleInfo roleInfoModel = findRoleInfo(roleInfo);
    
            int total  = roleInfoService.getRoleInfoSearchCount(roleInfoModel);
            List<RoleInfo> roleList = roleInfoService.searchRoleInfo(roleInfoModel);
            
            EntityGrid<RoleInfo> entityGrid = null;
            if(roleList!=null&&roleList.size()>0)
            {
                for(RoleInfo role:roleList)
                {
                    List<Integer> moduleIdList =  new ArrayList<Integer>();
                    RoleModule roleModule = new RoleModule();
                    roleModule.setRoleId(role.getId());
                    List<RoleModule> roleModuleList = roleModuleService.selectRoleModule(roleModule);
                    for(RoleModule module:roleModuleList)
                    {
                        moduleIdList.add(module.getModuleId());
                    }
                    role.setModuleIdList(moduleIdList);
                }

                entityGrid = new EntityGrid<RoleInfo>();
                entityGrid.rows = roleList;
                entityGrid.total = total;
            }
            else
            {
                entityGrid = new EntityGrid<RoleInfo>();
            }
            return this.handlerResponseMessage(entityGrid);
        } 
        catch (Exception e) 
        {
            logger.debug(e.getMessage().toString());
            return this.handlerFailMessage(e.getMessage().toString());
        }
    }
    
    
    /**
     * 角色添加
     */
    @SessionValidate(comment="角色添加")
    @RequestMapping(value = "/role.add", method = RequestMethod.POST,consumes="application/json")
    @ResponseBody
    public String add(@RequestBody RoleInfo roleInfo) throws Exception 
    {
        UserInfo user =  this.appContext.getCurrentUser(request);
        if(user==null)
        {
            return this.handlerSuccessMessage("../admin/login");
        }
    
        try 
        {
            String roleName = roleInfo.getRoleName();
            RoleInfo model = new RoleInfo();
            model.setRoleName(roleName);
            RoleInfo cl = roleInfoService.getRoleInfo(model);
            if(cl!=null)
            {
                throw new Exception("角色名称重复.");
            }
            
            roleInfo.setCreatedAt(CommanUtil.getCurrentDatetime());
            roleInfo.setCreaterId(user.getId());
            int change = transactionalService.insertRoleInfo(roleInfo);
            if(change==0)
            {
                throw new Exception("角色新建失败.");
            }
            this.logSuccess("角色新建");
            return this.handlerSuccessMessage("../admin/role");
        } 
        catch (Exception e) 
        {
            this.logFailed("角色新建");
            logger.debug(e.getMessage().toString());
            return this.handlerFailMessage(e.getMessage().toString());
        }
    }

    
    /**
     * 角色编辑
     */
    @SessionValidate(comment="角色编辑")
    @RequestMapping(value = "/role.edit", method = RequestMethod.POST,consumes="application/json")
    @ResponseBody
    public String edit(@RequestBody RoleInfo roleInfo) throws Exception 
    {
        UserInfo user =  this.appContext.getCurrentUser(request);
        if(user==null)
        {
            return this.handlerSuccessMessage("../admin/login");
        }
        
        try 
        {
            int change = transactionalService.updateRoleInfo(roleInfo);
            if(change==0)
            {
                throw new Exception("角色编辑失败.");
            }
            this.logSuccess("角色编辑");
            return this.handlerSuccessMessage("../admin/role");
        } 
        catch (Exception e) 
        {
            this.logFailed("角色编辑");
            logger.debug(e.getMessage().toString());
            return this.handlerFailMessage(e.getMessage().toString());
        }
    }
    
    /**
     * 角色删除
     */
    @SessionValidate(comment="角色删除")
    @RequestMapping(value = "/role.delete",method = RequestMethod.POST,consumes="application/json")
    @ResponseBody
    public String delete(@RequestBody List<Integer> params) throws Exception
    {
        UserInfo user =  this.appContext.getCurrentUser(request);
        if(user==null)
        {
            return this.handlerSuccessMessage("../admin/login");
        }
        
        try 
        {
            if(params.size()==0)
            {
                throw new Exception("params参数非空.");
            }
            
            List<RoleInfo> roleList = new ArrayList<RoleInfo>();
            for(Integer roleid : params)
            {
                RoleInfo roleInfo = new RoleInfo();
                roleInfo.setId(roleid);
                roleList.add(roleInfo);
            }
            int change = transactionalService.deleteRoleInfo((ArrayList<RoleInfo>)roleList);
            if(change==0)
            {
                throw new Exception("角色删除失败.");
            }
            this.logSuccess("角色删除");
            return this.handlerSuccessMessage("../admin/role");
        }
        catch (Exception e) 
        {
            this.logFailed("角色删除");
            logger.debug(e.getMessage().toString());
            return this.handlerFailMessage(e.getMessage().toString());
        }
    }
    
    /**
     * 封装前端查询角色条件的方法
     * @param roleInfo
     * @return
     */
    private RoleInfo findRoleInfo(RoleInfo roleInfo)
    {
        if(roleInfo.getSortName()!=null&&roleInfo.getSortOrder()!=null)
        {
            String sortName = roleInfo.getSortName();
            String sortOrder = roleInfo.getSortOrder();
            roleInfo.setOrderBy(sortName, sortOrder);
        }
        if(roleInfo.getRoleName() != null)
        {
            roleInfo.roleNameLike(roleInfo.getRoleName());
        }
        return roleInfo;
    }
    
}

(5)业务实体层 RoleInfo.java

package com.hwabao.model;

import java.util.List;

import com.hwabao.common.VoBase;

/**
 * @author steven9801@163.com
 */

public class RoleInfo extends VoBase<RoleInfo> {

    private static final long serialVersionUID = 1L;

 /**
  * 
  */
    private Integer id;

 /**
  * 角色名称
  */
    private String roleName;

 /**
  * 角色备注
  */
    private String roleMark;

 /**
  * 记录创建者id
  */
    private Integer createrId;

 /**
  * 
  */
    private String updatedAt;

 /**
  * 
  */
    private String createdAt;

 /**
  * 记录更新时间戳
  */
    private String timeStamp;

    //---------------------扩展属性-----------begin-----------//
    
    private List<Integer> moduleIdList;  
    public List<Integer> getModuleIdList() {
        return moduleIdList;
    }

    public void setModuleIdList(List<Integer> moduleIdList) {
        this.moduleIdList = moduleIdList;
    }


    //---------------------扩展属性-----------end-----------//
    

    public Integer getId() {
        return this.id;
    }

    public void setId(Integer id) {
        this.id = id;
    }

    public void idDesc() {
        _setOrder("id", "DESC");
    }

    public void idAsc() {
        _setOrder("id", "ASC");
    }

    public void idMax(Integer max) {
        _setRangeMax("id", String.valueOf(max));
    }

    public void idMin(Integer min) {
        _setRangeMin("id", String.valueOf(min));
    }

    public void idEqual(boolean equal) {
        _setRangeEqual("id", equal);
    }

    public void idIn(Integer in) {
        _setIn("id", String.valueOf(in));
    }

    public void idNotIn(Integer notin) {
        _setNotIn("id", String.valueOf(notin));
    }

    public void idOr(Integer or) {
        _setOr("id", String.valueOf(or));
    }

    public void idOrIn(Integer in) {
        _setOrIn("id", String.valueOf(in));
    }

    public void idOrNotIn(Integer notin) {
        _setOrNotIn("id", String.valueOf(notin));
    }

    public void idNull() {
        _setNull("id", null);
    }

    public void idNotNull(Integer nl) {
        _setNotNull("id", String.valueOf(nl));
    }

    public String getRoleName() {
        return this.roleName;
    }

    public void setRoleName(String roleName) {
        this.roleName = roleName;
    }

    public void roleNameDesc() {
        _setOrder("roleName", "DESC");
    }

    public void roleNameAsc() {
        _setOrder("roleName", "ASC");
    }

    public void roleNameMax(String max) {
        _setRangeMax("roleName", max);
    }

    public void roleNameMin(String min) {
        _setRangeMin("roleName", min);
    }

    public void roleNameEqual(boolean equal) {
        _setRangeEqual("roleName", equal);
    }

    public void roleNameLike(String like) {
        _setLike("roleName", like);
        setRoleName(null);
    }

    public void roleNameOrLike(String like) {
        _setOrLike("roleName", like);
        setRoleName(null);
    }

    public void roleNameIn(String in) {
        _setIn("roleName", in);
    }

    public void roleNameNotIn(String notin) {
        _setNotIn("roleName", notin);
    }

    public void roleNameOr(String or) {
        _setOr("roleName", or);
    }

    public void roleNameOrIn(String in) {
        _setOrIn("roleName", in);
    }

    public void roleNameOrNotIn(String notin) {
        _setOrNotIn("roleName", notin);
    }

    public void roleNameNull() {
        _setNull("roleName", null);
    }

    public void roleNameNotNull(String nl) {
        _setNotNull("roleName", nl);
    }

    public String getRoleMark() {
        return this.roleMark;
    }

    public void setRoleMark(String roleMark) {
        this.roleMark = roleMark;
    }

    public void roleMarkDesc() {
        _setOrder("roleMark", "DESC");
    }

    public void roleMarkAsc() {
        _setOrder("roleMark", "ASC");
    }

    public void roleMarkMax(String max) {
        _setRangeMax("roleMark", max);
    }

    public void roleMarkMin(String min) {
        _setRangeMin("roleMark", min);
    }

    public void roleMarkEqual(boolean equal) {
        _setRangeEqual("roleMark", equal);
    }

    public void roleMarkLike(String like) {
        _setLike("roleMark", like);
        setRoleMark(null);
    }

    public void roleMarkOrLike(String like) {
        _setOrLike("roleMark", like);
        setRoleMark(null);
    }

    public void roleMarkIn(String in) {
        _setIn("roleMark", in);
    }

    public void roleMarkNotIn(String notin) {
        _setNotIn("roleMark", notin);
    }

    public void roleMarkOr(String or) {
        _setOr("roleMark", or);
    }

    public void roleMarkOrIn(String in) {
        _setOrIn("roleMark", in);
    }

    public void roleMarkOrNotIn(String notin) {
        _setOrNotIn("roleMark", notin);
    }

    public void roleMarkNull() {
        _setNull("roleMark", null);
    }

    public void roleMarkNotNull(String nl) {
        _setNotNull("roleMark", nl);
    }

    public Integer getCreaterId() {
        return this.createrId;
    }

    public void setCreaterId(Integer createrId) {
        this.createrId = createrId;
    }

    public void createrIdDesc() {
        _setOrder("createrId", "DESC");
    }

    public void createrIdAsc() {
        _setOrder("createrId", "ASC");
    }

    public void createrIdMax(Integer max) {
        _setRangeMax("createrId", String.valueOf(max));
    }

    public void createrIdMin(Integer min) {
        _setRangeMin("createrId", String.valueOf(min));
    }

    public void createrIdEqual(boolean equal) {
        _setRangeEqual("createrId", equal);
    }

    public void createrIdIn(Integer in) {
        _setIn("createrId", String.valueOf(in));
    }

    public void createrIdNotIn(Integer notin) {
        _setNotIn("createrId", String.valueOf(notin));
    }

    public void createrIdOr(Integer or) {
        _setOr("createrId", String.valueOf(or));
    }

    public void createrIdOrIn(Integer in) {
        _setOrIn("createrId", String.valueOf(in));
    }

    public void createrIdOrNotIn(Integer notin) {
        _setOrNotIn("createrId", String.valueOf(notin));
    }

    public void createrIdNull() {
        _setNull("createrId", null);
    }

    public void createrIdNotNull(Integer nl) {
        _setNotNull("createrId", String.valueOf(nl));
    }

    public String getUpdatedAt() {
        return this.updatedAt;
    }

    public void setUpdatedAt(String updatedAt) {
        this.updatedAt = updatedAt;
    }

    public void updatedAtDesc() {
        _setOrder("updatedAt", "DESC");
    }

    public void updatedAtAsc() {
        _setOrder("updatedAt", "ASC");
    }

    public void updatedAtMax(String max) {
        _setRangeMax("updatedAt", max);
    }

    public void updatedAtMin(String min) {
        _setRangeMin("updatedAt", min);
    }

    public void updatedAtEqual(boolean equal) {
        _setRangeEqual("updatedAt", equal);
    }

    public void updatedAtLike(String like) {
        _setLike("updatedAt", like);
        setUpdatedAt(null);
    }

    public void updatedAtOrLike(String like) {
        _setOrLike("updatedAt", like);
        setUpdatedAt(null);
    }

    public void updatedAtIn(String in) {
        _setIn("updatedAt", in);
    }

    public void updatedAtNotIn(String notin) {
        _setNotIn("updatedAt", notin);
    }

    public void updatedAtOr(String or) {
        _setOr("updatedAt", or);
    }

    public void updatedAtOrIn(String in) {
        _setOrIn("updatedAt", in);
    }

    public void updatedAtOrNotIn(String notin) {
        _setOrNotIn("updatedAt", notin);
    }

    public void updatedAtNull() {
        _setNull("updatedAt", null);
    }

    public void updatedAtNotNull(String nl) {
        _setNotNull("updatedAt", nl);
    }

    public String getCreatedAt() {
        return this.createdAt;
    }

    public void setCreatedAt(String createdAt) {
        this.createdAt = createdAt;
    }

    public void createdAtDesc() {
        _setOrder("createdAt", "DESC");
    }

    public void createdAtAsc() {
        _setOrder("createdAt", "ASC");
    }

    public void createdAtMax(String max) {
        _setRangeMax("createdAt", max);
    }

    public void createdAtMin(String min) {
        _setRangeMin("createdAt", min);
    }

    public void createdAtEqual(boolean equal) {
        _setRangeEqual("createdAt", equal);
    }

    public void createdAtLike(String like) {
        _setLike("createdAt", like);
        setCreatedAt(null);
    }

    public void createdAtOrLike(String like) {
        _setOrLike("createdAt", like);
        setCreatedAt(null);
    }

    public void createdAtIn(String in) {
        _setIn("createdAt", in);
    }

    public void createdAtNotIn(String notin) {
        _setNotIn("createdAt", notin);
    }

    public void createdAtOr(String or) {
        _setOr("createdAt", or);
    }

    public void createdAtOrIn(String in) {
        _setOrIn("createdAt", in);
    }

    public void createdAtOrNotIn(String notin) {
        _setOrNotIn("createdAt", notin);
    }

    public void createdAtNull() {
        _setNull("createdAt", null);
    }

    public void createdAtNotNull(String nl) {
        _setNotNull("createdAt", nl);
    }

    public String getTimeStamp() {
        return this.timeStamp;
    }

    public void setTimeStamp(String timeStamp) {
        this.timeStamp = timeStamp;
    }

    public void timeStampDesc() {
        _setOrder("timeStamp", "DESC");
    }

    public void timeStampAsc() {
        _setOrder("timeStamp", "ASC");
    }

    public void timeStampMax(String max) {
        _setRangeMax("timeStamp", max);
    }

    public void timeStampMin(String min) {
        _setRangeMin("timeStamp", min);
    }

    public void timeStampEqual(boolean equal) {
        _setRangeEqual("timeStamp", equal);
    }

    public void timeStampLike(String like) {
        _setLike("timeStamp", like);
        setTimeStamp(null);
    }

    public void timeStampOrLike(String like) {
        _setOrLike("timeStamp", like);
        setTimeStamp(null);
    }

    public void timeStampIn(String in) {
        _setIn("timeStamp", in);
    }

    public void timeStampNotIn(String notin) {
        _setNotIn("timeStamp", notin);
    }

    public void timeStampOr(String or) {
        _setOr("timeStamp", or);
    }

    public void timeStampOrIn(String in) {
        _setOrIn("timeStamp", in);
    }

    public void timeStampOrNotIn(String notin) {
        _setOrNotIn("timeStamp", notin);
    }

    public void timeStampNull() {
        _setNull("timeStamp", null);
    }

    public void timeStampNotNull(String nl) {
        _setNotNull("timeStamp", nl);
    }

    public String _getPrimary() {
        return String.valueOf(id);
    }

    public String toString() {
        StringBuffer sb = new StringBuffer();
        sb.append("{\n");
        sb.append("    id:" + getId() + ",\n");
        sb.append("    role_name:" + _getSnap(getRoleName()) + ",\n");
        sb.append("    role_mark:" + _getSnap(getRoleMark()) + ",\n");
        sb.append("    creater_id:" + getCreaterId() + ",\n");
        sb.append("    updated_at:" + _getSnap(getUpdatedAt()) + ",\n");
        sb.append("    created_at:" + _getSnap(getCreatedAt()) + ",\n");
        sb.append("    time_stamp:" + _getSnap(getTimeStamp()) + "\n");
        sb.append("}\n");
        return sb.toString();
    }

    public void setOrderBy(String sortName,String sortOrder){
      if(sortOrder.equalsIgnoreCase("asc")){
          if(sortName.equalsIgnoreCase("id")){
           idAsc();
               }
          if(sortName.equalsIgnoreCase("roleName")){
           roleNameAsc();
               }
          if(sortName.equalsIgnoreCase("roleMark")){
           roleMarkAsc();
               }
          if(sortName.equalsIgnoreCase("createrId")){
           createrIdAsc();
               }
          if(sortName.equalsIgnoreCase("updatedAt")){
           updatedAtAsc();
               }
          if(sortName.equalsIgnoreCase("createdAt")){
           createdAtAsc();
               }
          if(sortName.equalsIgnoreCase("timeStamp")){
           timeStampAsc();
               }
            }
       else if(sortOrder.equalsIgnoreCase("desc")){
       if(sortName.equalsIgnoreCase("id")){
           idDesc();
                  }
       if(sortName.equalsIgnoreCase("roleName")){
           roleNameDesc();
                  }
       if(sortName.equalsIgnoreCase("roleMark")){
           roleMarkDesc();
                  }
       if(sortName.equalsIgnoreCase("createrId")){
           createrIdDesc();
                  }
       if(sortName.equalsIgnoreCase("updatedAt")){
           updatedAtDesc();
                  }
       if(sortName.equalsIgnoreCase("createdAt")){
           createdAtDesc();
                  }
       if(sortName.equalsIgnoreCase("timeStamp")){
           timeStampDesc();
                  }
              }
}
    public boolean equals(Object o) {
        if (o instanceof RoleInfo) {
            RoleInfo roleInfo = (RoleInfo) o;
            return roleInfo.getId().equals(getId()) &&
                   roleInfo.getRoleName().equals(getRoleName()) &&
                   roleInfo.getRoleMark().equals(getRoleMark()) &&
                   roleInfo.getCreaterId().equals(getCreaterId()) &&
                   roleInfo.getUpdatedAt().equals(getUpdatedAt()) &&
                   roleInfo.getCreatedAt().equals(getCreatedAt()) &&
                   roleInfo.getTimeStamp().equals(getTimeStamp());
        }
        return false;
    }
}

(6)业务数据层 IRoleInfoData.java

package com.hwabao.data;

import java.util.List;
import java.util.ArrayList;
import com.hwabao.model.RoleInfo;
import com.hwabao.common.Pager;

/**
 * @author steven9801@163.com
 */

public interface IRoleInfoData {

    public int insertRoleInfo(RoleInfo roleInfo);

    public int updateRoleInfo(RoleInfo roleInfo);

    public int deleteRoleInfo(RoleInfo roleInfo);

    public RoleInfo getRoleInfo(RoleInfo roleInfo);

    public int getRoleInfoCount(RoleInfo roleInfo);

    public List<RoleInfo> selectRoleInfo(RoleInfo roleInfo);

    public List<RoleInfo> selectRoleInfo(RoleInfo roleInfo, Pager pager);

    public List<RoleInfo> selectRoleInfoByList(ArrayList<Integer> arrListId);

    public int getRoleInfoSearchCount(RoleInfo roleInfo);

    public List<RoleInfo> searchRoleInfo(RoleInfo roleInfo);

    public List<RoleInfo> searchRoleInfo(RoleInfo roleInfo, Pager pager);

}

(7)业务服务层 RoleInfoService.java

package com.hwabao.service.impl;

import java.util.List;
import java.util.ArrayList;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Propagation;
import org.springframework.transaction.annotation.Transactional;
import com.hwabao.data.IRoleInfoData;
import com.hwabao.model.RoleInfo;
import com.hwabao.service.IRoleInfoService;
import com.hwabao.common.Pager;

/**
 * @author steven9801@163.com
 */

@Service
public class RoleInfoService implements IRoleInfoService {

    @Autowired
    private IRoleInfoData roleInfoData;

    @Override
    @Transactional(readOnly = false, propagation = Propagation.REQUIRED, rollbackFor = { Exception.class })
    public int insertRoleInfo(RoleInfo roleInfo) {
        return roleInfoData.insertRoleInfo(roleInfo);
    }

    @Override
    @Transactional(readOnly = false, propagation = Propagation.REQUIRED, rollbackFor = { Exception.class })
    public int insertRoleInfoBatch(ArrayList<RoleInfo> arrListRoleInfo) {
        int insertedCount = 0;
        int result;
        RoleInfo roleInfo;
        for (int i = 0; i < arrListRoleInfo.size(); i++) {
            roleInfo = arrListRoleInfo.get(i);
            result = roleInfoData.insertRoleInfo(roleInfo);
            if (result < 1) {
                return 0;
            }
            insertedCount++;
        }
        return insertedCount;
    }

    @Override
    @Transactional(readOnly = false, propagation = Propagation.REQUIRED, rollbackFor = { Exception.class })
    public int updateRoleInfo(RoleInfo roleInfo) {
        return roleInfoData.updateRoleInfo(roleInfo);
    }

    @Override
    @Transactional(readOnly = false, propagation = Propagation.REQUIRED, rollbackFor = { Exception.class })
    public int updateRoleInfoBatch(ArrayList<RoleInfo> arrListRoleInfo) {
        int updatedCount = 0;
        int result;
        RoleInfo roleInfo;
        for (int i = 0; i < arrListRoleInfo.size(); i++) {
            roleInfo = arrListRoleInfo.get(i);
            result = roleInfoData.updateRoleInfo(roleInfo);
            if (result < 1) {
                return 0;
            }
            updatedCount++;
        }
        return updatedCount;
    }

    @Override
    @Transactional(readOnly = false, propagation = Propagation.REQUIRED, rollbackFor = { Exception.class })
    public int deleteRoleInfo(RoleInfo roleInfo) {
        return roleInfoData.deleteRoleInfo(roleInfo);
    }

    @Override
    @Transactional(readOnly = false, propagation = Propagation.REQUIRED, rollbackFor = { Exception.class })
    public int deleteRoleInfoBatch(ArrayList<RoleInfo> arrListRoleInfo) {
        int deletedCount = 0;
        int result;
        RoleInfo roleInfo;
        for (int i = 0; i < arrListRoleInfo.size(); i++) {
            roleInfo = arrListRoleInfo.get(i);
            result = roleInfoData.deleteRoleInfo(roleInfo);
            if (result < 1) {
                return 0;
            }
            deletedCount++;
        }
        return deletedCount;
    }

    @Override
    public RoleInfo getRoleInfo(RoleInfo roleInfo) {
        return roleInfoData.getRoleInfo(roleInfo);
    }

    @Override
    public RoleInfo getRoleInfo(Integer id) {
        RoleInfo roleInfo = new RoleInfo();
        roleInfo.setId(id);
        return getRoleInfo(roleInfo);
    }

    @Override
    public int getRoleInfoCount(RoleInfo roleInfo) {
        return roleInfoData.getRoleInfoCount(roleInfo);
    }

    @Override
    public List<RoleInfo> selectRoleInfo(RoleInfo roleInfo) {
        return roleInfoData.selectRoleInfo(roleInfo);
    }

    @Override
    public List<RoleInfo> selectRoleInfo(RoleInfo roleInfo, Pager pager) {
        if (null != pager) {
            int count = roleInfoData.getRoleInfoCount(roleInfo);
            if (count == 0) {
                return null;
            }
            pager.setRowCount(count);
        }
        return roleInfoData.selectRoleInfo(roleInfo, pager);
    }

    @Override
    public List<RoleInfo> selectRoleInfoByList(ArrayList<Integer> arrListId) {
        if (arrListId.size() == 0) {
            return null;
        }
        return roleInfoData.selectRoleInfoByList(arrListId);
    }

    @Override
    public int getRoleInfoSearchCount(RoleInfo roleInfo) {
        return roleInfoData.getRoleInfoSearchCount(roleInfo);
    }

    @Override
    public List<RoleInfo> searchRoleInfo(RoleInfo roleInfo) {
        return roleInfoData.searchRoleInfo(roleInfo);
    }

    @Override
    public List<RoleInfo> searchRoleInfo(RoleInfo roleInfo, Pager pager) {
        if (null != pager) {
            int count = roleInfoData.getRoleInfoSearchCount(roleInfo);
            if (count == 0) {
                return null;
            }
            pager.setRowCount(count);
        }
        return roleInfoData.searchRoleInfo(roleInfo, pager);
    }

}
package com.hwabao.service;

import java.util.List;
import java.util.ArrayList;
import com.hwabao.model.RoleInfo;
import com.hwabao.common.Pager;

/**
 * @author steven9801@163.com
 */

public interface IRoleInfoService {

    public int insertRoleInfo(RoleInfo roleInfo);

    public int insertRoleInfoBatch(ArrayList<RoleInfo> arrListRoleInfo);

    public int updateRoleInfo(RoleInfo roleInfo);

    public int updateRoleInfoBatch(ArrayList<RoleInfo> arrListRoleInfo);

    public int deleteRoleInfo(RoleInfo roleInfo);

    public int deleteRoleInfoBatch(ArrayList<RoleInfo> arrListRoleInfo);

    public RoleInfo getRoleInfo(RoleInfo roleInfo);

    public RoleInfo getRoleInfo(Integer id);

    public int getRoleInfoCount(RoleInfo roleInfo);

    public List<RoleInfo> selectRoleInfo(RoleInfo roleInfo);

    public List<RoleInfo> selectRoleInfo(RoleInfo roleInfo, Pager pager);

    public List<RoleInfo> selectRoleInfoByList(ArrayList<Integer> arrListId);

    public int getRoleInfoSearchCount(RoleInfo roleInfo);

    public List<RoleInfo> searchRoleInfo(RoleInfo roleInfo);

    public List<RoleInfo> searchRoleInfo(RoleInfo roleInfo, Pager pager);

}

就这样简单整个业务表的CRUD结构清晰的完整的呈现在你面前啦。管中窥豹,真正拥有者会如获至宝。

敬请期待下期:

asp.net mvc 实战化项目之三板斧

spring mvc 实战化项目之三板斧

原文:http://www.cnblogs.com/fx2008/p/6082375.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!