亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Java用Cookie限制點(diǎn)贊次數(shù)(簡(jiǎn)版)

 更新時(shí)間:2016年02月03日 11:44:22   投稿:mrr  
最近做了一個(gè)項(xiàng)目,其中有項(xiàng)目需求是,要用cookie實(shí)現(xiàn)限制點(diǎn)贊次數(shù),特此整理,把實(shí)現(xiàn)代碼分享給大家供大家學(xué)習(xí)

本文簡(jiǎn)單利用Cookie技術(shù)來(lái)簡(jiǎn)單的限制點(diǎn)贊次數(shù),并不能杜絕游客的惡意點(diǎn)贊。

好了,不啰嗦了,先來(lái)看看基礎(chǔ)知識(shí):

ajax+springMVC+cookie

中間框架你隨意,樓主這里用了springMVC,只要取得HttpServletRequest和HttpServletResponse你就可以操作cookie啦

什么是Cookie

cookie 是存儲(chǔ)于訪問(wèn)者的計(jì)算機(jī)中的變量。每當(dāng)同一臺(tái)計(jì)算機(jī)通過(guò)瀏覽器請(qǐng)求某個(gè)頁(yè)面時(shí),就會(huì)發(fā)送這個(gè) cookie。你可以使用 JavaScript 來(lái)創(chuàng)建和取回 cookie 的值。

第2篇閱讀中提到了cookie存放在http的request中,這為我們?cè)趈ava中操作cookie提供了可能

cookie主要用途編輯

服務(wù)器可以利用Cookies包含信息的任意性來(lái)篩選并經(jīng)常性維護(hù)這些信息,以判斷在HTTP傳輸中的狀態(tài)。Cookies最典型的應(yīng)用是判定注冊(cè)用戶是否已經(jīng)登錄網(wǎng)站,用戶可能會(huì)得到提示,是否在下一次進(jìn)入此網(wǎng)站時(shí)保留用戶信息以便簡(jiǎn)化登錄手續(xù),這些都是Cookies的功用。另一個(gè)重要應(yīng)用場(chǎng)合是“購(gòu)物車”之類處理。用戶可能會(huì)在一段時(shí)間內(nèi)在同一家網(wǎng)站的不同頁(yè)面中選擇不同的商品,這些信息都會(huì)寫入Cookies,以便在最后付款時(shí)提取信息。

基本了解了Cookie,我們來(lái)看看java怎么操作cookie

建立一個(gè)無(wú)生命周期的cookie,即隨著瀏覽器的關(guān)閉即消失的cookie,代碼如下:

HttpServletRequest request 
HttpServletResponse response
Cookie cookie = new Cookie("cookiename","cookievalue");
response.addCookie(cookie);

  建立一個(gè)有生命周期的cookie,可以設(shè)置他的生命周期

cookie = new Cookie("cookiename","cookievalue");
//此方法接收一個(gè)以秒為單位的整數(shù),該整數(shù)表示cookie的最大生存期。負(fù)值表示當(dāng)關(guān)閉瀏覽器時(shí),該cookie將被清除,表示必須立即清除該cookie。
cookie.setMaxAge();
//設(shè)置路徑,這個(gè)路徑即該工程下都可以訪問(wèn)該cookie 如果不設(shè)置路徑,那么只有設(shè)置該cookie路徑及其子路徑可以訪問(wèn)
cookie.setPath("/");
response.addCookie(cookie);

讀取cookie,讀取cookie代碼如下

Cookie[] cookies = request.getCookies();//這樣便可以獲取一個(gè)cookie數(shù)組
for(Cookie cookie : cookies){
cookie.getName();// get the cookie name
cookie.getValue(); // get the cookie value
}

springMVC具體限制操作

/**
* 點(diǎn)贊操作
*
* @param comment
* @param request
* @param response
* @return
*/
@RequestMapping(value = TalkingConst.PATH_LOVE, method = RequestMethod.POST)
public @ResponseBody Map<String, Object> love(Comment comment, HttpServletRequest request, HttpServletResponse response) {
Map<String, Object> map = new HashMap<String, Object>();
// 根據(jù)cookie的name取的cookie getCookieByName()方法可以參考代碼塊上的鏈接處的封裝
Cookie cookie = getCookieByName(request, comment.getCommentId() + "");
// 判斷cookie是否為空
if (cookie != null) {
// cookie不為空,提示已經(jīng)贊過(guò)
// 前臺(tái)傳值
map.put(TalkingConst.ATTRIBUTE_MSG, "您已贊過(guò),請(qǐng)休息一下~");
map.put(TalkingConst.ATTRIBUTE_NAME_RESULT, Boolean.FALSE);
} else {
// 數(shù)據(jù)庫(kù)操作,點(diǎn)贊個(gè)數(shù)加
commentService.love(comment);
// 創(chuàng)建cookie addCookie()方法可以參考代碼塊上的鏈接處的封裝
addCookie(response, comment.getCommentId() + "", "", );
map.put(TalkingConst.ATTRIBUTE_NAME_RESULT, Boolean.TRUE);
}
return map;
}

至此,簡(jiǎn)單的cookie限制點(diǎn)贊次數(shù)基本完成。前臺(tái)的代碼沒(méi)放因?yàn)槊總€(gè)點(diǎn)贊的樣式都不大一樣。

以上所述給大家分享了Java用Cookie限制點(diǎn)贊次數(shù)的相關(guān)知識(shí),希望對(duì)大家有所幫助。

相關(guān)文章

最新評(píng)論