作用:对数据进行加密解密的类,由JDK提供
public static String encode(String str){String s =Base64.getEncoder().encodeToString(str.getBytes());return s;
}
public static String decode(String str){byte[] bytes = Base64.getDecoder().decode(str);String s = new String(bytes);return s;
}
import java.util.Base64;
public class Base64Utils {public static String encode(String str){String s = Base64.getEncoder().encodeToString(str.getBytes());return s;}public static String decode(String str){byte[] bytes = Base64.getDecoder().decode(str);String s = new String(bytes);return s;}
}
作用:对数据进行加密,由JDK提供
public static String encode(String str){try {MessageDigest messageDigest=MessageDigest.getInstance("MD5");messageDigest.update(str.getBytes("utf-8"));byte[] digest = messageDigest.digest();BigInteger bigInteger=new BigInteger(1, digest);String secret=bigInteger.toString(16);return secret;} catch (Exception e) {e.printStackTrace();}return null;
}
import java.math.BigInteger;
import java.security.MessageDigest;public class MD5Utils {public static String encode(String str){try {MessageDigest messageDigest=MessageDigest.getInstance("MD5");messageDigest.update(str.getBytes("utf-8"));byte[] digest = messageDigest.digest();BigInteger bigInteger=new BigInteger(1, digest);String secret=bigInteger.toString(16);return secret;} catch (Exception e) {e.printStackTrace();}return null;}
}
Base64:
1、可逆性。
2、可以将图片等二进制文件转换为文本文件。
3、可以把非ASCII字符的数据转换成ASCII字符,避免不可见字符。
MD5:
1、不可逆性。
2、任意长度的明文字符串,加密后得到的密文字符串是长度固定的
因为验证码的编写比较复杂,使用jar包(需要自行导入jar包)
ValidateCode.jar
生成验证码:
//步骤1,创建ValidateCode对象
//1参:生成图片宽度
//2参:生成图片高度
//3参:验证码位数
//4参:影响线数量
ValidateCode validateCode = new ValidateCode(width, height, codeCoun,
lineCount);
//步骤2,获取生产的验证码
String 变量名 = validateCode.getCode();
并通过response输出验证码
validateCode.write(response.getOutputStream());
示例
import cn.dsna.util.images.ValidateCode;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
@WebServlet("/code")
public class CodeServlet extends HttpServlet {@Overrideprotected void doGet(HttpServletRequest req, HttpServletResponseresp) throws ServletException, IOException {doPost(req,resp);}@Overrideprotected void doPost(HttpServletRequest req, HttpServletResponseresp) throws ServletException, IOException {ValidateCode validateCode = new ValidateCode(100, 30, 4, 10);String code = validateCode.getCode();req.getSession().setAttribute("code",code);validateCode.write(resp.getOutputStream());}
}
注意:引入浏览器缓存的原因,如果我们访问的地址没有发生改变浏览器不会为我们在此发起请求.
所以我们在请求地址后加一个可变的参数(可以加一个随机数),该参数无须被服务器获取.只是防止因浏览器缓存请求被拦截
$("#btn_getcode").click(function () {// $("#btn_getcode").attr("src","code?d="+new Date().getTime());//或$("#btn_getcode").attr("src","code?d="+Math.random());
});