<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>


    posts - 15,  comments - 34,  trackbacks - 27

    Spring對JDBC進行了非常優雅的封裝,通過一系列的模板方法,只需簡單的幾行代碼就可實現數據庫的訪問。通過Spring的JdbcTemplate訪問數據庫從而實現用戶驗證。Access數據庫,建立表Account,包含兩個字段:

        username:VARCHAR(20),主鍵;
        password:VARCHAR(20)。

    然后輸入一些測試數據,注冊到系統DSN,名字為Blog。接下來我們在Tomcat中配置一個名為“jdbc/blog”的DataSource如下:

    如果你使用其他數據庫,只需要保證表的邏輯結構和JDNI名“jdbc/blog”。在AccountManager中,使用JdbcTemplate訪問數據庫來驗證用戶:

        Account getAccount(String username, String password) throws Exception {
            
    // validate the password:
            InitialContext ctx = new InitialContext();
            DataSource dataSource 
    = (DataSource)ctx.lookup("java:comp/env/jdbc/blog");
            JdbcTemplate jt 
    = new JdbcTemplate(dataSource);
            String pass 
    = (String) jt.queryForObject(
                
    "select password from Account where username=?",
                
    new Object[] {username}, String.class);
            
    if(password.equals(pass))
            
    {
                Account account 
    = new Account();
                account.setUsername(username);
                account.setPassword(password);
                
    return account;
            }

            
    throw new Exception("authorization failed.");
        }

     

    編譯運行,輸入hello.c?username=xxx&password=xxx來測試用戶登錄,如果匹配數據庫中的記錄,會顯示出用戶名,否則可以看到authorization failed異常。要更友好的顯示登陸失敗,可以在Controller中導向一個login_failed.jsp并給出登陸失敗的原因。

    下面來看這個AccountManager,很顯然在驗證邏輯中寫入了JNDI查找DataSource的代碼,這將導致比較“生硬”的編碼。“依賴注入”此刻顯示出了威力:讓容器注入DataSource:

    public class AccountManager implements java.io.Serializable {
        
    private DataSource dataSource;
        
    public void setDataSource(DataSource dataSource) {
            
    this.dataSource = dataSource;
        }


        Account getAccount(String username, String password) throws Exception 
    {
            JdbcTemplate jt 
    = new JdbcTemplate(dataSource);
            
        }

    }

    OK,現在這個AccountManager變得優雅多了,現在如何配置DataSource的注入呢?Spring提供了一個DataSourceUtils類,通過靜態方法getDataSourceFromJndi來獲得容器中配置的DataSource。我們添加以下配置:

        <bean id="dataSource"
              class
    ="org.springframework.jdbc.datasource.DataSourceUtils"
              factory-method
    ="getDataSourceFromJndi">
            
    <constructor-arg><value>jdbc/blogvalue>constructor-arg>
        
    bean>
        
    <bean id="accountManager" class="AccountManager">
            
    <property name="dataSource">
                
    <ref bean="dataSource" />
            
    property>
        
    bean>
     
    現在重新部署,效果和以前一樣了,但是相關代碼已被"放到",配置文件中了
    posted on 2005-02-04 11:20 jacky 閱讀(2018) 評論(1)  編輯  收藏 所屬分類: Open source

    FeedBack:
    # re: spring的jdbc封裝
    2011-09-14 14:21 | 呂紅芬
    OK,Thank you !!!  回復  更多評論
      
    <2011年9月>
    28293031123
    45678910
    11121314151617
    18192021222324
    2526272829301
    2345678

    常用鏈接

    留言簿(10)

    隨筆檔案

    文章分類

    文章檔案

    相冊

    收藏夾

    java

    搜索

    •  

    最新評論


    主站蜘蛛池模板: 亚洲av纯肉无码精品动漫| 亚洲精品乱码久久久久久下载| 亚洲av永久无码| 天天摸天天操免费播放小视频| 亚洲三级高清免费| 国产三级在线观看免费| 亚洲αⅴ无码乱码在线观看性色| 最新中文字幕电影免费观看| 中文字幕 亚洲 有码 在线| 成年男女免费视频网站| 亚洲欧洲专线一区| 日韩免费毛片视频| 四虎影视在线看免费观看| 久久久久噜噜噜亚洲熟女综合| 精品国产免费一区二区三区| 亚洲国产第一站精品蜜芽| 一区二区免费视频| 亚洲不卡视频在线观看| 日本一区二区三区日本免费| jyzzjyzz国产免费观看| 亚洲午夜久久久精品影院| 最近最新中文字幕完整版免费高清| 老司机午夜在线视频免费| 一本色道久久综合亚洲精品高清| 国内精品免费在线观看| 亚洲人成免费电影| 国产网站在线免费观看| 成人免费乱码大片A毛片| 亚洲成电影在线观看青青| 黄a大片av永久免费| 亚欧洲精品在线视频免费观看| 亚洲成在人天堂一区二区| 免费一本色道久久一区| 人碰人碰人成人免费视频| 亚洲人成网www| 国产三级电影免费观看| 久久免费观看国产99精品| 亚洲第一街区偷拍街拍| 亚洲国产天堂在线观看| 免费人妻av无码专区| 亚洲精品免费在线|