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

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

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

    隨筆-40  評論-66  文章-0  trackbacks-0
      2008年2月28日
    springside3背景struts2.1.2 spring2.5.6 Hibernate3.4GA


    1.struts2

    使用ZeroConfig + CodeBehind插件,實現(xiàn)約定大于配置的零配置文件風(fēng)格.

    根本不用配置struts.xml文件





    這里就是action實現(xiàn)annotation  CodeBehind。
    如方法


    通過 /user/user!input.action訪問, 并轉(zhuǎn)到 /user/user-xxx.jsp頁面
    即namespace + action name + "-" + "xxx.jsp"


     另外其中 action中需要注入的 service 使用annotation ,在set方法前 加入@request 或 @ autowired 或 @resource
    注釋(具體是用那個暫時無法搞清楚,總之我用request 就不行,另外兩個都可以)



    有了這個代碼之后 就能注入spring 環(huán)境中的 id = userManager 的bean (我個人理解)

    而spring中  id = userManager 的bean  也是通過自動注入完成的

    主要代碼是 applicationContext.xml文件中的
    代碼:




    2.spring

    spring2.5.6的annotation特性用的比較泛濫。 新手剛開始看的一頭霧水很正常。

    xml文件中配置自動注冊bean,通過掃描包中的帶注解的類。即這個代碼:




    掃描到下面的類,就自動注冊成 id=userManager





    3.hibernate
    使用hiberante3 注解,不要XML配置,實體類注解不用多說。

    需要注意的是entity類的掃描配置




    看清楚是掃描包,不是掃描類! 所以實體類com.mylu.User是無法掃描到,要放在 com.mylu.xxx.User才能掃描到!




    下邊按照ss3風(fēng)格做的例子,去掉spring security 框架的, 結(jié)構(gòu)更清晰。

    下載:實例代碼


    附:
    類庫
    posted @ 2009-01-08 17:01 Super·shen BLOG 閱讀(1795) | 評論 (2)編輯 收藏

    在jsp中,其實jsp就是servlet,jsp和servlet也都是一個class:

    1 .request.getRealPath(),這個方法已經(jīng)不推薦使用,在servlet后繼版本中將被取締。

    2.getServletContext().getRealPath("/")這個方法比較好用,可以直接在servlet和jsp中使用。

    3.request.getSession().getServletContext().getRealPath()也可以在jsp和servlet使用。

    4.this.getClass().getClassLoader().getResource("").getPath(),這個方法可以在任意jsp,servlet,java文件中使用,因為不管是jsp,servlet其實都是java程序,都是一個class。所以它應(yīng)該是一個通用的方法。

    posted @ 2008-09-17 14:55 Super·shen BLOG 閱讀(502) | 評論 (0)編輯 收藏

    普遍的,簡單的權(quán)限系統(tǒng)要求:

    1.系統(tǒng)所有資源定義 [資源表]   ( 還可以分為更小的權(quán)限表,操作表,這里通叫資源表)
    2.定義角色 [角色表]
    3.給角色指定資源(一個角色可以管理多個資源) [角色-資源表]
    4.定義用戶組 [用戶表]
    5.給用戶組指定角色(一個用戶組可以擁有多種角色) [用戶組-角色表]
    6.給用戶指定角色(一個用戶可以擁有多種角色,可以直接指定角色,也可以繼承用戶組的角色)[用戶-角色表]

     


    查找權(quán)限時:

    根據(jù)用戶ID[用戶-角色表]或用戶組ID[用戶組-角色表],查到所有角色I(xiàn)D,再[角色-資源表]找到所有角色下的所有資源。

    此就是用戶擁有的資源。(資源一般為模塊,當(dāng)然也可以分更細(xì)的定義為頁面,操作方法等)


    此權(quán)限設(shè)計適合于模塊化訪問系統(tǒng),如OA


    當(dāng)然很多系統(tǒng)因地而已,不可能完全滿足,按照自己系統(tǒng)需求設(shè)計是最合適的設(shè)計。



    posted @ 2008-08-18 16:17 Super·shen BLOG 閱讀(802) | 評論 (0)編輯 收藏
    提交頁面

    插入

    用戶:
    密碼:
    處理頁面add2.cgi 代碼 #include #include #include #include "sqlite3.h" #include "cgic.h" int cgiMain() { printf("Content-type:text/html\n\n"); printf(""); sqlite3 *db=NULL; char *zErrMsg = 0; int rc; rc = sqlite3_open("test.db", &db); if(rc){ printf("Can't open database\n"); //這里改了。要是按原先的,會提示stderr未定義,我不知道為什么。哪位朋友知道一定要告訴我哦。 sqlite3_close(db); exit(1); } else printf("open test.db successfully!\n"); char username[241]; cgiFormString("username", username, 241); fprintf(cgiOut, "username:
    \n");
    cgiHtmlEscape(username);
    fprintf(cgiOut, "
    \n"); char password[241]; cgiFormString("password", password, 241); fprintf(cgiOut, "password:
    \n");
    cgiHtmlEscape(password);
    fprintf(cgiOut, "
    \n"); char sql[300]={'\0'}; //不能用指針! //插入數(shù)據(jù) sprintf(sql, "INSERT INTO \"user\" VALUES('%s', '%s');", username,password); //sql = "INSERT INTO \"user\" VALUES('username', 'password');" ; sqlite3_exec( db , sql , 0 , 0 , &zErrMsg ); printf(sql); printf("插入數(shù)據(jù)成功!\n"); int nrow = 0, ncolumn = 0; char **azResult; //二維數(shù)組存放結(jié)果 //查詢數(shù)據(jù) /* int sqlite3_get_table(sqlite3*, const char *sql,char***result , int *nrow , int *ncolumn ,char **errmsg ); result中是以數(shù)組的形式存放你所查詢的數(shù)據(jù),首先是表名,再是數(shù)據(jù)。 nrow ,ncolumn分別為查詢語句返回的結(jié)果集的行數(shù),列數(shù),沒有查到結(jié)果時返回0 */ char *sql2 = "SELECT * FROM user"; sqlite3_get_table( db , sql2 , &azResult , &nrow , &ncolumn , &zErrMsg ); int i = 0 ; printf( "row:%d column=%d
    " , nrow , ncolumn ); printf( "\nThe result of querying is : \n" ); for( i=0 ; i<( nrow + 1 ) * ncolumn ; i++ ) printf( "azResult[%d] = %s
    ", i , azResult[i] ); //釋放掉 azResult 的內(nèi)存空間 sqlite3_free_table( azResult ); sqlite3_close(db); //關(guān)閉數(shù)據(jù)庫 return 0; } 請注意數(shù)據(jù)庫文件 test.db的訪問權(quán)限! 這里改成777!
    posted @ 2008-03-01 17:11 Super·shen BLOG 閱讀(1738) | 評論 (1)編輯 收藏

    [轉(zhuǎn)自] http://webdn.trueself.cn/archives/107

    posted @ 2008-02-28 14:19 Super·shen BLOG 閱讀(745) | 評論 (0)編輯 收藏
    主站蜘蛛池模板: 最近最好的中文字幕2019免费| 一级美国片免费看| 1000部啪啪未满十八勿入免费| 亚洲精品少妇30p| 亚洲免费人成在线视频观看 | 亚洲AV日韩AV永久无码色欲| 97人伦色伦成人免费视频| 亚洲三级在线视频| 无人在线观看完整免费版视频 | 亚洲ts人妖网站| 毛片免费观看视频| 国产精品亚洲综合一区在线观看 | 国产一区二区三区免费在线观看| 亚洲1区2区3区精华液| 亚洲国产午夜福利在线播放| 91在线免费视频| 亚洲天堂一区二区三区| 三年片在线观看免费观看高清电影| 亚洲欧洲精品成人久久曰| 国产真人无遮挡作爱免费视频| 美女黄色免费网站| 亚洲va久久久噜噜噜久久狠狠| 8090在线观看免费观看| 在线aⅴ亚洲中文字幕| 亚洲第一页综合图片自拍| 久久国产精品国产自线拍免费| 久久精品国产亚洲AV大全| 毛片免费在线视频| a级毛片免费观看网站| 亚洲高清中文字幕| 国产免费直播在线观看视频| 99在线免费视频| 亚洲色丰满少妇高潮18p| 亚洲综合区小说区激情区| 99免费视频观看| 男人和女人高潮免费网站| 亚洲AV无码国产丝袜在线观看| 国产卡一卡二卡三免费入口| 九九视频高清视频免费观看| 亚洲色欲www综合网| 免费大黄网站在线观看|