[转]java利用AES实现URL的参数加密

原文地址:http://h5566h.iteye.com/blog/1465426

很多时候需要在URL传参,希望URL参数能够加密,这里我结合了文章http://www.2cto.com/kf/201112/114046.html  提供的思路,然后结合java的ASE加密实现,写了下面的代码:

代码主要考虑两个问题:1、加密过的字符必须能有使用Url传输 2、加密算法必须是对称算法,通过私钥可以解密

另外:代码中为什么要把二进制转换成16进制呢,因为强制把byte数组转化成String的话,会出现乱码,第二是强制转换过的字符串,再转回byte数组的时候,二进制会变化,而且二进制的位数不是16的倍数(解密算法中的输入二进制数组的大小必须是16的倍数)。因此需要二进制的相互转换

代码如下:

Java代码  

  1. package p;
  2. import java.security.SecureRandom;
  3. import javax.crypto.Cipher;
  4. import javax.crypto.KeyGenerator;
  5. import javax.crypto.SecretKey;
  6. public class AEStest {
  7. public static void main(String[] args) throws Exception {
  8. // TODO Auto-generated method stub
  9. String str = "user=admin&pwd=admin";
  10. String key = "12345678";
  11. String encrytStr;
  12. byte[] encrytByte;
  13. byte[] byteRe = enCrypt(str,key);
  14. //加密过的二进制数组转化成16进制的字符串
  15. encrytStr = parseByte2HexStr(byteRe);
  16. System.out.println("加密后:"+encrytStr);
  17. //加密过的16进制的字符串转化成二进制数组
  18. encrytByte = parseHexStr2Byte(encrytStr);
  19. System.out.println("解密后:"+deCrypt(encrytByte,key));
  20. }
  21. /**
  22. * 加密函数
  23. * @param content   加密的内容
  24. * @param strKey    密钥
  25. * @return          返回二进制字符数组
  26. * @throws Exception
  27. */
  28. public static byte[] enCrypt(String content,String strKey) throws Exception{
  29. KeyGenerator keygen;
  30. SecretKey desKey;
  31. Cipher c;
  32. byte[] cByte;
  33. String str = content;
  34. keygen = KeyGenerator.getInstance("AES");
  35. keygen.init(128, new SecureRandom(strKey.getBytes()));
  36. desKey = keygen.generateKey();
  37. c = Cipher.getInstance("AES");
  38. c.init(Cipher.ENCRYPT_MODE, desKey);
  39. cByte = c.doFinal(str.getBytes("UTF-8"));
  40. return cByte;
  41. }
  42. /** 解密函数
  43. * @param src   加密过的二进制字符数组
  44. * @param strKey  密钥
  45. * @return
  46. * @throws Exception
  47. */
  48. public static String deCrypt (byte[] src,String strKey) throws Exception{
  49. KeyGenerator keygen;
  50. SecretKey desKey;
  51. Cipher c;
  52. byte[] cByte;
  53. keygen = KeyGenerator.getInstance("AES");
  54. keygen.init(128, new SecureRandom(strKey.getBytes()));
  55. desKey = keygen.generateKey();
  56. c = Cipher.getInstance("AES");
  57. c.init(Cipher.DECRYPT_MODE, desKey);
  58. cByte = c.doFinal(src);
  59. return new String(cByte,"UTF-8");
  60. }
  61. /**2进制转化成16进制
  62. * @param buf
  63. * @return
  64. */
  65. public static String parseByte2HexStr(byte buf[]) {
  66. StringBuffer sb = new StringBuffer();
  67. for (int i = 0; i < buf.length; i++) {
  68. String hex = Integer.toHexString(buf[i] & 0xFF);
  69. if (hex.length() == 1) {
  70. hex = ‘0‘ + hex;
  71. }
  72. sb.append(hex.toUpperCase());
  73. }
  74. return sb.toString();
  75. }
  76. /**将16进制转换为二进制
  77. * @param hexStr
  78. * @return
  79. */
  80. public static byte[] parseHexStr2Byte(String hexStr) {
  81. if (hexStr.length() < 1)
  82. return null;
  83. byte[] result = new byte[hexStr.length()/2];
  84. for (int i = 0;i< hexStr.length()/2; i++) {
  85. int high = Integer.parseInt(hexStr.substring(i*2, i*2+1), 16);
  86. int low = Integer.parseInt(hexStr.substring(i*2+1, i*2+2), 16);
  87. result[i] = (byte) (high * 16 + low);
  88. }
  89. return result;
  90. }
  91. }
