posts - 15,comments - 29,trackbacks - 0
               摘要: 服務(wù)端配置 cas是個(gè)好東西,很靈活很好用,但是配置起來很麻煩,網(wǎng)上資料比較零碎。不弄個(gè)三五天根本不知道其中的原理,終于在多天的奮斗中配置成功,現(xiàn)在將配置的一些過程記錄下來供大家參考。 cas官方網(wǎng)站 http://www.jasig.org/cas 下載最新的服務(wù)端 CAS Server 3.3.3 Final 解壓后將modules下面的cas-server-webapp-3.3...  閱讀全文
          posted @ 2009-10-20 18:21 流腥魚 閱讀(20445) | 評(píng)論 (13)編輯 收藏
           eclipse  中使用 svn 插件,原本正常,未作任何更改,突然有一天, eclipse 中查看文件時(shí),文件后面的 版本號(hào) 、 文件的狀態(tài)圖標(biāo) 等等都不見了。

            檢查插件都在,更新,提交等操作都能正常使用,唯獨(dú)看不到狀態(tài)了。

            經(jīng)過一番查找,找到問題解決辦法。

            打開 : windows ->preferences->General->Appearance->Lable Decorations  勾選其中的 SVN 項(xiàng)即可。

            同時(shí),還可以打開 windows ->preferences->Team -> SVN 中做相關(guān)設(shè)置。

          posted @ 2009-05-21 12:19 流腥魚 閱讀(1474) | 評(píng)論 (3)編輯 收藏

          之前看到很多人一直都問這個(gè)問題,不過當(dāng)時(shí)我沒當(dāng)一回事,因?yàn)樵?CSS 中要垂直居中,多數(shù)是在有高度的情況下,或者容器高度不定的情況下才用,看上去比較舒服,而且實(shí)現(xiàn)的方法也不少,不一定要拘泥于和 table 布局一樣。不過最近有人問了幾個(gè)例子,看來對(duì)此的需求還不少。現(xiàn)在就把我經(jīng)驗(yàn)?zāi)贸鰜矸窒硪幌拢M蠹夜墓恼啤?/p>

          首先,要有一個(gè)概念:凡是 table 布局可以實(shí)現(xiàn)的,CSS 一定可以實(shí)現(xiàn)。CSS 可以實(shí)現(xiàn)的,table 未必能做到。

          現(xiàn)在來幾個(gè)例子:

          一、單行內(nèi)容的居中
          只考慮單行是最簡(jiǎn)單的,無論是否給容器固定高度,只要給容器設(shè)置 line-heightheight,并使兩值相等,再加上 over-flow: hidden 就可以了

          .middle-demo-1{
          height: 4em;
          line-height: 4em;
          overflow: hidden;
          }

          優(yōu)點(diǎn):
          1. 同時(shí)支持塊級(jí)和內(nèi)聯(lián)極元素
          2. 支持所有瀏覽器
          缺點(diǎn):
          1. 只能顯示一行
          2. IE中不支持<img>等的居中
          要注意的是:
          1. 使用相對(duì)高度定義你的 height 和 line-height
          2. 不想毀了你的布局的話,overflow: hidden 一定要
          為什么?
          請(qǐng)比較以下兩個(gè)例子:


          [Ctrl+A 全部選擇 提示:你可先修改部分代碼,再按運(yùn)行]

          上一個(gè)高度是用的絕對(duì)單位px,并且沒有隱藏溢出,下一個(gè)高度用的單位是相對(duì)單位em,并且隱藏了溢出。如果你的瀏覽器支持放大字體,那么盡情地放大字體,看看會(huì)出現(xiàn)什么效果。

          二、多行內(nèi)容居中,且容器高度可變
          也很簡(jiǎn)單,給出一致的 padding-bottom 和 padding-top 就行

          .middle-demo-2{
          padding-top: 24px;
          padding-bottom: 24px;
          }

          優(yōu)點(diǎn):
          1. 同時(shí)支持塊級(jí)和內(nèi)聯(lián)極元素
          2. 支持非文本內(nèi)容
          3. 支持所有瀏覽器
          缺點(diǎn):
          容器不能固定高度

          三、把容器當(dāng)作表格單元
          CSS 提供一系列diplay屬性值,包括 display: table, display: table-row, display: table-cell 等,能把元素當(dāng)作表格單元來顯示。這是再加上 vertical-align: middle, 就和表格中的 valign="middle" 一樣了。

          .middle-demo-3{
          display: table-cell;
          height: 300px;
          vertical-align: middle;
          }

          可惜IE不支持這些屬性,不過在其他瀏覽器上顯示效果非常完美。
          要注意的是:和一個(gè)合法的<td>元素必須在<table>里一樣,display: table-cell 元素必須作為 display: table 的元素的子孫出現(xiàn)。

          優(yōu)點(diǎn):
          不用說了吧,就是表格,效果和表格一模一樣
          缺點(diǎn):
          IE下無效

          四、以毒攻毒!用 IE 的 bug 解決 IE 中的絕對(duì)居中
          先不得不說一句,IE 真的是個(gè)很爛的瀏覽器,CSS1中的定義都不支持,害得要我們轉(zhuǎn)個(gè)大圈子來造居中。不過就像我說的,凡是 table 布局可以實(shí)現(xiàn)的,CSS 一定可以實(shí)現(xiàn),即使在 IE 里也不例外。我研究 IE layout 模式多年,還是找出了一個(gè)可以在 IE 中絕對(duì)居中的方法。這個(gè)方法就是基于 IE layout 的 bug,也可以算以毒攻毒。至于原理,不要問我,這是獨(dú)門秘學(xué),何況三言兩語也講不清楚,只要好用就行

          .middle-demo-4{
          height: 300px;
          position: relative;
          }
          .middle-demo-4 div{
          position: absolute;
          top: 50%;
          left: 0;
          }
          .middle-demo-4 div div{
          position: relative;
          top: -50%;
          left: 0;
          }

          五、整合三和四,寫出支持所有瀏覽器的垂直居中容器!
          思路是利用 IE 和 非IE 瀏覽器的 CSS hack, 整合三和四的CSS,寫出兼容主流瀏覽器的垂直居中容器。具體代碼就不給出了,大家權(quán)當(dāng)作練習(xí)練習(xí)。例子可以在下面的附錄中找到。
          最終實(shí)測(cè)支持的瀏覽器:IE6+, Mozilla 1.7, Netscape Navigator 8, Opera 8.0+, Firefox 1.0+ 和 Safari 1.0+IE5 下需要加上對(duì)合適模型的補(bǔ)正。
          推測(cè)支持的瀏覽器:Mozilla 1.5+, Netscape Navigator 7+, Opera 7+
          未測(cè)試瀏覽器:Konqueror

          最后附上自己寫的,所有居中布局的范例網(wǎng)頁,大家不明白可以參考。


          [Ctrl+A 全部選擇 提示:你可先修改部分代碼,再按運(yùn)行]
          posted @ 2009-04-17 19:59 流腥魚 閱讀(463) | 評(píng)論 (0)編輯 收藏

          現(xiàn)階段我們?cè)陂_發(fā)報(bào)表的時(shí)候,是使用jdbc鏈接數(shù)據(jù)庫的,為提高報(bào)表的運(yùn)行效率和穩(wěn)定性,使用連接池進(jìn)行管理。比較簡(jiǎn)便和低耦合的解決辦法,使用jndi連接池。

           

          jdbc和jndi的區(qū)別

          JDBC -最基本的連接數(shù)據(jù)庫的方式, 每次對(duì)數(shù)據(jù)庫打交道的時(shí)候 ,連接數(shù)據(jù)庫是需要實(shí)例下你實(shí)現(xiàn)連接數(shù)據(jù)庫的方法或者類。
          JNDI DataSource 英文全稱是:Java Naming and Directory Interface java 命明接口,當(dāng)服務(wù)啟動(dòng)時(shí) 事先把連接數(shù)據(jù)庫的已經(jīng)連好多條,具體多少條你可以設(shè)置,存放在tomcat容器里,用的時(shí)候可以直接使用, 不用再實(shí)例化得到連接, 相對(duì)與jdbc效率要快點(diǎn)

           

           

          在eclipse設(shè)計(jì)報(bào)表的時(shí)候,我們使用jdbc鏈接數(shù)據(jù)庫做測(cè)試,當(dāng)?shù)搅藅omcat運(yùn)行環(huán)境中切換到j(luò)ndi連接池,這是比較方便的開發(fā)方法。

          實(shí)現(xiàn)步驟:

          1.tomcat配置jndi連接池

          在 {tomcat目錄}\webapps\{項(xiàng)目名}\META-INF 中新增context.xml文件,配置代碼如下

          <?xml version="1.0" encoding="UTF-8"?>
          <Context>
           
          <Resource
                
          auth="Container"
                name
          ="jdbc/travel_agency"
                type
          ="javax.sql.DataSource"
                maxIdle
          ="5"
                maxWait
          ="-1"
             driverClassName
          ="com.mysql.jdbc.Driver"
                username
          ="itravel"
             password
          ="709394"
                url
          ="jdbc:mysql://192.168.1.100/travel_agency?useUnicode=true&amp;characterEncoding=UTF-8"
                maxActive
          ="10"/>
          </Context>

          2.在web.xml中加入配置

           

          <resource-ref>
              
          <description>Database Source</description>
              
          <res-ref-name>jdbc/travel_agency</res-ref-name>
              
          <res-type>javax.sql.DataSource</res-type>
              
          <res-auth>Container</res-auth>
          </resource-ref>


          3.實(shí)例報(bào)表中數(shù)據(jù)源代碼

           

          1 <data-sources>
          2        <oda-data-source extensionID="org.eclipse.birt.report.data.oda.jdbc" name="數(shù)據(jù)源" id="227">
          3            <property name="odaDriverClass">com.mysql.jdbc.Driver</property> 
          4            <property name="odaURL">jdbc:mysql://192.168.1.100/travel_agency</property> 
          5            <property name="odaUser">itravel</property>
          6            <encrypted-property name="odaPassword" encryptionID="base64">NzA5Mzk0</encrypted-property>
          7            <property name="odaJndiName">java:comp/env/jdbc/travel_agency</property>
          8        </oda-data-source>
          9    </data-sources>

           

           

          除了第7行 <property name="odaJndiName">java:comp/env/jdbc/travel_agency</property>,其余是我們的之前的配置。用了第7行的代碼,表示該報(bào)表支持jndi數(shù)據(jù)源,birt在運(yùn)行報(bào)表的時(shí)候,會(huì)先用jndi去連接,如果失敗了再用jdbc鏈接,這樣做的好處就是,我們?cè)陂_發(fā)報(bào)表的時(shí)候,沒有放到web環(huán)境中,可以使用jdbc,當(dāng)放到tomcat中,因?yàn)橛辛说?行的配置。默認(rèn)采用jdni連接。


           

          posted @ 2009-03-19 10:46 流腥魚 閱讀(3643) | 評(píng)論 (2)編輯 收藏

          從論壇的一篇文章(http://www.javaeye.com/topic/335078)得知,在BIRT VIEWER SERVLET內(nèi)部也有認(rèn)證接口代碼,只是簡(jiǎn)單的返回了true,沒有做處理。BIRT VIEWER SERVLET是報(bào)表處理的入口,該接口如果返回flase,那么報(bào)表將不會(huì)顯示,目標(biāo)就是在該接口加入我們自己的邏輯實(shí)現(xiàn),本階段先實(shí)現(xiàn)簡(jiǎn)單的安全認(rèn)證,即在沒有登錄的情況下無法訪問報(bào)表。

          處理步驟:

          1.把birt viewer項(xiàng)目和現(xiàn)有項(xiàng)目整合在一起(為了讓birt viewer項(xiàng)目能獲取到現(xiàn)有項(xiàng)目的session)

          2.修改BIRT VIEWER SERVLET類,該類源碼在org.eclipse.birt.report.servlet.BirtEngineServlet下面,找到函數(shù)經(jīng)行修改,紅色為新增部分

          /**
            * Local authentication.
            *
            * @param request
            *            incoming http request
            * @param response
            *            http response
            * @return
            */
           protected boolean __authenticate( HttpServletRequest request,
             HttpServletResponse response )
           {
            
            //報(bào)表權(quán)限,沒有登錄訪問不了
            if(request.getSession().getAttribute("user")==null)
            {
             return false;
            }

            
            return true;
           }

          3.將該類編譯后放進(jìn)BIRT包里面。

          posted @ 2009-03-19 10:42 流腥魚 閱讀(2035) | 評(píng)論 (2)編輯 收藏
          http://www.overset.com/2008/05/12/multiday-calendar-datepicker-jquery-plugin/
          posted @ 2009-02-17 00:26 流腥魚 閱讀(1769) | 評(píng)論 (1)編輯 收藏

          1.組織機(jī)構(gòu)的完善

          工作流中的權(quán)限設(shè)置往往是比較復(fù)雜的,如審批中經(jīng)常需要某部門的主管審批,或者某個(gè)人的上級(jí)領(lǐng)導(dǎo)審批等等。

          為了滿足需求的多樣化,在原來的組織機(jī)構(gòu)基礎(chǔ)上引入崗位的模型,每個(gè)員工都對(duì)應(yīng)一個(gè)部門和一個(gè)崗位。部門中設(shè)置主管的崗位。有個(gè)這個(gè)關(guān)系,這樣可以比較清楚地查找某個(gè)人的上級(jí)領(lǐng)導(dǎo),或者是某個(gè)部門的主管。



          2.工作流節(jié)點(diǎn)中設(shè)置執(zhí)行者方案

          6種方式定義執(zhí)行者

          1.指定人

          通過在組織結(jié)構(gòu)樹中點(diǎn)選具體的某些人。

          2.指定崗位

          在崗位樹中指定執(zhí)行的崗位。

          3.指定部門

          在組織機(jī)構(gòu)樹中指定執(zhí)行的部門

          4.指定角色

          角色是某些邏輯上相識(shí)的一個(gè)組定義。選擇某個(gè)角色。

          5.相對(duì)執(zhí)行人

          在流程還沒有開啟之前,執(zhí)行者是誰是未知的,所以這里的指定是相對(duì)的,當(dāng)流程開啟的時(shí)候才能確定,這里可以設(shè)置相對(duì)執(zhí)行人的部門主管、相對(duì)執(zhí)行人的上級(jí)主管、相對(duì)執(zhí)行人的所在部門、執(zhí)行人自己這4個(gè)情況。

          6.表單確定

          有些流程不在定義的時(shí)候確定,是由上一節(jié)點(diǎn)執(zhí)行者確定的。

          前五種方式可以混合,只要登錄者復(fù)合定義制定人的并集,就有權(quán)限在待辦任務(wù)中看到等待處理任務(wù)并有權(quán)限執(zhí)行。

          posted @ 2009-02-12 17:27 流腥魚 閱讀(1875) | 評(píng)論 (1)編輯 收藏
          ps -ef |grep tomcat
          kill -9 端口
          posted @ 2009-01-09 18:28 流腥魚 閱讀(1000) | 評(píng)論 (0)編輯 收藏
          主站蜘蛛池模板: 澄城县| 青浦区| 台州市| 布尔津县| 天峨县| 崇礼县| 长宁区| 类乌齐县| 津南区| 临漳县| 永济市| 定州市| 石泉县| 香港 | 贵溪市| 松原市| 灵璧县| 丹阳市| 武安市| 叶城县| 玛曲县| 无棣县| 临颍县| 平顺县| 潮安县| 扶余县| 柳江县| 永登县| 牙克石市| 鱼台县| 海兴县| 济阳县| 自治县| 宁强县| 尉犁县| 长白| 青神县| 察雅县| 西乡县| 潼关县| 石泉县|