Package com.github.zhangkaitao.shiro.chapter19.dao

Source Code of com.github.zhangkaitao.shiro.chapter19.dao.UrlFilterDaoImpl

package com.github.zhangkaitao.shiro.chapter19.dao;

import com.github.zhangkaitao.shiro.chapter19.entity.UrlFilter;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.jdbc.core.BeanPropertyRowMapper;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.jdbc.core.PreparedStatementCreator;
import org.springframework.jdbc.support.GeneratedKeyHolder;
import org.springframework.stereotype.Repository;

import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.SQLException;
import java.util.List;

/**
* <p>User: Zhang Kaitao
* <p>Date: 14-1-28
* <p>Version: 1.0
*/
@Repository
public class UrlFilterDaoImpl implements UrlFilterDao {

    @Autowired
    private JdbcTemplate jdbcTemplate;
   
    public UrlFilter createUrlFilter(final UrlFilter urlFilter) {
        final String sql = "insert into sys_url_filter(name, url, roles, permissions) values(?,?,?,?)";

        GeneratedKeyHolder keyHolder = new GeneratedKeyHolder();
        jdbcTemplate.update(new PreparedStatementCreator() {
            @Override
            public PreparedStatement createPreparedStatement(Connection connection) throws SQLException {
                PreparedStatement psst = connection.prepareStatement(sql, new String[]{"id"});
                int count = 1;
                psst.setString(count++, urlFilter.getName());
                psst.setString(count++, urlFilter.getUrl());
                psst.setString(count++, urlFilter.getRoles());
                psst.setString(count++, urlFilter.getPermissions());
                return psst;
            }
        }, keyHolder);
        urlFilter.setId(keyHolder.getKey().longValue());
        return urlFilter;
    }

    @Override
    public UrlFilter updateUrlFilter(UrlFilter urlFilter) {
        final String sql = "update sys_url_filter set name=?,url=?,roles=?,permissions=? where id=?";
        jdbcTemplate.update(
                sql,
                urlFilter.getName(), urlFilter.getUrl(), urlFilter.getRoles(), urlFilter.getPermissions(), urlFilter.getId());
        return urlFilter;
    }

    public void deleteUrlFilter(Long urlFilterId) {
        final String sql = "delete from sys_url_filter where id=?";
        jdbcTemplate.update(sql, urlFilterId);
    }


    @Override
    public UrlFilter findOne(Long urlFilterId) {
        final String sql = "select id, name, url, roles, permissions from sys_url_filter where id=?";
        List<UrlFilter> urlFilterList = jdbcTemplate.query(sql, new BeanPropertyRowMapper(UrlFilter.class), urlFilterId);
        if(urlFilterList.size() == 0) {
            return null;
        }
        return urlFilterList.get(0);
    }

    @Override
    public List<UrlFilter> findAll() {
        final String sql = "select id, name, url, roles, permissions from sys_url_filter";
        return jdbcTemplate.query(sql, new BeanPropertyRowMapper(UrlFilter.class));
    }

}
TOP

Related Classes of com.github.zhangkaitao.shiro.chapter19.dao.UrlFilterDaoImpl

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.