在web开发中,有时候为了防止表单的重复提交,都会在表单域中埋有一个token令牌,然后在服务器端将此token存储到redis或者session中,当用户提交表单时,则比较token,被使用过的令牌token立刻作废。当此token再次发起请求时,则认为此请求已经处理过;从而达到避免表单的重复提交。
package Token;
import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.Random;
import Decoder.BASE64Encoder;
//令牌生产器
public class TokenProcessor {
private TokenProcessor(){}
private static TokenProcessor instance = new TokenProcessor();
public static TokenProcessor getInstance(){
return instance;
}
public String generateTokeCode(){
String value = System.currentTimeMillis()+new Random().nextInt()+"";
System.out.println(value);
long currentTime = System.currentTimeMillis();
SimpleDateFormat formatter = new SimpleDateFormat("yyyy年-MM月dd日-HH