日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

[Struts]Token 使用及原理

發布時間:2025/3/14 编程问答 21 豆豆
生活随笔 收集整理的這篇文章主要介紹了 [Struts]Token 使用及原理 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

?

Struts Token?使用

?

1,先在一個Action中,調用saveToken(HttpServletRequest request)方法。然后轉向帶有表單的JSP頁面。

?

2,在JSP頁面提交表單給一個Action,再這個Action中進行是否為重復提交的判斷。

?

if?(isTokenValid(request,?true))?{

?????????????????????//?未重復提交時,正確的時候應該做的事情

??????????????????return?mapping.findForward("success");

??????????????}?else?{

????????????//?重復提交時,需要做的事情

??????????????????saveToken(request);

??????????????????return?mapping.findForward("error");

??????????????}

?

?

Struts Token?機制:

?

1,??由第一個Action調用saveToken(HttpServletRequest request),這個方法內部實現如下:

?

protected?void?saveToken(HttpServletRequest?request)?{

????????token.saveToken(request);

}

?

?

????????token.saveToken(request);

???????這個方法的實現如下:

?

public?synchronized?void?saveToken(HttpServletRequest?request)?{

?

????????HttpSession?session?=?request.getSession();

????????String?token?=?generateToken(request);

????????if?(token?!=?null)?{

????????????session.setAttribute(Globals.TRANSACTION_TOKEN_KEY,?token);

????????}

}

?

這個方法調用generateToken方法實現如下:

?

public?synchronized?void?saveToken(HttpServletRequest?request)?{

?

????????HttpSession?session?=?request.getSession();

????????String?token?=?generateToken(request);

????????if?(token?!=?null)?{

????????????session.setAttribute(Globals.TRANSACTION_TOKEN_KEY,?token);

????????}

}

?

?

generateToken完畢后,將得到的唯一值setAttribute到session中。

?

session.setAttribute(Globals.TRANSACTION_TOKEN_KEY,?token);

?

?

Globals.TRANSACTION_TOKEN_KEY的值是:” org.apache.struts.action.TOKEN”

?

?

然后跳轉到JSP頁面。

?

?

2,??JSP頁面的Struts自定義標簽?<html:form>的標簽類:org.apache.struts.taglib.html. FormTag

?

這個類的doStartTag()方法會調用本類的renderToken()方法。

?

protected?String?renderToken()?{

????????StringBuffer?results?=?new?StringBuffer();

????????HttpSession?session?=?pageContext.getSession();

?

????????if?(session?!=?null)?{

????????????String?token?=

????????????????(String)?session.getAttribute(Globals.TRANSACTION_TOKEN_KEY);

????????????????

????????????if?(token?!=?null)?{

????????????????results.append("<input?type=\"hidden\"?name=\"");

????????????????results.append(Constants.TOKEN_KEY);

????????????????results.append("\"?value=\"");

????????????????results.append(token);

????????????????if?(this.isXhtml())?{

????????????????????results.append("\"?/>");

????????????????}?else?{

????????????????????results.append("\">");

????????????????}

????????????}

????????}

?

????????return?results.toString();

}

?

?

?

這樣子會生成類似于

?

<input?type="hidden"?name="org.apache.struts.taglib.html.TOKEN"?
?????????value="6aa35341f25184fd996c4c918255c3ae">

?

的隱藏標簽。

?

然后提交到一個Action中,在Action中用isTokenValid()方法進行比較session中” org.apache.struts.action.TOKEN”的這個key所對應的值和提交來的request中的” org.apache.struts.action.TOKEN”的這個value是否一致。

如果為true,那么證明可以提交。如果為false,證明已經重復,不允許提交。

轉載于:https://www.cnblogs.com/u0mo5/p/4170426.html

總結

以上是生活随笔為你收集整理的[Struts]Token 使用及原理的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。