[JSP]如何加密URL中.jsp?后面的参数?
问题描述:我们公司有个线上签核系统,将申请人填写好的表单发送到主管的信箱,主管不需要登录,只需点击url即可查看到表单,现在问题是url中的参数都是显式的,这样别人只需修...
问题描述:
我们公司有个线上签核系统,将申请人填写好的表单发送到主管的信箱,主管不需要登录,只需点击url即可查看到表单,现在问题是url中的参数都是显式的,这样别人只需修改参数就可以看到别的单子,所以想要加密url,不知该如何加密。
还有,能否实现当输入显式的URL(未加过密的url)时,禁止其访问?
我这是jsp,不是asp,请不要盲目copy网上的资料。
至于加密,我已经有了思路。
至于第二个问题有没有好的方法? 展开
我们公司有个线上签核系统,将申请人填写好的表单发送到主管的信箱,主管不需要登录,只需点击url即可查看到表单,现在问题是url中的参数都是显式的,这样别人只需修改参数就可以看到别的单子,所以想要加密url,不知该如何加密。
还有,能否实现当输入显式的URL(未加过密的url)时,禁止其访问?
我这是jsp,不是asp,请不要盲目copy网上的资料。
至于加密,我已经有了思路。
至于第二个问题有没有好的方法? 展开
2015-12-15 · 做真实的自己 用良心做教育
千锋教育
千锋教育专注HTML5大前端、JavaEE、Python、人工智能、UI&UE、云计算、全栈软件测试、大数据、物联网+嵌入式、Unity游戏开发、网络安全、互联网营销、Go语言等培训教育。
向TA提问
关注
展开全部
加密参数是jsp参数传递中的一种安全措施,加密方法如下:
建议使用对称加密如:DES或者是PBE算法。
加密算法如下:
public static String encrypt(String key, String plainText) throws Exception {
String encryptTxt = "";
try {
byte[] salt = new byte[8];
MessageDigest md = MessageDigest.getInstance("MD5");
md.update(key.getBytes());
byte[] digest = md.digest();
for (int i = 0; i < 8; i++) {
salt[i] = digest[i];
}
PBEKeySpec pbeKeySpec = new PBEKeySpec(key.toCharArray());
SecretKeyFactory keyFactory = SecretKeyFactory
.getInstance("PBEWithMD5AndDES");
SecretKey skey = keyFactory.generateSecret(pbeKeySpec);
PBEParameterSpec paramSpec = new PBEParameterSpec(salt, ITERATIONS);
Cipher cipher = Cipher.getInstance("PBEWithMD5AndDES");
cipher.init(Cipher.ENCRYPT_MODE, skey, paramSpec);
byte[] cipherText = cipher.doFinal(plainText.getBytes());
String saltString = new String(Base64.encode(salt));
String ciphertextString = new String(Base64.encode(cipherText));
return saltString + ciphertextString;
} catch (Exception e) {
throw new Exception("Encrypt Text Error:" + e.getMessage(), e);
}
使用方法:
把jsp?后面的参数作为参数传入encrypt();然后就可以返回加密串了。
建议使用对称加密如:DES或者是PBE算法。
加密算法如下:
public static String encrypt(String key, String plainText) throws Exception {
String encryptTxt = "";
try {
byte[] salt = new byte[8];
MessageDigest md = MessageDigest.getInstance("MD5");
md.update(key.getBytes());
byte[] digest = md.digest();
for (int i = 0; i < 8; i++) {
salt[i] = digest[i];
}
PBEKeySpec pbeKeySpec = new PBEKeySpec(key.toCharArray());
SecretKeyFactory keyFactory = SecretKeyFactory
.getInstance("PBEWithMD5AndDES");
SecretKey skey = keyFactory.generateSecret(pbeKeySpec);
PBEParameterSpec paramSpec = new PBEParameterSpec(salt, ITERATIONS);
Cipher cipher = Cipher.getInstance("PBEWithMD5AndDES");
cipher.init(Cipher.ENCRYPT_MODE, skey, paramSpec);
byte[] cipherText = cipher.doFinal(plainText.getBytes());
String saltString = new String(Base64.encode(salt));
String ciphertextString = new String(Base64.encode(cipherText));
return saltString + ciphertextString;
} catch (Exception e) {
throw new Exception("Encrypt Text Error:" + e.getMessage(), e);
}
使用方法:
把jsp?后面的参数作为参数传入encrypt();然后就可以返回加密串了。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
那就没办法,以为你在网上找不到,帮找一个.说实在的,我不会,呵呵.
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询