<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進(jìn)行了非常優(yōu)雅的封裝,通過一系列的模板方法,只需簡單的幾行代碼就可實(shí)現(xiàn)數(shù)據(jù)庫的訪問。通過Spring的JdbcTemplate訪問數(shù)據(jù)庫從而實(shí)現(xiàn)用戶驗(yàn)證。Access數(shù)據(jù)庫,建立表Account,包含兩個(gè)字段:

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

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

    如果你使用其他數(shù)據(jù)庫,只需要保證表的邏輯結(jié)構(gòu)和JDNI名“jdbc/blog”。在AccountManager中,使用JdbcTemplate訪問數(shù)據(jù)庫來驗(yàn)證用戶:

        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.");
        }

     

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

    下面來看這個(gè)AccountManager,很顯然在驗(yàn)證邏輯中寫入了JNDI查找DataSource的代碼,這將導(dǎo)致比較“生硬”的編碼。“依賴注入”此刻顯示出了威力:讓容器注入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,現(xiàn)在這個(gè)AccountManager變得優(yōu)雅多了,現(xiàn)在如何配置DataSource的注入呢?Spring提供了一個(gè)DataSourceUtils類,通過靜態(tài)方法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>
     
    現(xiàn)在重新部署,效果和以前一樣了,但是相關(guān)代碼已被"放到",配置文件中了
    posted on 2005-02-04 11:20 jacky 閱讀(2018) 評論(1)  編輯  收藏 所屬分類: Open source

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

    常用鏈接

    留言簿(10)

    隨筆檔案

    文章分類

    文章檔案

    相冊

    收藏夾

    java

    搜索

    •  

    最新評論


    主站蜘蛛池模板: 国产成人AV片无码免费| 精品无码专区亚洲| 永久免费AV无码国产网站 | 久久久久久久亚洲精品| 国产V片在线播放免费无码| 亚洲va在线va天堂va不卡下载| 2019中文字幕在线电影免费| 久久亚洲精精品中文字幕| 日韩吃奶摸下AA片免费观看 | 69精品免费视频| 亚洲中文字幕久久精品无码VA| 亚洲国产精品自产在线播放| 亚洲美女视频免费| 麻豆安全免费网址入口| 久久精品国产精品亚洲毛片| 国产乱子伦精品免费无码专区| 中文字幕不卡高清免费| 亚洲日本VA午夜在线影院| 亚洲精品无码专区久久久| 免费观看大片毛片| 国产成人久久AV免费| 黄页视频在线观看免费| 亚洲激情黄色小说| 久久亚洲国产成人精品无码区| 91精品免费国产高清在线| 中文字幕av无码不卡免费| 亚洲色欲色欱wwW在线| 亚洲AV无码精品色午夜果冻不卡| 永久免费看bbb| 最近2019免费中文字幕视频三| 美女一级毛片免费观看 | 9久久免费国产精品特黄| 亚洲综合欧美色五月俺也去| 亚洲AV永久无码精品一百度影院 | 亚洲综合久久1区2区3区| 久久激情亚洲精品无码?V| 成人免费在线视频| 国产精品免费网站| 国产精品免费大片| 久久久久国色AV免费观看| 婷婷国产偷v国产偷v亚洲|