java框架--springmvc --ajax-json-upload+maven
Posted 周无极
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了java框架--springmvc --ajax-json-upload+maven相关的知识,希望对你有一定的参考价值。
注:eclipse 开发工具 <context:component-scan base-package="com.zhouwuji.controller"></context:component-scan> 加入后 controller包的控制类会有S符好
package com.zhouwuji.controller; import java.io.File; import java.io.FileInputStream; import java.io.IOException; import java.io.OutputStream; import java.net.URLEncoder; import java.util.Iterator; import java.util.Map; import javax.servlet.ServletException; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import org.apache.commons.io.FileUtils; import org.springframework.stereotype.Controller; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RequestParam; import org.springframework.web.bind.annotation.ResponseBody; import org.springframework.web.multipart.MultipartFile; import org.springframework.web.multipart.MultipartHttpServletRequest; import org.springframework.web.multipart.commons.CommonsMultipartFile; import org.springframework.web.multipart.commons.CommonsMultipartResolver; @Controller public class FileController { @RequestMapping("/download.do") public void doMain(HttpServletRequest request, HttpServletResponse response)throws ServletException, IOException { //得到要下载的文件名 String fileName =request.getParameter("filename"); System.out.println("fileName:"+fileName.trim()); //23239283-92489-阿凡达.avi // fileName="zhangruan.txt"; // fileName = new String(fileName.getBytes("iso8859-1"),"UTF-8"); //上传的文件都是保存在/WEB-INF/upload目录下的子目录当中 String fileSaveRootPath=request.getServletContext().getRealPath("/WEB-INF/upload"); //得到要下载的文件 File file = new File(fileSaveRootPath + "\\\\" + fileName); //如果文件不存在 if(!file.exists()){ request.setAttribute("message", "您要下载的资源已被删除!!"); request.getRequestDispatcher("/fail.jsp").forward(request, response); return; } //处理文件名 String realname = fileName.substring(fileName.indexOf(".")+1); //设置响应头,控制浏览器下载该文件 response.setHeader("content-disposition", "attachment;filename=" + URLEncoder.encode(realname, "UTF-8")); //读取要下载的文件,保存到文件输入流 FileInputStream in = new FileInputStream(file); //创建输出流 OutputStream out = response.getOutputStream(); //创建缓冲区 byte buffer[] = new byte[1024]; int len = 0; //循环将输入流中的内容读取到缓冲区当中 while((len=in.read(buffer))>0){ //输出缓冲区的内容到浏览器,实现文件下载 out.write(buffer, 0, len); } System.out.println("下载成功"); //关闭文件输入流 in.close(); //关闭输出流 out.close(); } @RequestMapping("/upload.do") //@RequestParam("uploadfile") @ResponseBody public String queryFileData(@RequestParam("uploadfile")CommonsMultipartFile file,HttpServletRequest request){ System.out.println("+++++++++++++++++"+request.getParameter("username")); /*MultipartFile是对当前上传的文件的封装, * 当同时上传多个文件时,可以给定多个MultipartFile参数(数组) */ if(file!=null){ System.out.println("文件对象接到了!"); //获取文件名 String filename=file.getOriginalFilename(); //获取上传路径 String path=request.getSession().getServletContext().getRealPath("/WEB-INF/upload/"+filename.trim()); System.out.println("path:"+path); //创建文件流并指定写入路径 File destFile=new File(path); //springmvc的方式 //该方法自动操作,不需要额外的去关闭IO流 //复制临时文件到指定文件夹下 try { FileUtils.copyInputStreamToFile(file.getInputStream(), destFile); System.out.println("上传成功"); return "/success.jsp"; } catch (IOException e) { e.printStackTrace(); System.out.println("上传失败"); return "/error.jsp"; } }else{ System.out.println("文件没有对象接到了!"); return "/error.jsp"; } } } /*文件对象接到了! filename:中软笔记.txt path:D:/apache-tomcat-7.0.82-windows-x64/apache-tomcat-7.0.82/webapps/project-ajaxjson/upload/中软笔记.txt 上传成功*/
package com.zhouwuji.controller; import java.util.ArrayList; import java.util.List; import java.util.Map; import java.util.Map.Entry; import javax.servlet.http.HttpServletRequest; import org.springframework.stereotype.Controller; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.ResponseBody; import com.zhouwuji.util.EncryptUtil; @Controller public class LoginController { @RequestMapping("/json.do") @ResponseBody public List<User> login(HttpServletRequest request) throws Exception{ String username=request.getParameter("username"); String password=request.getParameter("password"); // key 为解密密钥 String key=request.getParameter("key"); if (username !=null && password !=null ) { System.out.println("username:"+EncryptUtil.decrypt(username, key)); System.out.println("password:"+EncryptUtil.decrypt(password, key)); } if (key==null) { key="LmMGStGtOpF4xNyvYt54EQ=="; } List<User> users=new ArrayList<User>(); users.add(new User(1, EncryptUtil.encrypt("张三",key), "男")); users.add(new User(2, EncryptUtil.encrypt("李四",key), "男")); users.add(new User(3, EncryptUtil.encrypt("西施",key), "女")); return users; } }
package com.zhouwuji.controller; public class User { private int id; private String name; private String sex; public int getId() { return id; } public void setId(int id) { this.id = id; } public String getName() { return name; } public void setName(String name) { this.name = name; } public String getSex() { return sex; } public void setSex(String sex) { this.sex = sex; } public User(int id, String name, String sex) { super(); this.id = id; this.name = name; this.sex = sex; } public User() { super(); } }
package com.zhouwuji.util; import java.io.IOException; import java.io.UnsupportedEncodingException; import java.security.MessageDigest; import javax.crypto.Cipher; import javax.crypto.spec.IvParameterSpec; import javax.crypto.spec.SecretKeySpec; import sun.misc.BASE64Decoder; import sun.misc.BASE64Encoder; /** * 功能描述 DES+MD5 加密工具类 * 加密常用类 */ public class EncryptUtil { // 密钥是16位长度的byte[]进行Base64转换后得到的字符串 // public static String key = "LmMGStGtOpF4xNyvYt54EQ=="; /** * <li> * 方法名称:encrypt</li> <li> * 加密方法 * @param xmlStr * 需要加密的消息字符串 * @return 加密后的字符串 */ public static String encrypt(String xmlStr,String key) { byte[] encrypt = null; try { // 取需要加密内容的utf-8编码。 encrypt = xmlStr.getBytes("utf-8"); } catch (UnsupportedEncodingException e) { e.printStackTrace(); } // 取MD5Hash码,并组合加密数组 byte[] md5Hasn = null; try { md5Hasn = EncryptUtil.MD5Hash(encrypt, 0, encrypt.length); } catch (Exception e) { e.printStackTrace(); } // 组合消息体 byte[] totalByte = EncryptUtil.addMD5(md5Hasn, encrypt); // 取密钥和偏转向量 byte[] key1 = new byte[8]; byte[] iv = new byte[8]; getKeyIV(key, key1, iv); SecretKeySpec deskey = new SecretKeySpec(key1, "DES"); IvParameterSpec ivParam = new IvParameterSpec(iv); // 使用DES算法使用加密消息体 byte[] temp = null; try { temp = EncryptUtil.DES_CBC_Encrypt(totalByte, deskey, ivParam); } catch (Exception e) { e.printStackTrace(); } // 使用Base64加密后返回 return new BASE64Encoder().encode(temp); } /** * <li> * 方法名称:encrypt</li> <li> * 功能描述: * * <pre> * 解密方法 * </pre> * * </li> * * @param xmlStr * 需要解密的消息字符串 * @return 解密后的字符串 * @throws Exception */ public static String decrypt(String xmlStr,String key) throws Exception { // base64解码 BASE64Decoder decoder = new BASE64Decoder(); byte[] encBuf = null; try { encBuf = decoder.decodeBuffer(xmlStr); } catch (IOException e) { e.printStackTrace(); } // 取密钥和偏转向量 byte[] key1 = new byte[8]; byte[] iv = new byte[8]; getKeyIV(key, key1, iv); SecretKeySpec deskey = new SecretKeySpec(key1, "DES"); IvParameterSpec ivParam = new IvParameterSpec(iv); // 使用DES算法解密 byte[] temp = null; try { temp = EncryptUtil.DES_CBC_Decrypt(encBuf, deskey, ivParam); } catch (Exception e) { e.printStackTrace(); } // 进行解密后的md5Hash校验 byte[] md5Hash = null; try { md5Hash = EncryptUtil.MD5Hash(temp, 16, temp.length - 16); } catch (Exception e) { e.printStackTrace(); } // 进行解密校检 for (int i = 0; i < md5Hash.length; i++) { if (md5Hash[i] != temp[i]) { // System.out.println(md5Hash[i] + "MD5校验错误。" + temp[i]); throw new Exception("MD5校验错误。"); } } // 返回解密后的数组,其中前16位MD5Hash码要除去。 return new String(temp, 16, temp.length - 16, "utf-8"); } /** * <li> * 方法名称:TripleDES_CBC_Encrypt</li> <li> * 功能描述: * * <pre> * 经过封装的三重DES/CBC加密算法,如果包含中文,请注意编码。 * </pre> * * </li> * * @param sourceBuf * 需要加密内容的字节数组。 * @param deskey * KEY 由24位字节数组通过SecretKeySpec类转换而成。 * @param ivParam * IV偏转向量,由8位字节数组通过IvParameterSpec类转换而成。 * @return 加密后的字节数组 * @throws Exception */ public static byte[] TripleDES_CBC_Encrypt(byte[] sourceBuf, SecretKeySpec deskey, IvParameterSpec ivParam) throws Exception { byte[] cipherByte; // 使用DES对称加密算法的CBC模式加密 Cipher encrypt = Cipher.getInstance("TripleDES/CBC/PKCS5Padding"); encrypt.init(Cipher.ENCRYPT_MODE, deskey, ivParam); cipherByte = encrypt.doFinal(sourceBuf, 0, sourceBuf.length); // 返回加密后的字节数组 return cipherByte; } /** * <li> * 方法名称:TripleDES_CBC_Decrypt</li> <li> * 功能描述: * * <pre> * 经过封装的三重DES / CBC解密算法 * </pre> * * </li> * * @param sourceBuf * 需要解密内容的字节数组 * @param deskey * KEY 由24位字节数组通过SecretKeySpec类转换而成。 * @param ivParam * IV偏转向量,由6位字节数组通过IvParameterSpec类转换而成。 * @return 解密后的字节数组 * @throws Exception */ public static byte[] TripleDES_CBC_Decrypt(byte[] sourceBuf, SecretKeySpec deskey, IvParameterSpec ivParam) throws Exception { byte[] cipherByte; // 获得Cipher实例,使用CBC模式。 Cipher decrypt = Cipher.getInstance("TripleDES/CBC/PKCS5Padding"); // 初始化加密实例,定义为解密功能,并传入密钥,偏转向量 decrypt.init(Cipher.DECRYPT_MODE, deskey, ivParam); cipherByte = decrypt.doFinal(sourceBuf, 0, sourceBuf.length); // 返回解密后的字节数组 return cipherByte; } /** * <li> * 方法名称:DES_CBC_Encrypt</li> <li> * 功能描述: * * <pre> * 经过封装的DES/CBC加密算法,如果包含中文,请注意编码。 * </pre> * * </li> * * @param sourceBuf * 需要加密内容的字节数组。 * @param deskey * KEY 由8位字节数组通过SecretKeySpec类转换而成。 * @param ivParam * IV偏转向量,由8位字节数组通过IvParameterSpec类转换而成。 * @return 加密后的字节数组 * @throws Exception */ public static byte[] DES_CBC_Encrypt(byte[] sourceBuf, SecretKeySpec deskey, IvParameterSpec ivParam) throws Exception { byte[] cipherByte; // 使用DES对称加密算法的CBC模式加密 Cipher encrypt = Cipher.getInstance("DES/CBC/PKCS5Padding"); encrypt.init(Cipher.ENCRYPT_MODE, deskey, ivParam); cipherByte = encrypt.doFinal(sourceBuf, 0, sourceBuf.length); // 返回加密后的字节数组 return cipherByte; } /** * <li> * 方法名称:DES_CBC_Decrypt</li> <li> * 功能描述: * * <pre> * 经过封装的DES/CBC解密算法。 * </pre> * * </li> * * @param sourceBuf * 需要解密内容的字节数组 * @param deskey * KEY 由8位字节数组通过SecretKeySpec类转换而成。 * @param ivParam * IV偏转向量,由6位字节数组通过IvParameterSpec类转换而成。 * @return 解密后的字节数组 * @throws Exception */ public static byte[] DES_CBC_Decrypt(byte[] sourceBuf, SecretKeySpec deskey, IvParameterSpec ivParam) throws Exception { byte[] cipherByte; // 获得Cipher实例,使用CBC模式。 Cipher decrypt = Cipher.getInstance("DES/CBC/PKCS5Padding"); // 初始化加密实例,定义为解密功能,并传入密钥,偏转向量 decrypt.init(Cipher.DECRYPT_MODE, deskey, ivParam); cipherByte = decrypt.doFinal(sourceBuf, 0, sourceBuf.length); // 返回解密后的字节数组 return cipherByte; } /** * <li> * 方法名称:MD5Hash</li> <li> * 功能描述: * * <pre> * MD5,进行了简单的封装,以适用于加,解密字符串的校验。 * </pre> * * </li> * * @param buf * 需要MD5加密字节数组。 * @param offset * 加密数据起始位置。 * @param length * 需要加密的数组长度。 * @return * @throws Exception */ public static byte[] MD5Hash(byte[] buf, int offset, int length) throws Exception { MessageDigest md = MessageDigest.getInstance("MD5"); md.update(buf, offset, length); return md.digest(); } /** * <li> * 方法名称:byte2hex</li> <li> * 功能描述: * * <pre> * 字节数组转换为二行制表示 * </pre> * * </li> * * @param inStr * 需要转换字节数组。 * @return 字节数组的二进制表示。 */ public static String byte2hex(byte[] inStr) { String stmp; StringBuffer out = new StringBuffer(inStr.length * 2); for (int n = 0; n < inStr.length; n++) { // 字节做"与"运算,去除高位置字节 11111111 stmp = Integer.toHexString(inStr[n] & 0xFF); if (stmp.length() == 1) { // 如果是0至F的单位字符串,则添加0 out.append("0" + stmp); } else { out.append(stmp); } } return out.toString(); } /** * <li> * 方法名称:addMD5</li> <li> * 功能描述: * * <pre> * MD校验码 组合方法,前16位放MD5Hash码。 把MD5验证码byte[],加密内容byte[]组合的方法。 * </pre> * * </li> * * @param md5Byte * 加密内容的MD5Hash字节数组。 * @param bodyByte * 加密内容字节数组 * @return 组合后的字节数组,比加密内容长16个字节。 */ public static byte[] addMD5(byte[] md5Byte, byte[] bodyByte) { int length = bodyByte.length + md5Byte.length; byte[] resutlByte = new byte[length]; // 前16位放MD5Hash码 for (int i = 0; i < length; i++) { if (i < md5Byte.length) { resutlByte[i] = md5Byte[i]; } else { resutlByte[i] = bodyByte[i - md5Byte.length]; } } return resutlByte; } /** * <li> * 方法名称:getKeyIV</li> <li> * 功能描述: * * <pre> * * </pre> * </li> * * @param encryptKey * @param key * @param iv */ public static void getKeyIV(String encryptKey, byte[] key, byte[] iv) { // 密钥Base64解密 BASE64Decoder decoder = new BASE64Decoder(); byte[] buf = null; try { buf = decoder.decodeBuffer(encryptKey); } catch (IOException e) { e.printStackTrace(); } // 前8位为key int i; for (i = 0; i < key.length; i++) { key[i] = buf[i]; } // 后8位为iv向量 for (i = 0; i < iv.length; i++) { iv[i] = buf[i + 8]; } } public static void main(String[] args) throws Exception { System.out.println(encrypt("欧长璐","LmMGStGtOpF4xNyvYt54EQ==")); System.err.println(decrypt("BYyD3pQ9rYonhg9bbbXp3UzZYMGkgmJt8G9NIg1EZ3I=","LmMGStGtOpF4xNyvYt54EQ==")); } }
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %> <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> <title>Insert title here</title> </head> <body> 值:${ad} </body> </html>
<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:context="http://www.springframework.org/schema/context" xmlns:mvc="http://www.springframework.org/schema/mvc" xsi:schemaLocation="http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-4.1.xsd http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.1.xsd"> <bean id="stringConverter" class="org.springframework.http.converter.StringHttpMessageConverter"> <property name="supportedMediaTypes"> <list> <value>text/plain;charset=UTF-8</value> </list> </property> </bean> <bean id="jsonConverter" class="org.springframework.http.converter.json.MappingJackson2HttpMessageConverter"></bean> <bean class="org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter"> <property name="messageConverters"> <list> <ref bean="stringConverter" /> <ref bean="jsonConverter" /> </list> </property> </bean> <!-- 1.springMVC上传文件时,需要配置CommonsMultipartResolver处理器 --> <bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver"> <!-- 设置默认的编码格式 --> <property name="defaultEncoding" value="UTF-8" /> <property name="maxInMemorySize" value="10240" /> <!-- 最大内存大小 (10240) --> <property name="uploadTempDir" value="/upload/" /> <!-- 上传后的目录名 (WebUtils#TEMP_DIR_CONTEXT_ATTRIBUTE) --> <!-- 指定所上传文件的总的大小不能超过200kb, 注意maxUploadSize属性点 限制 不是针对单个文件, 而是所有文件的容量总和 --> <property name="maxUploadSize" value="-1" /><!-- 最大文件大小,-1为无限止(-1) --> </bean> <!-- 2.springMVC在超出上传文件限制时,会抛出 org.springframework.web.multipart.MaxUploadSizeExceededException 该异常时SpringMVC在检查上传文件信息时抛出来的,而且此时还没有进入到Controller方法中 --> <bean id="exceptionResolver" class="org.springframework.web.servlet.handler.SimpleMappingExceptionResolver"> <property name="exceptionMappings"> <props> <!-- 在遇到MaxUploadSizeExceededException异常时,自动跳到xxx面 --> <prop key="org.springframework.web.multipart.MaxUploadSizeExceededException">error.jsp</prop> </props> </property> </bean> <context:component-scan base-package="com.zhouwuji.controller"></context:component-scan> </beans>
<?xml version="1.0" encoding="UTF-8"?> <web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" id="WebApp_ID" version="2.5"> <filter> <filter-name>encoding</filter-name> <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class> <init-param> <param-name>encoding</param-name> <param-value>UTF-8</param-value> </init-param> </filter> <filter-mapping> <filter-name>encoding</filter-name> <url-pattern>/*</url-pattern> </filter-mapping> <servlet> <servlet-name>springmvc</servlet-name> <servlet-class> org.springframework.web.servlet.DispatcherServlet </servlet-class> <load-on-startup>1</load-on-startup> </servlet> <servlet-mapping> <servlet-name>springmvc</servlet-name> <url-pattern>*.do</url-pattern> </servlet-mapping> <welcome-file-list> <welcome-file>index.jsp</welcome-file> </welcome-file-list> </web-app>
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%> <% String path = request.getContextPath(); String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/"; %> <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html> <head> <base href="<%=basePath%>"> <title>My JSP \'index.jsp\' starting page</title> <meta http-equiv="pragma" content="no-cache"> <meta http-equiv="cache-control" content="no-cache"> <meta http-equiv="expires" content="0"> <meta http-equiv="keywords" content="keyword1,keyword2,keyword3"> <meta http-equiv="description" content="This is my page"> <!-- <link rel="stylesheet" type="text/css" href="styles.css"> --> </head> <body> 文件上传异以上是关于java框架--springmvc --ajax-json-upload+maven的主要内容,如果未能解决你的问题,请参考以下文章
java框架--springmvc --ajax-json-upload+maven