Ajax ºÍ REST£¬µÚ 1 ²¿·Ö
2006 Äê 11 ÔÂ 09 ÈÕ
·þÎñÆ÷¶Ë Web Ó¦ÓóÌÐòÒò²ÉÓø»Ó¦ÓóÌÐòÄ£Ðͺͽ»¸¶¸öÐÔ»¯ÄÚÈݶø¾ß±¸ÁËÈÚÈëʽ£¨immersive£© µÄÌØµã£¬ÕâÖÖÌØµãԽͻ³ö£¬Ó¦ÓóÌÐò¼Ü¹¹¶Ô Web ¼Ü¹¹·ç¸ñ REST£¨Representational State Transfer£©µÄÎ¥±³¾ÍÔ½¶à¡£ÕâÖÖÎ¥±³»á½µµÍÓ¦ÓóÌÐòµÄ¿ÉÉìËõÐÔ£¬Ôö¼Óϵͳ¸´ÔÓÐÔ¡£Í¨¹ýÓë REST Ï໥е÷£¬Ajax ¼Ü¹¹½«Ê¹ÈÚÈëʽ Web Ó¦ÓóÌÐòÏû³ýÕâЩ¸ºÃæÓ°Ï죬¾¡Ïí REST ÄÇЩ³öÉ«µÄÌØÐÔ¡£
ÔÚ¶Ì¶Ì 15 ÄêÖУ¬World Wide Web ÒѾ´ÓÒ»ÏîÑо¿ÊµÑé³É³¤ÎªÏÖ´úÉç»áµÄ¼¼ÊõÖ§Öù¡£×î³õ·¢Ã÷ Web µÄÄ¿µÄÊÇʹÈËÃÇ¿ÉÒÔÇáËÉ·¢²¼ºÍÁ´½ÓÐÅÏ¢£¬ÏÖÔÚËüÒѾ·¢Õ¹ÎªÈí¼þÓ¦ÓóÌÐòµÄ¿ÉÐÐÆ½Ì¨¡£µ«Ëæ×ÅÓ¦ÓóÌÐòͨ¹ýʹÓø»Ó¦ÓóÌÐòÄ£ÐͺÍÉú³É¸öÐÔ»¯ÄÚÈݶø»ñµÃÁ˸ü¶àµÄÈÚÈëÐÔ£¬ËüÃǵļܹ¹¶Ô Web ¼Ü¹¹·ç¸ñ REST£¨Representational State Transfer£©µÄÎ¥±³Ò²Ô½À´Ô½¶à¡£ÕâÖÖÎ¥±³»á½µµÍÓ¦ÓóÌÐòµÄ¿ÉÉìËõÐÔ£¬Ôö¼Óϵͳ¸´ÔÓÐÔ¡£
ÐÂÐ赀 Ajax Web ¿Í»§»ú¼Ü¹¹·ç¸ñÈÃÈÚÈëʽ Web Ó¦ÓóÌÐòÓë REST ¼Ü¹¹·ç¸ñе÷Ò»Ö¡£Ê¹ËüÃÇ¿ÉÒÔ¾¡Ïí REST ÄÇЩ³öÉ«µÄÌØÐÔ£¬Í¬Ê±ÓÖÏû³ýÁËÓ¦ÓóÌÐòÎ¥±³ REST ×¼Ôòʱ´øÀ´µÄ²»Á¼ÌØÐÔ¡£±¾ÎĽ«½éÉÜΪÈÚÈëʽ Web Ó¦ÓóÌÐò³É¹¦½áºÏ Ajax ºÍ REST µÄ·½·¨ÓëÔÒò¡£
Çë·ÃÎÊ Ajax ¼¼Êõ×ÊÔ´ÖÐÐÄ£¬ÕâÊÇÓÐ¹Ø Ajax ±à³ÌÄ£ÐÍÐÅÏ¢µÄһվʽÖÐÐÄ£¬°üÀ¨ºÜ¶àÎĵµ¡¢½Ì³Ì¡¢ÂÛ̳¡¢blog¡¢wiki ºÍÐÂÎÅ¡£ÈκÎÐÂÐÅÏ¢¶¼ÄÜÔÚÕâÀïÕÒµ½¡£
REST£ºWeb ¼Ü¹¹
¾¡¹Ü World Wide Web ÊÇÔÚÊýÊ®ÄêµÄÏà¹ØÑо¿»ù´¡ÉϽ¨Á¢ÆðÀ´µÄ£¬µ«ËüµÄÓÐЧµ®ÉúÈÕÆÚÊÇ 1990 Äê 12 Ô£¬µ±Ê± Tim Berners-Lee Íê³ÉÁË Web Ö÷Òª×é¼þµÄ¹¤×÷ÔÐÍ£ºÍ³Ò»×ÊÔ´±êʶ·û£¨URI£©¡¢HTTP¡¢HTML¡¢ä¯ÀÀÆ÷ºÍ·þÎñÆ÷¡£Web ±»Ñ¸ÃͲÉÓã¬Ô¶Ô¶³¬¹ýÁËÏÈÇýÕßÃǵÄÔ¤ÆÚ¡£ÔÚ Roy Fielding ×î³öÃûµÄϵÁÐÎÄÕÂÖУ¨Çë²Î¿´ ²Î¿¼×ÊÁÏ£©£¬ËûÃèÊöÁË×Ô¼ºµ±Ê±µÄÐÄÇ飺
“¾¡¹Ü¶ÔÆä³É¹¦¸Ðµ½Ð˷ܲ»ÒÑ£¬µ«ÊÇ Internet ¿ª·¢ÕßÉçÇøÖ𽥿ªÊ¼µ£ÐÄ£¬Web ʹÓõÄÕâÖÖ¿ìËÙÔö³¤£¬ÒÔ¼°ÔçÆÚ HTTP µÄһЩ׾ÁÓµÄÍøÂçÌØÐÔ£¬»á¿ìËÙѹµ¹ Internet »ù´¡ÉèÊ©ËùÄܳе£µÄÈÝÁ¿£¬´Ó¶øµ¼ÖÂͻȻµÄ±ÀËú¡£”
“Ò»Öּܹ¹ÔÚÉè¼ÆÊ±¾ÍÓ¦¸Ã¿¼Âǵ½Ò»×éÌØÐÔ£¬ÈÃËü¿ÉÒÔÂú×ãÉõÖÁ³¬Ô½ÏµÍ³µÄÐèÇ󡣺öÂÔÕâÐ©ÌØÐÔ¿ÉÄܻᵼÖºóÆÚ±ä¸ü¸ÉÈÅÕû¸ö¼Ü¹¹£¬¾ÍÏñÊÇʹÓÃÒ»ÉÈÂ䵨´°È¥È¡´ú³ÐÖØÇ½»áÆÆ»µÕû¸ö½¨Öþ½á¹¹µÄ¿É¿¿ÐÔ¡£” —— Roy Fielding
Fielding ºÍÆäËûÈË¶Ô Web ¼Ü¹¹¼°ÆäÊÇ·ñÄܹ»×ãÒÔÖ§³Ö¸÷ÖÖÀ©Õ¹ºÍÓ÷¨ÖØÐ½øÐÐÁËÉóÊÓ¡£ÕâÖÖÖØÐÂÉóÊÓµÄÓÐÐνá¹û°üÀ¨¸üÐÂÖ
Ïà¹ØÎĵµ£º
ÕâÊÇÒ»¸ö»ùÓÚprototype.jsµÄajax·ÖÒ³£¬ÔËÓÃÁËspring¿ò¼Ü£¬×Ô¶¨Òå·ÖÒ³±êÇ©£¬Ã¿´Î½øÈëÁбíÒ³ÃæÊ±£¬°ÑÁÐ±í´æÈësession£¬·ÖÒ³Ö»¶Ôsession´æ´¢µÄÁÐ±í½øÐзÖÒ³£¬²»ÐèÒªÔÙÈ¥²éѯÊý¾Ý¿â£¬ÐÔÄÜ»á¸ßЩ
Ê×ÏÈÔÚweb.xmlÖÐÅäÖÃspring¼àÌýºÍservlet
web.xmlÄÚÈÝÈçÏ£º
<?xml version="1.0" encoding="UTF-8"?>
<web-app versi ......
ÔÚÒ»¸öÏîÄ¿Öзּ¶Ñ¡ÔñÐÐÕþÇø»®Ê±Óõ½AJAX½øÐÐÎÞˢм¶Áª£¬ÎÒÔÚÒ³ÃæÖбàÂëÓõÄÊÇUTF-8£¬×ÜÊDZ¨½Å±¾´íÎó£¬
ÎÒ°ÑÒ³Ãæ±àÂë»»³ÉGBKÓÖÊÇÕý³£µÄ£¬ºóÀ´ÔÚÍøÉÏËÑË÷ÁËһϣ¬ÔÚÒýÈëJSʱ¼ÓÈë±àÂë¾Í¿ÉÒÔÁË£¬ÈçÏ£º
<script language="Javascript" src="js/jquery.js" charset="gb2312"></script> ......
ÏîÄ¿ÉèÏë
ѧУ¸÷²¿ÃŵÄÍøÕ¾²¢·ÇÓõÄÒ»Ì×cmsϵͳ£¬ÐÐÕþ²¿ÃÅÓë¶þ¼¶Ñ§ÔºµÄÍøÕ¾ÊýÁ¿ÖÚ¶àÇÒ¿ª·¢ÈËÔ±µÄˮƽ²Î²î²»Æë£¬µ¼ÖÂÐÅÏ¢¼Ü¹¹±È½Ï»ìÂÒ¡£Í¨¹ýÒ»¸öÈ«¾ÖµÄ¹¤¾ßÌõʵÏÖȫУվµãÁ´½ÓÓ빫¸æ¶¯Ì¬¸üУ¨ÄÜÔÚÈκÎÒ»¸ö×ÓÕ¾µã¿´µ½×îÐµĹ«¸æ£©µÄ¹¦ÄÜ¡£
¹«¸æÄ£¿éÊý¾Ý¿âÉè¼Æ(Êý¾Ý¿â:globaltools)
Ê×ÏÈ´´½¨Ò»¸ö±íannouncement£¬°üÀ¨Ëĸö× ......
jqueryÖÐÓÃajax(Ã²ËÆ±àÂëĬÈÏΪutf-8)Èç¹ûÓÐÖÐÎĵϰ »á³öÏÖÂÒÂë ÏÂÃæµÄ½â¾ö°ì·¨Ö®Ò»£º
ÒÔÏÂÊÇjsÖеĴúÂë
classname=encodeURI($('#classname').val());
classdescription=encodeURI($('#classdescription').val());
actionArr={classname:classname,classdescription:classdescription};
$.post("product_class ......