ÇøÓòÒ½ÁÆÎÀÉúÐÅÏ¢¹²ÏíÆ½Ì¨ÃÅ»§½¨Éè·½°¸
3.4.3.3¼¼ÊõÒªµã
±¾ÃÅ»§µÄÓ¦Ó÷þÎñÖ÷Òª·ÖΪÄÚÍøºÍÍâÍøÁ½´ó²¿·Ö£¬ÆäÖУ¬ÄÚÍøÖ÷ÒªÃæÏòÒ½Éú¡¢ ¿Æ½ÌÑÐÈËÔ±¡¢¹ÜÀíÕß¡¢·Ö¼¶¹ÜÀíÔ±µÈÕýʽÔÚ±àÈËÔ±£¬ÍâÍøÖ÷ÒªÃæÏò»¼ÕߵĹ«ÖÚȺ Ìå¡£»ùÓÚÒµÎñ¹¦ÄÜºÍÆ½Ì¨¹ÜÀíµÄ¿¼ÂÇ£¬ ÄÚÍøÓëÍâÍø×÷Ϊ¶ÀÁ¢Ó¦Ó÷ֱð²¿Êð¡£Portal µÄÖ÷ÒªÌØÐÔÖ®Ò»¼´¶Ô²»Í¬ÍⲿϵͳµÄÓ¦Óù¦ÄÜʵÏÖͳһÓû§µÇ¼µÄ¼¼Êõ Ö§³Å¡£¶ÔÓÚ±¾Æ½Ì¨¶øÑÔ£¬Ó¦Óþù»ùÓÚͳһµÄƽ̨£¬Òò´Ë£¬¶ÔÓÚµ¥µãµÇ¼£¬¸ü¶àÊÇ ÎªÆ½Ì¨À©Õ¹ÐÔ¿¼ÂÇ£¬´Óµ×²ã¼¼ÊõÉ϶Ե¥µãµÇ¼½øÐÐÖ§³Ö£¬ÒÔ±ãÓÚ¶Ô½ñºóÍⲿϵͳ ½ÓÈëʱµÄ±ê×¼»¯µ¥µãµÇ¼֧³Ö£¬ÒÔÌáÉý°²È«ÐÔºÍÕûºÏЧÂÊ¡£
3.4.1ÄÚ²¿ÃÅ»§
µç×Ó²¡Àú¹²Ïí²¿·Ö£¬Ö÷ÒªÓÉ HTB ͳһµÄ±ê×¼µÄÊý¾ÝÕ¹ÏÖ·þÎñ×é¼þͳһÌṩ£¬Ö÷Òª°üÀ¨£º»¼Õß»ù±¾ÐÅÏ¢¡¢²¡ÀúÕªÒª¡¢ÃÅÕﲡÀú¡¢×¡Ôº²¡Àú¡¢Ò½Öö±íµ¥¡¢´¦·½±íµ¥¡¢Ò©Æ·±íµ¥¡¢¼ìÑé½á¹û¡¢¼ì²é½á¹û£¨Ó°Ïñ³ýÍ⣩¡¢ÊÖÊõÂé×í¡¢»¤Àí¼Ç¼¡¢³öԺС½á¡¢·ÑÓÃ±íµ¥¡¢²¡°¸Ê×Ò³£¬ºÍ»¼Õ߸öÈ˽¡¿µµµ°¸µÄ²éѯ¡£
תÕïת¼ìÒ½ÁÆ×ÉѯµÈÄ£¿éÐèÒªµÄ¼´Ê±ÐÔµç×Ó²¡ÀúÊý¾Ý£¬Ò²ÓÉHTBͳһµÄ±ê×¼µÄÊý¾ÝÕ¹ÏÖ·þÎñ×é¼þͳһÌṩ£¨Ó°Ïñ³ýÍ⣩£¬¼¯³ÉÔÚ¶¨ÖÆµÄÆ½Ì¨¹¤¾ßÉÏ¡£
¿ÆÑС¢½ÌѧÐèÒªµÄµç×Ó²¡Àú£¬ÓÉHTBÌṩ£¨Ó°ÏñÊý¾Ý ³ýÍ⣩¡£ÆäÖнÌѧ²¡Àú¿â£¬ÈôÊÇÐèÒª»ùÓÚ±ê×¼µÄHTB²¡Àú¿âÐ޸ġ¢±ê×¢½ÌѧÏà¹ØÄÚÈÝ£¬Ôò½¨Òéµ¥¶ÀÉèÁ¢½Ìѧ²¡Àú¿â¡£²¢ÇÒ£¬Í³Ò»ÓÉHTBÊý¾ÝÕ¹ÏÖ·þÎñÖ§³ÖÓû§¼ìË÷Ñ¡Ôñµç×Ó²¡Àú¡£
µÚ 9 Ò³ ¹² 30 Ò³
ÇøÓòÒ½ÁÆÎÀÉúÐÅÏ¢¹²ÏíÆ½Ì¨ÃÅ»§½¨Éè·½°¸
¿ÆÑС¢½ÌѧÐèÒªµÄÓ°ÏñÊý¾Ý£¬Óɶ¨ÖƵÄÊý¾Ý¿âºÍ·þÎñÌṩ£¬²¢ÇÒÖ§³ÖÓëHTB²¡ÀúµÄÎļþË÷Òý¡£
3.4.2ÍⲿÃÅ»§·þÎñ
ÍâÍøÒµÎñ×é¼þ£¬Ö÷ÒªÌá¹©ÃæÏòÍⲿÓû§µÄ·þÎñ£¬Ö÷ÒªµÄ·þÎñ°üÀ¨£ºÍøÉÏÔ¤Ô¼ ¹ÒºÅ¡¢»¼Õß·´À¡¡¢¸öÈ˽¡¿µµµ°¸¡¢¹«¹²ÐÅÏ¢²éѯ¡£
»¼Õß·´À¡ºÍ¸öÈ˽¡¿µµµ°¸£¬ÐèÒªµ÷ÓÃHTB±ê׼ͳһµÄµç×Ó²¡ÀúÕ¹ÏÖ·þÎñ»¼Õß·´À¡µÄÒâ¼û¡¢¸öÈ˽¡¿µµµ°¸ÖиöÈËÐÅÏ¢µÄÐ޸ģ¬ÐèÒª¶¨ÖÆÊý¾Ýµ½¡°ÆäËûÒµÎñÊý¾Ý¡±£¬²¢²»Í¬²½HTBÊý¾ÝÍøÉÏÔ¤Ô¼¹ÒºÅ£¬Í¨¹ý¶¨ÖƵŦÄÜ·þÎñ£¬Êý¾Ý´æ´¢µ½¡°Ô¤Ô¼¹ÒºÅÊý¾Ý¡±
¹«¹²ÐÅÏ¢£¬È罡¿µ½ÌÓý¡¢Ò½Ôº×ÊÔ´½éÉܵȣ¬¶¨ÖÆ¿ª·¢·þÎñ£¬Êý¾Ý´æ´¢µ½¡°ÃÅ »§ÏµÍ³Êý¾Ý¡±¡£
±¾Æ½Ì¨ÖУ¬µ¥µãµÇ¼µÄÉè¼ÆÖ÷Òª»ùÓÚÁ½¸ö¼¼ÊõʵÏÖ£¬»ùÓÚ WAS µÄ JAVA ÑéÖ¤ÓëÊÚȨ·þÎñ£¨Java Authentication and Authorization Service£¬JAAS£©ÒÔ¼°»ùÓÚWPSµÄƾ֤±£Ïտ⣨Credential Vault£©¡£
Portal µÇ¼×é¼þÉè¼Æ
ÔÚPortalµÇ¼×é¼þÖУ¬Æ½Ì¨²ÉÓÃJAASÈÏÖ¤·½Ê½ÒÔÖ§³Ö»ñÈ¡Óû§ÐÅÏ¢½øÐбê ×¼»¯ÈÏÖ¤£¬¼´ HttpFormBasedAuthentication ÈÏÖ¤·½·¨¡£´Ë·½·¨¶ÔÓÚ cookie »ò session ÈÏÖ¤£¬ÓиüºÃµÄ°²È«ÐÔºÍͨÓÃÐÔ¡£Portal µÄµÇ¼×é¼þÖÐµÄ form Éè¼Æ×ñÑÒÔϹæÔò£º
actionÊôÐÔΪj_security_check; ÒÔÖ§³ÖJ2EEÖеÄÈÏÖ¤servlet½øÐÐÓû§ ÈÏÖ¤
j_usernameÎı¾ÊäÈë¿ò; ×÷ΪÓû§Ãû¶ÔÏó j_passwordÎı¾ÊäÈë¿ò; ×÷ΪÃÜÂë¶ÔÏó
±íµ¥Ìá½»ºóÓÉWASÖеÄÈÏÖ¤servlet½øÐÐÓû§ÈÏÖ¤¡£¶ÔÓÚÓû§ÃÜÂ룬±¾Æ½Ì¨ ͳһ²ÉÓÃMD5·½·¨¶ÔÃ÷ÎÄÃÜÂë½øÐÐÉ¢Áкʹ洢£¬±È¶Ôʱ£¬½«Óû§Ìá½»µÄÃÜÂë½øÐРɢÁкó£¬Óë´æ´¢µÄÉ¢ÁÐÖµ½øÐбȶԣ¬Ïàͬʱ¼´ÈÏΪͨ¹ý¡£
ΪʹWASÄܹ»Ë³Àû¶ÔÌá½»Óû§ÐÅÏ¢ÑéÖ¤£¬ÐèÒªÔÚWASÖÐÉèÖöÔÓ¦µÄÓû§ÐÅÏ¢ ¿â£¬ÒÔ½øÐмǼ±È¶Ô¡£±¾Æ½Ì¨ÖеÄÓû§¿â»ùÓÚ IBM Tivoli Directory Server
µÚ 10 Ò³ ¹² 30 Ò³
ÇøÓòÒ½ÁÆÎÀÉúÐÅÏ¢¹²ÏíÆ½Ì¨ÃÅ»§½¨Éè·½°¸
µÄLDAPĿ¼Êý¾Ý¿â£¬ÔÚWASµÄ°²È«ÖÐÐÄÖУ¬¼¤»îLTPAÈÏÖ¤·½Ê½£¨Light-weight Third Party Authentication£©£¬²¢½«¶ÔÓ¦LDAPĿ¼Êý¾Ý¿âµÄÓòÃûÐÅÏ¢¡¢¼àÌý¶Ë¿Ú¡¢»ù±¾×¨ÓÐÃû³Æ£¨¼´Óû§Êý¾ÝËùÔڵĽڵ㣬cn=people, dc=sysu, dc=edu, dc=cn£©ÖÃÈëWASÅäÖÃÖС£
´ËÍ⣬ÐèÒª¶ÔÈÏÖ¤Ò³ÃæÂß¼Á÷ת½øÐпØÖÆ¡£¶ÔÓÚÈÏÖ¤Ò³Ãæ£¬Ö÷Òª°üÀ¨µÇ¼ҳ Ãæ¡¢µÇ³öÒ³Ãæ¡¢´íÎóÌáÊ¾Ò³Ãæ¡£Í¨¹ýÔÚ
web.xml
ÖÐ
Portal ¿çÓòÈÏÖ¤Éè¼Æ
ÉÏÊö¹ý³ÌʵÏÖÁË»ù´¡µÄ JAAS ÈÏÖ¤·½·¨£¬µ±Óû§Ìá½»ÈÏÖ¤ÐÅϢʱ£¬WAS ¿É¼´ ʱÔÚÔ¤ÉèµÄ LDAP Ŀ¼ÖнøÐÐÑéÖ¤£¬²¢·µ»ØÑéÖ¤½á¹û¡£ÎªÊ¹µÃÆäËûÓ¦ÓóÌÐòÄܹ» µ÷Óõ½¸ÃÈÏÖ¤½á¹û£¬²¢´¥·¢¶ÔÓ¦µÄµÇ¼¹ý³Ì£¬»¹ÐèÒª½øÒ»²½µ÷Óà Portal Öеķ½ ·¨¡£
ƾ֤±£ÏÕ¿âÊÇÕû¸öÓû§ÈÏÖ¤ÐÅÏ¢ÔÚ¿çÓòÈÏÖ¤ÐÅÏ¢½»»»¹ý³ÌÖеĻù´¡¡£Æ¾Ö¤±£ ÏÕ¿âÓɹÜÀíÔ±ÔÚWPSºǫ́½øÐд´½¨ºÍ¹ÜÀí£¬¹ÜÀíÔ±ÐëÔÚÆ¾Ö¤±£ÏÕ¿âÖд´½¨Æ¾Ö¤±£ÏÕ²Û£¬ÓÃÓÚÖ¸¶¨ºÍ´æ·Åƾ֤±£ÏÕÊý¾Ý¡£²Û£¨slot£©ÖеÄÊý¾Ý¿Éͨ¹ý
com.ibm.portal.portlet.service.
credentialvault.credentials.CredentialµÄ·þÎñ·½·¨£¬±»ÆäËûÍⲿӦÓ÷ÃÎÊ£¬ÒÔʵÏÖµ¥µãÈÏÖ¤¡£
ÀàËÆµØ£¬Æ½Ì¨ÖÐͨ¹ýHTTPFormBasedAuthCredential·½·¨£¬²ÉÓÃÖ÷¶¯Æ¾Ö¤·½ ʽ£¬À´±£´æºÍµ÷ÓÃÆ¾Ö¤ÐÅÏ¢£¨¼´Óû§ÈÏÖ¤ÐÅÏ¢£©¡£¿çÓòÈÏÖ¤ºÍ±£´æÆ¾Ö¤ÐÅϢͨ¹ýʵÏÖ doView()·½·¨½øÐС£Ê×ÏÈͨ¹ýPortletRequest.getData().getAttribute()·½·¨»ñȡԤÉèµÄ£¬½«Óû§Ãû¡¢ÃÜÂë¡¢µÇ¼ºÍµÇ³öÒ³ÃæµÄ URL ÒÔ¼° URL ÊôÐÔÖÃÓÚÒ»¸ö HashMap ¶ÔÏóÖУ¬Í¨¹ý HTTPFormBasedAuthCredential.getCredential()·½·¨»ñȡƾ֤£¬Ëæºóµ÷ÓÃHttpFormBasedAuthCredential.login()·½·¨½øÐÐÍⲿӦÓõÄÈÏÖ¤£¬Í¬Ñù£¬¿ÉÒÔÓÃHttpFormBasedAuthCredential.logout()·½·¨Í˳öÍⲿӦÓá£
¶ÔÓÚÔËÐÐÓÚͬһӦÓÃÖеŦÄÜ×é¼þ£¬Í¨¹ýHTTPrequest.getRemoteUser()·½ ·¨µÃµ½Óû§ ID£¬ÊµÏÖµ¥µãµÇ¼¹ý³Ì£¬Ëæºó¸ù¾Ý¸ÃÓû§ ID£¬´¦Àí²¢·µ»Ø¶ÔÓ¦µÄ¹¦
µÚ 11 Ò³ ¹² 30 Ò³
ÇøÓòÒ½ÁÆÎÀÉúÐÅÏ¢¹²ÏíÆ½Ì¨ÃÅ»§½¨Éè·½°¸
ÄÜÒ³Ãæ¡£
¶ÔÍⲿӦÓù¦ÄÜÔÚÍ¬Ò»Ò³ÃæÉϵĵǼºÍÐÅÏ¢¾ÛºÏÊÇWPSµÄ×îÖ÷Òª¹¦ÄÜ¡£¶ÔÓÚ WPS¶øÑÔ£¬ÔÚÃÅ»§Ê×Ò³ÖнøÐжàÀàÐÅÏ¢ÄÚÈݵľۺÏÏÔʾÊÇÖ÷ÒªµÄÓ¦ÓÃÄ¿±ê¡£±¾Æ½ ̨ÖеÄÓ¦Óù¦ÄÜÖ÷Òª·ÖΪÄÚÍâÍøÁ½´ó²¿·Ö£¬ÊôÓÚͬһӦÓÃÆ½Ì¨ÖеÄÐÅÏ¢¾ÛºÏ¡£¶Ô ÓÚÐÅÏ¢²¿·Ö£¬³éÈ¡ÁËÍâÍøÖеĽ¡¿µÖªÊ¶¸üС¢ÄÚÍøµÄÂÛ̳ºÍ²©¿Í¸üÐÂ×÷ΪÐÅÏ¢¾Û ºÏ×é¼þÓ¦Óá£ÁíÍ⼯³ÉÁËÓû§ÈÏÖ¤¡¢Óû§×é¼þÊÓͼ¡¢ËÑË÷ÒýÇæµÈ·þÎñ×é¼þ£¬·½±ã ÔÚ±àÔ±¹¤µÄÐÅÏ¢·ÃÎÊ¡£
×é¼þµÄ°²×°Ó벿Êð
¶¯Ì¬Ò³ÃæÊÇÓɶà¸ö×é¼þ×é³ÉµÄ£¬ÕâЩ×é¼þÓÉÃÅ»§¹ÜÀíԱͳһ¹ÜÀí¡£ÕâЩ×é¼þ ¶¼ÊǸù¾Ý¾ßÌåµÄÐèÇó×Ô¶¨Ò忪·¢µÄ²¢ÇÒ·ûºÏÒ»¶¨±ê×¼µÄweb³ÌÐò£¬¿ª·¢Íê³ÉÖ®ºó µ¼³öΪwar°ü¾Í¿ÉÒÔ¹©ÃÅ»§Ê¹ÓÃÁË¡£ÃÅ»§¹ÜÀíÔ±¿ÉÒÔÔÚÃÅ»§¹ÜÀíÆ½Ì¨°²×°ºÍ²¿Êð war°ü£¬³É¹¦Ö®ºóÕâЩwar°ü¾Í¿ÉÒÔ×÷Ϊ×é¼þ±»²¼¾ÖÔÚÒ³ÃæÖУ¬¹©Óû§·ÃÎÊ¡£
×é¼þµÄ°²È«ÐÔ¹ÜÀí
ÃÅ»§¹ÜÀíÔ±¿ÉÒÔÉèÖÃ×é¼þ¡¢Ò³ÃæµÈµÄ·ÃÎÊȨÏÞ£¬¼´ÉèÖÿɼû×é¼þºÍÒ³ÃæµÄ½Ç É«£¬´Ó¶øÌṩÁ˶Ô×é¼þµÄ·ÃÎÊ¿ØÖÆ¡£ÃÅ»§Ê¹ÓûùÓÚ½ÇÉ«£¨role based£©µÄȨÏÞ¿Ø ÖÆ¡£ÃÅ»§ÒÑÔ¤ÖÃÁËһЩ½ÇÉ«£¨½ÇÉ«²»Äܱ»Ôö¼ÓºÍÐ޸ģ©£¬ÃÅ»§ÀïµÄÒ³Ãæ¡¢×é¼þµÈ ¶¼¿ÉÒÔ¿´³É×ÊÔ´¡£´Ë´¦µÄ½ÇÉ«±»ÓÃÓÚ¶¨ÖÆ´óÓû§ÀàÐÍ£¬ÔÚ±¾Æ½Ì¨ÖÐÓÃÓÚ¶¨ÒåÆÕͨ Óû§¿ÉÒÔ¿´¼ûµÄÃÅ»§Ê×Ò³£¬ÒÔ¼°ÃÅ»§¹ÜÀíÔ±¿ÉÒÔ¿´¼ûµÄ¹ÜÀíÔ±Ê×Ò³¡£
±¾Æ½Ì¨µÄÃÅ»§ÖÐʹÓõĵǼ×é¼þÊÇ×Ô¶¨ÒåµÄ£¬¾ßÌåʵÏÖÁË LoginModule API¡£Óû§µÇ¼µÄʱºò£¬Í¨¹ýʹÓÃPortalÈÝÆ÷ÌṩµÄJAAS £¨Java Authentication Authorization Service £ºJavaÑéÖ¤ºÍÊÚȨAPI£©¡ª¡ªJAASÊÇJ2EE·þÎñÆ÷ÓÃÀ´ °ïÖúÓ¦ÓÃϵͳʵÏÖ°²È«¹¦ÄÜ¡ª¡ªJ2EE ÈÝÆ÷¾ÍÖ´ÐÐ LoginModule ½Ó¿Ú£¬Í¨¹ý½Ó¿Ú ºÍ¾ßÌåʵÏÖÖ®¼äµÄ¹ØÏµ£¬ Portal ÈÝÆ÷½«½áºÏ¾ßÌåÓ¦ÓÃϵͳʵÏÖÌØ¶¨µÄ JAAS ¹¦ ÄÜ¡£ ÕâÑù¾ÍÀûÓÃPortalÌṩµÄ°²È«»úÖÆ±£Ö¤Á˰²È«ÐÔ¡£
ÃÅ»§Ò³ÃæÖеÄ×é¼þ²¼¾Ö¹ÜÀí
ÔÚÒ»¸ö¶¯Ì¬Ò³ÃæÖУ¬´æÔÚ¶à¸ö×é¼þ£¬ÃÅ»§¹ÜÀíÔ±¿ÉÒÔÈÎÒâ²¼¾ÖÕâЩ×é¼þµÄλÖá£ÃÅ»§¹ÜÀíÔ±¿ÉÒÔÑ¡Ôñ½«Ò»¸ö¶¯Ì¬Ò³Ãæ·ÖΪ¼¸¸öÇøÓò£¨ÃÅ»§ÌṩÁ˼¸ÖÖĬÈÏ µÄ·½°¸£¬¹ÜÀíÔ±Ò²¿ÉÒÔ×Ô¼ºÉè¼Æ£©£¬ÔÚÿ¸öÇøÓò²¼¾Ö²»Í¬µÄ×é¼þ£¬µ±È»ÔÚͬһ¸ö ÇøÓòÄÚÒ²¿ÉÒÔ²¼¾Ö¶à¸ö×é¼þ¡£ÕâÐ©ÇøÓòµÄ´óС¶¼ÊÇ¿ÉÒÔµ÷ÕûµÄ¡£Í¬Ê±£¬Ò³ÃæµÄÖ÷
µÚ 12 Ò³ ¹² 30 Ò³
Ïà¹ØÍÆ¼ö£º