时间: 2024-08-05 15:25:18

[转]java利用AES实现URL的参数加密的相关文章

利用jQuery 解决URL请求参数有中文时出现乱码的问题

利用jQuery 解决URL请求参数有中文时出现乱码的问题 在开发的时候经常会碰到URL中请求参数含有中文的情况,这时如果在前台不作处理,直接在后台利用request.getParameter()拿对应的参数值就会出现中文乱码. 这时可以先利用jQuery对对应中文进行encodeURI(),例子如下: 前台对应代码 <!--省畋无关代码--> <input type="button" id="submitA" value="重发短信&q

利用MVC的过滤器实现url的参数加密和解密

最近在与一个IOS应用做接口对接,之前一直都没有遇到什么很大的问题,但是有一天发现可以通过软件解析app的url,然后直接通过url的拼接修改接口数据,这一下使得数据的安全性和准确性都降低了,于是就想到了url加密. 然后在网上查了一下url的加密算法,使用比较普遍的还是Base64的加密,但是对于如何实现加密,网上的资料确不多,可能是我搜索的关键词不对.既然没有现成的参考文件,那么就只能靠自己了.因为所有的Controller都继承一个基Controller,所以比较自然的想到在基Contro

java.net.URLEncoder 解决url中文参数乱码问题【2014-11-17】

1.编码规则 java.net Class URLEncoder java.lang.Object java.net.URLEncoder public class URLEncoder extends Object Utility class for HTML form encoding. This class contains static methods for converting a String to the application/x-www-form-urlencoded MIM

Java利用MessageDigest提供的MD5算法加密字符串或文件

MD5是常用的加密算法,也经常用于校验信息完整,如文件的完整性.用术语讲,MD5是一种消息摘要算法(Message Digest Algorithm).另外还有一种常用的消息摘要算法SHA1.如果想了解这些的话,可以去百度百科:MD5.SHA1.消息摘要算法. Java已经实现了MD5.SHA1算法.利用java.security.MessageDigest类就可以获取字符串和文件的MD5以及SHA1结果. 1.字符串的MD5(下面的代码有详细注释) public static String s

ASP.NET - URL中参数加密解密操作

效果: 代码: using System; using System.Text; using System.IO; using System.Security.Cryptography; public partial class _Default : System.Web.UI.Page { protected void Page_Load(object sender, EventArgs e) { Response.Write("<a href = " + "http

nginx利用location匹配url中?号后的参数

nginx利用location匹配url中?号后的参数 http://www.baidu.com/index.php?a=1&b=2location能匹配到url,但是匹配不到url后面的参数,例如:?a=1&b=2 需求:访问地址:https://www.aposoft.com/all-apowersoft/?from=edm 开发要求可不可以只是这个完整地址https://www.aposoft.com/all-apowersoft/?from=edm 跳转到404,然后https:/

JAVA利用HttpClient进行POST请求(HTTPS)

目前,要为另一个项目提供接口,接口是用HTTP URL实现的,最初的想法是另一个项目用jQuery post进行请求. 但是,很可能另一个项目是部署在别的机器上,那么就存在跨域问题,而JQuery的post请求是不允许跨域的. 这时,就只能够用HttpClient包进行请求了,同时由于请求的URL是HTTPS的,为了避免需要证书,所以用一个类继承DefaultHttpClient类,忽略校验过程. 1.写一个SSLClient类,继承至HttpClient [java] view plain c

Java利用Eclipse和Mysql数据库连接并存储图片——存储图片

import java.io.File; import java.io.FileInputStream; import java.io.InputStream; import java.sql.Connection; import java.sql.DriverManager; import java.sql.PreparedStatement; public class insertImage {  public static void main(String[]args) throws Ex

Java高级编程之URL处理

Java URL处理 URL(Uniform Resource Locator)中文名为统一资源定位符,有时也被俗称为网页地址.表示为互联网上的资源,如网页或者FTP地址. 本章节我们将介绍Java是如处理URL的.URL可以分为如下几个部分. protocol://host:port/path?query#ref protocols(协议)可以是 HTTP, HTTPS, FTP, 和File.port 为端口号.path为文件路径及文件名. HTTP协议的URL实例如下: http://ww