文章出處

從上一節的小demo中我們搞清楚了如何跟易寶對接以及易寶的支付流程。這一節我們來做一下支付頁面以及在頁面中導入銀行圖標。

 

1. 存儲銀行圖標

銀行圖標一般不會總是去加載,因為這些東西是死的,沒必要每次進入支付頁面就去加載銀行圖標,這樣性能會受到一定的影響。這讓我們聯想到了之前的加載首頁數據了,其實跟那個道理是一樣的,我們可以在項目啟動的時候就將銀行圖標資源加載到application中,后面用到了就直接在application域中取就行了。所以跟原來一樣,我們在監聽器中加載銀行圖標。 
  銀行圖標易寶官方會提供給我們,那么我們需要做的就是將這些圖標放到工程下的某個文件夾里,我是放在了WebRoot/files/bankImages中,這些圖標的名稱都嚴格根據易寶官方要求的名字命名,就像上一節中看到的,工行就命名為ICBC-NET.gif。 
  加載圖標的思路是如下: 
  1)首先從指定目錄中獲取所有圖標的名字,并且過濾掉不需要的文件,這個過濾很重要,因為如果有一些多余的文件或者隱藏文件的話,我們都獲取到了,然后前臺顯示的時候就會出現一些奇怪的東西,所以我們只要有用的圖標。 
  2)其次我們拿到圖標名稱后將它們放到數組或者集合中,然后把數組或集合存到application域中 
  很明顯,第二步是在監聽器中實現的,第一步我們可以自己新寫一個工具類,也可以在我們之前寫過的fileUploadUtil類中完成。

1.1 獲取圖標名稱

  我們在fileUploadUtil中添加獲取圖標名稱的代碼:

 

@Component("fileUpload")
public class FileUploadUtil implements FileUpload {
    //省略原來的代碼……

    //@Value表示去beans.xml文件中找id="prop"的bean,它是通過注解的方式讀取properties配置文件的,然后去相應的配置文件中讀取
    @Value("#{prop.basePath+prop.bankImagePath}")
    private String bankImagePath;

    public String[] getBankImage() {
        String[] list  = new File(bankImagePath).list(new FilenameFilter() {

            //測試指定文件是否應該包含在某一文件列表中
            @Override
            public boolean accept(File dir, String name) {
                System.out.println("dir:" + dir + ",name:" + name);             
                //通過后綴名來實現文件的過濾效果
                //返回真就放到list中,返回假就過濾掉
                return name.endsWith(".gif");
            }
        });
        return list;
    }

 

我們加載的是public.properties配置文件,看一下配置文件中的內容:

 

basePath=E\:\\web\\apache-tomcat-8.0.26\\webapps\\E_shop
filePath=\\files
bankImagePath=\\files\\bankImages

 

之所以有個basePath是為了便于擴展,而且以后修改的話basePath不需要動。我們繼續看上面那個方法,new File(path).list()方法是獲取路徑中所有文件名,但是new File(path).list(FilenameFilter filter) 帶有過濾功能,可以過濾掉不想要的文件,只返回想要的文件到數組中。FilenameFilter 接口中只有一個accept方法,所以我們可以用內部類來實現,在里面判斷 一下是否是.gif后綴的文件即可。

1.2 將圖標名稱存入application域

  下面我們在監聽器中將剛剛保存圖標名稱的數組存儲到application域中,這些方法之前都有介紹過,就不多做解釋了,直接看代碼:

 

//@Component //監聽器是web層的組件,它是tomcat實例化的,不是Spring實例化的。不能放到Spring中
public class InitDataListener implements ServletContextListener {
    //省略其他代碼……

    private ApplicationContext context = null;
    private FileUpload fileUpload = null;

    @Override
    public void contextInitialized(ServletContextEvent event) {
        context = WebApplicationContextUtils.getWebApplicationContext(event.getServletContext());               
        //將存儲銀行圖片的數組放到application中,項目啟動的時候加載
        fileUpload = (FileUpload) context.getBean("fileUpload");
        event.getServletContext().setAttribute("bankImageList", fileUpload.getBankImage());
    }
}

 

2.支付頁面顯示

 我們來看一下bank.jsp關于銀行圖標這一塊的代碼,如下: 
前臺獲取
  還有一塊是顯示訂單的相關信息的,從下面的代碼中也可以看出,是從session中拿我們之前備份的訂單信息,原信息在用戶確認訂單跳到支付頁面時已經銷毀了。
 
訂單信息

3. 測試一下效果

  下面我們來測試一下支付頁面的顯示效果,如下: 
支付頁面
好了,支付頁面顯示正常,下面要完成支付功能了,即上一節用servlet寫的那個demo的功能,只不過現在放到Struts中,并且可能要考慮到一些其他的問題,下一節再寫吧~

 


文章列表


不含病毒。www.avast.com
arrow
arrow
    全站熱搜
    創作者介紹
    創作者 大師兄 的頭像
    大師兄

    IT工程師數位筆記本

    大師兄 發表在 痞客邦 留言(0) 人氣()