servlet利用token防止重复提交

1:定义一个servlet:AccessTokenServlet.并有一下内容:
String token = System.currentTimeMillis()+new Random().nextInt()+"";
MessageDigest md = MessageDigest.getInstace("md5");
byte[] md5 = md.digest(token.getBytes());
BASE64Encoder encoder = new BASE64Encoder();
String result = encoder.encode(md5);
至此生成一个唯一的字符串作为我们的令牌。并request.getSession().setAttribute("token",result);
最后,request.getDispatcher("/showLogin.jsp").forward(request,response);进行表单的提交。
2:showLogin.jsp:
<form action="/应用名/LoginServlet">
<input type="hiden" name="token" value=${token}/>
<input type="text" />
<input type="submit"/>
</form>
3:LoginServlet:
String token = request.getParameter("token");
判断token不为null且token==session中的令牌值就:
request.getSession().removeAttribute("token");
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值