java+js上传图片_java+ jsp+js 实现富文本编辑和上传图片功能
class FileManageActionController extends BaseAction
{
// windows
private String PATH_LINEs = "\\";
// linux
private String PATH_LINE = "/";
/**
* 文件上传
* @param request {@link HttpServletRequest}
* @param response {@link HttpServletResponse}
* @return json response
*/
@SuppressWarnings("unchecked")
@RequestMapping(value = "/fileUpload", method = RequestMethod.POST)
@ResponseBody
public void fileUpload(HttpServletRequest request, HttpServletResponse response,@RequestParam(value = "imgFile", required = false) MultipartFile[] imgFile ) {
try {
response.setCharacterEncoding("utf-8");
PrintWriter out = response.getWriter();
//文件保存本地目录路径
String savePath = MapCacheManager.getInstance().getMapCache().get("serverPathUp");
String serverPicPath = savePath + "/" + "pic"+ "/";
//文件保存目录URL
String saveUrls =MapCacheManager.getInstance().getMapCache().get("serverPaths");
String saveUrlPath = saveUrls + "/" + "upload"+ "/";
if(!ServletFileUpload.isMultipartContent(request)){
out.print(getError("请选择文件。"));
out.close();
return;
}
//检查目录
File uploadDir = new File(serverPicPath);
if(!uploadDir.isDirectory()){
out.print(getError("上传目录不存在。"));
out.close();
return;
}
//检查目录写权限
if(!uploadDir.canWrite()){
out.print(getError("上传目录没有写权限。"));
out.close();
return;
}
String dirName = request.getParameter("dir");
if (dirName == null) {
dirName = "image";
}
//定义允许上传的文件扩展名
Map extMap = new HashMap();
extMap.put("image", "gif,jpg,jpeg,png,bmp");
extMap.put("flash", "swf,flv");
extMap.put("media", "swf,flv,mp3,wav,wma,wmv,mid,avi,mpg,asf,rm,rmvb");
extMap.put("file", "doc,docx,xls,xlsx,ppt,htm,html,xml,txt,zip,rar,gz,bz2");
if(!extMap.containsKey(dirName)){
out.print(getError("目录名不正确。"));
out.close();
return;
}
//创建文件夹
serverPicPath += dirName + PATH_LINE;
saveUrlPath+= dirName + PATH_LINE;
File saveDirFile = new File(serverPicPath);
if (!saveDirFile.exists()) {
saveDirFile.mkdirs();
}
SimpleDateFormat sdf = new SimpleDateFormat("yyyyMMdd");
String ymd = sdf.format(new Date());
serverPicPath += ymd + PATH_LINE;
saveUrlPath += ymd + PATH_LINE;
File dirFile = new File(serverPicPath);
if (!dirFile.exists()) {
dirFile.mkdirs();
}
//最大文件大小
long maxSize = 1000000;
// 保存文件
for(MultipartFile iFile : imgFile){
String fileName = iFile.getOriginalFilename();
//检查文件大小
if(iFile.getSize() > maxSize){
out.print(getError("上传文件大小超过限制。"));
out.close();
return;
}
//检查扩展名
String fileExt = fileName.substring(fileName.lastIndexOf(".") + 1).toLowerCase();
if(!Arrays.asList(extMap.get(dirName).split(",")).contains(fileExt)){
out.print(getError("上传文件扩展名是不允许的扩展名。\n只允许" + extMap.get(dirName) + "格式。"));
out.close();
return;
}
SimpleDateFormat df = new SimpleDateFormat("yyyyMMddHHmmss");
String newFileName = df.format(new Date()) + "_" + new Random().nextInt(1000) + "." + fileExt;
try{
File uploadedFile = new File(serverPicPath, newFileName);
}catch(Exception e){
out.print(getError("上传文件失败。"));
out.close();
return;
}
System.out.println(saveUrlPath+newFileName);
JSONObject obj = new JSONObject();
obj.put("error", 0);
obj.put("url", saveUrlPath + newFileName);
System.out.println(newFileName+"上传的图片");
out.print(obj.toJSONString());
out.close();
}
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
private Map getError(String errorMsg) {
Map errorMap = new HashMap();
errorMap.put("error", 1);
errorMap.put("message", errorMsg);
return errorMap;
}
}
java+js上传图片_java+ jsp+js 实现富文本编辑和上传图片功能相关推荐
- java+ jsp+js 实现富文本编辑和上传图片功能
java+ jsp+js 实现富文本编辑和上传图片功能 使用kindeditor富文本插件: - kindeditor富文本官网地址 详细的文档和demo都有 下面是实现步骤: -导入项目中相关的文件 ...
- 百度ueditor新增的将word内容导入到富文本编辑框的功能.
如何做到 ueditor批量上传word图片? 1.前端引用代码 <!DOCTYPEhtmlPUBLIC"-//W3C//DTD XHTML 1.0 Transitional//EN& ...
- vue 使用quill富文本编辑 增加表格功能
先看结果: 必要条件: 1.需要quill版本为2.0的开发版(发布正式版只有1.0的) 使用npm view quill查看版本,最新的dev版本为dev.4,官方文档好像是说按得dev.3 我直接 ...
- java js方法_JAVA调用js方法
JS如下: function add(a,b){ return a + b + number; } JAVA代码如下: package com.cgnb.dataqualitymng; import ...
- java 防止js注入_java 防止JS注入(使用ESAPI进行编码)
今天在做报表导入的时候遇到测试在excel数据里面填了一段js代码,导致数据回显到页面的时候弹一个框出来,这个框我想大家都懂了,又恰好逢项目在做代码安全扫描, 扫描工具使用的是Fortify 安全工具 ...
- java批量上传图片_JAVA图片批量上传JS-带预览功能
这篇文章就简单的介绍一个很好用的文件上传工具,批量带预览功能.直接贴代码吧,都有注释,很好理解. HTML页面 pageEncoding="UTF-8"%> 新增照片 var ...
- java 登录验证码_java jsp实现登录验证码
java jsp实现登录验证码 工作中使用的java jsp实现的登录验证码.代码记录如下: 1.登录主页面(login.jsp) pageEncoding="UTF-8"%> ...
- 关于kindeditor富文本编辑的上传图片、音频、和视频的使用
版本:KindEditor 4.x 官方文档:http://kindeditor.net/doc.php 最近在公司实现一个功能: 大概就是这样: 富文本编辑器的上传图片.音频和视频的原理,就是将这 ...
- java 文本查找_Java基于正则表达式实现查找匹配的文本功能【经典实例】
本文实例讲述了Java基于正则表达式实现查找匹配的文本功能.分享给大家供大家参考,具体如下: REMatch.java: package reMatch; import java.util.regex ...
最新文章
- 学习完Ajax的总结
- 腾讯终于良心了!桌面混乱终于有救了
- 持续集成之路——Maven
- 8.6M超轻量中英文OCR模型开源,训练部署一条龙 | Demo在线可玩
- python写入数据到excel中_Python写入数据到Excel
- (Mybatis)XML配置解析
- jps显示当前所有java进程pid
- UVa 816 (BFS求最短路)
- 基于Memcached的Nginx服务器集群session共享
- vuecli3 配置多个代理
- eureka服务注册中心集群模式创建
- 分享一些自用软件,学妹们用了都说好用!
- css 垂直居中_当面试官问起CSS布局之水平垂直居中时~~
- Ubuntu安装gcc-7.3.0
- 数学建模——01规划 / 线性规划 (工具:matlab + lingo,算法:Folyd)
- libcrypto yum 安装_centos7下nginx 报错需要安装 libcrypto.so.10(OPENSSL_1.0.2)(64bit)
- Wind Python案例
- Spring Boot整合Shiro + Springboot +vue
- 【PyTorch教程】P27、28、29 完整的模型套路
- 想想也有五年多了(胡紫薇博客)
热门文章
- 5-flutter 布局和列表
- LightOJ 1364 Expected Cards(概率+DP)
- Extjs 基础篇—— Function基础
- python_day16_pythom-mysql-API
- The system cannot find the file specified
- [QA]Python字节码优化问题
- 软件包管理 之 软件在线升级更新yum 图形工具介绍
- Vagrant控制管理器——“Hobo”
- ROS 用 roboware实现节点信息发送和接收
- node 模块化 require expores,简易实现原理。