项目中采用的是kindeditor3.4
UploadContentImgAction
@SuppressWarnings("serial")
@ParentPackage("control-center")
public class UploadContentImgAction extends BaseAction {
private File up;
private String upFileName;
private String upContentType;
private String fileDir = "uploads/articleContentImg";
private String imgTitle;
private String align;
private int imgWidth;
private int imgHeight;
/**
* kindeditor图片上传
* @return
* @throws Exception
*/
@Action("kindeditorImgUpload")
public String kindeditorImgUpload() throws Exception {
//只能传图片
try {
if(!validatePostfix(upFileName)) {
return "error";
}
User user = (User)getSession().get("user");
String fileRealDir = getServletContext().getRealPath(fileDir);
File file = up;
String fileRealName = createfilename(user.getUserId());
String fileName = fileRealName + upFileName.substring(upFileName.lastIndexOf(".")).toLowerCase();
File newFile = new File(fileRealDir, fileName);
FileUtils.copyFile(file, newFile);
//压缩图片
ImageUtil.resize(newFile.getPath(), newFile.getPath(), 500);
String id = "contentId";
String url = "/" + fileDir + "/" + fileName;
String border = "0";
String result = "<script type='text/javascript'>parent.KE.plugin['image'].insert('" + id + "','" + url + "','" + imgTitle + "','" + imgHeight + "','" + imgHeight + "','" + border + "','" + align + "');</script>";
getHttpServletResponse().getWriter().write(result);
} catch (RuntimeException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return null;
}
/**
* 生成文件名 : 当前时间 + 随机数 + 用户id
*/
private String createfilename(int userId) {
StringBuilder result = new StringBuilder();
// 得到 本地的 当前时间
String now = DateUtil.getLongStrFromDate(new Date());
// 在 1000W 内随机生成一个数字
int rand = new Random().nextInt(9999999);
// 去掉 - 去掉 : 去掉 空格 后,返回
result.append(now.replace("-", "").replace(":", "").replace(" ", "")).append("_").append(rand).append("_").append(userId);
return result.toString();
}
/**
* 验证后缀名 应该从配置文件中获取
*/
public boolean validatePostfix(String filename) {
// 定义可上传文件的 类型
List<String> fileTypes = new ArrayList<String>();
// 图片
fileTypes.add("jpg");
fileTypes.add("jpeg");
fileTypes.add("bmp");
fileTypes.add("gif");
fileTypes.add("png");
// 得到文件尾数 并 进行小写转换
String postfix = filename.substring(filename.lastIndexOf(".") + 1).toLowerCase();
return fileTypes.contains(postfix) ? true : false;
}
public File getUp() {
return up;
}
public void setUp(File up) {
this.up = up;
}
public String getUpFileName() {
return upFileName;
}
public void setUpFileName(String upFileName) {
this.upFileName = upFileName;
}
public String getUpContentType() {
return upContentType;
}
public void setUpContentType(String upContentType) {
this.upContentType = upContentType;
}
public String getImgTitle() {
return imgTitle;
}
public void setImgTitle(String imgTitle) {
this.imgTitle = imgTitle;
}
public int getImgWidth() {
return imgWidth;
}
public void setImgWidth(int imgWidth) {
this.imgWidth = imgWidth;
}
public int getImgHeight() {
return imgHeight;
}
public void setImgHeight(int imgHeight) {
this.imgHeight = imgHeight;
}
public String getAlign() {
return align;
}
public void setAlign(String align) {
this.align = align;
}
}
ImageUitl
package com.yancheng.myframe.util;
import java.awt.AlphaComposite;
import java.awt.Color;
import java.awt.Font;
import java.awt.Graphics2D;
import java.awt.Image;
import java.awt.geom.AffineTransform;
import java.awt.image.AffineTransformOp;
import java.awt.image.BufferedImage;
import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;
import javax.imageio.ImageIO;
import magick.ImageInfo;
import magick.MagickImage;
import com.sun.image.codec.jpeg.JPEGCodec;
import com.sun.image.codec.jpeg.JPEGImageEncoder;
/**
* @author
*
*/
public class ImageUtil {
public final static int PHOTO_RATIO = 800; //缩放图片系数
static{
System.setProperty("jmagick.systemclassloader", "no");
}
/**
* 图片水印
*
* @param pressImg 水印图片
* @param targetImg 目标图片
* @param x 修正值 默认在中间
* @param y 修正值 默认在中间
* @param alpha 透明度
*/
public final static void pressImage(String pressImg, String targetImg,
int x, int y, float alpha) {
try {
File img = new File(targetImg);
Image src = ImageIO.read(img);
int wideth = src.getWidth(null);
int height = src.getHeight(null);
BufferedImage image = new BufferedImage(wideth, height,
BufferedImage.TYPE_INT_RGB);
Graphics2D g = image.createGraphics();
g.drawImage(src, 0, 0, wideth, height, null);
// 水印文件
Image src_biao = ImageIO.read(new File(pressImg));
int wideth_biao = src_biao.getWidth(null);
int height_biao = src_biao.getHeight(null);
g.setComposite(AlphaComposite.getInstance(AlphaComposite.SRC_ATOP,
alpha));
g.drawImage(src_biao, (wideth - wideth_biao) / 2,
(height - height_biao) / 2, wideth_biao, height_biao, null);
// 水印文件结束
g.dispose();
ImageIO.write((BufferedImage) image, "jpg", img);
} catch (Exception e) {
e.printStackTrace();
}
}
/**
* 文字水印
*
* @param pressText 水印文字
* @param targetImg 目标图片
* @param fontName 字体名称
* @param fontStyle 字体样式
* @param color 字体颜色
* @param fontSize 字体大小
* @param x 修正值
* @param y 修正值
* @param alpha 透明度
*/
public static void pressText(String pressText, String targetImg, String fontName, int fontStyle, Color color, int fontSize, int x,
int y, float alpha) {
try {
File img = new File(targetImg);
Image src = ImageIO.read(img);
int width = src.getWidth(null);
int height = src.getHeight(null);
BufferedImage image = new BufferedImage(width, height, BufferedImage.TYPE_INT_RGB);
Graphics2D g = image.createGraphics();
g.drawImage(src, 0, 0, width, height, null);
g.setColor(color);
g.setFont(new Font(fontName, fontStyle, fontSize));
g.setComposite(AlphaComposite.getInstance(AlphaComposite.SRC_ATOP, alpha));
g.drawString(pressText, (width - (getLength(pressText) * fontSize)) / 2 + x, (height - fontSize) / 2 + y);
g.dispose();
ImageIO.write((BufferedImage) image, "jpg", img);
} catch (Exception e) {
e.printStackTrace();
}
}
/**
* 缩放 效果太差 ps: Graphics下的 还有 AffineTransform下的
* 缩放都是针对"图形"而不是"图像"的,所以处理后图片很不清晰
* @param filePath 图片路径
* @param height 高度
* @param width 宽度
* @param bb 比例不对时是否需要补白
*/
public static void resizeImgcale(String filePath, int height, int width, boolean bb) {
try {
double ratio = 0.0; // 缩放比例
File f = new File(filePath);
BufferedImage bi = ImageIO.read(f);
Image itemp = bi.getScaledInstance(width, height, bi.SCALE_SMOOTH);
// 计算比例
if ((bi.getHeight() > height) || (bi.getWidth() > width)) {
if (bi.getHeight() > bi.getWidth()) {
ratio = (new Integer(height)).doubleValue() / bi.getHeight();
} else {
ratio = (new Integer(width)).doubleValue() / bi.getWidth();
}
AffineTransformOp op = new AffineTransformOp(AffineTransform.getScaleInstance(ratio, ratio), null);
itemp = op.filter(bi, null);
}
if (bb) {
BufferedImage image = new BufferedImage(width, height, BufferedImage.TYPE_INT_RGB);
Graphics2D g = image.createGraphics();
g.setColor(Color.white);
g.fillRect(0, 0, width, height);
if (width == itemp.getWidth(null))
g.drawImage(itemp, 0, (height - itemp.getHeight(null)) / 2,
itemp.getWidth(null), itemp.getHeight(null),
Color.white, null);
else
g.drawImage(itemp, (width - itemp.getWidth(null)) / 2, 0,
itemp.getWidth(null), itemp.getHeight(null),
Color.white, null);
g.dispose();
itemp = image;
}
ImageIO.write((BufferedImage) itemp, "jpg", f);
} catch (IOException e) {
e.printStackTrace();
}
}
/**
* 计算字的长度
*
* @param text
* @return
*/
public static int getLength(String text) {
int length = 0;
for (int i = 0; i < text.length(); i++) {
if (new String(text.charAt(i) + "").getBytes().length > 1) {
length += 2;
} else {
length += 1;
}
}
return length / 2;
}
/**
* 压缩图片
*
* @param imgsrc 源文件
* @param imgdist 目标文件
* @param widthdist 宽
* @param heightdist 高
*/
public static void resizeImg(String imgsrc, String imgdist, int widthdist, int heightdist) {
try {
File srcfile = new File(imgsrc);
if (!srcfile.exists()) {
return;
}
Image src = javax.imageio.ImageIO.read(srcfile);
BufferedImage tag = new BufferedImage(widthdist, heightdist, BufferedImage.TYPE_INT_RGB);
/*
* SCALE_SMOOTH:尺寸平滑 SCALE_AREA_AVERAGING:尺度区平均 SCALE_FAST:尺度快速
* SCALE_REPLICATE:尺度复制
*/
tag.getGraphics().drawImage(src.getScaledInstance(widthdist, heightdist, Image.SCALE_SMOOTH), 0, 0, null);
FileOutputStream out = new FileOutputStream(imgdist);
JPEGImageEncoder encoder = JPEGCodec.createJPEGEncoder(out);
encoder.encode(tag);
out.close();
} catch (IOException ex) {
ex.printStackTrace();
}
}
/**
* 图片压缩
* @param picFrom
* @param picTo
* @param widthdist
* @param heightdist
*/
public static void resize(String picFrom, String picTo, int widthdist, int heightdist) {
try {
ImageInfo info = new ImageInfo(picFrom);
MagickImage image = new MagickImage(new ImageInfo(picFrom));
MagickImage scaled = image.scaleImage(widthdist, heightdist);// 小图片文件的大小.
scaled.setFileName(picTo);
scaled.writeImage(info);
} catch (Exception ex) {
ex.printStackTrace();
}
}
public static void resize(String picFrom, String picTo, int ratio) throws Exception {
BufferedImage bi = ImageIO.read(new File(picFrom));
//原始图片属性
int srcWidth = bi.getWidth();
int srcHeight = bi.getHeight();
//生成图片属性
int newWidth = srcWidth;
int newHeight = srcHeight;
//如果超出最大宽或高就压缩
if (srcWidth > ratio || newHeight > ratio) {
//生成图片width, height计算
if (srcWidth >= srcHeight) {
if (srcWidth < ratio) {
return;
}
newWidth = ratio;
newHeight = (int)(ratio * srcHeight / srcWidth);
} else {
if (srcHeight < ratio) {
return;
}
newHeight = ratio;
newWidth = (int)(ratio * srcWidth / srcHeight);
}
}
resize(picFrom, picTo, newWidth, newHeight);
}
public static void resize(String picFrom, String picTo) throws Exception {
resize(picFrom, picTo, PHOTO_RATIO);
}
public static void main(String[] args) throws Exception {
// resizeImg("d:/411766.jpg", "d:/411766_1.jpg", 800, 600);
// resize("d:/test_4.jpg", "d:/test_4_2.jpg", 800);
pressText("欢喜冤家", "d:/411766.jpg", "简体", Font.ITALIC, Color.black, 90, 40, 80, 0.5f);
}
}
分享到:
相关推荐
6. **保存压缩图片**:将缩放后的图像数据保存为新的文件,通常会降低图片质量以减小文件大小。 7. **返回结果**:在服务器端脚本中,将新图片的URL作为响应返回给KindEditor,编辑器会将其插入到文档中。 此外,还...
在这个“kindeditor(带压缩图片功能)”的压缩包中,很可能包含了已经集成图片压缩功能的KindEditor源码或者插件。 在Web开发中,富文本编辑器是非常常见的一种组件,用于让用户在网页上像在桌面应用中那样编辑文本...
2. **接收上传图片**:在KindEditor中,用户上传图片时会触发服务器端的事件。你需要创建一个处理POST请求的控制器方法,接收上传的图片文件。通常,文件会被作为Multipart/form-data的Part提交,需要解析请求以获取...
3. **使用说明**:集成后的Struts2版KindEditor应提供详细的使用指南,包括如何在Action类中接收编辑器提交的内容、如何配置Struts2的配置文件以支持动态生成的textarea,以及如何在JSP页面中正确引入和初始化...
vue 使用kindeditor粘贴复制图片上传给自己服务器,单独图片上传,避免用户到处寻找,解决了用户粘贴复制截图时候,图片变成base64,上传给后台的时候长度过于长,所以在粘贴的时候就上传给服务器,最后以形式显示在富...
Struts2Image可能包含对图像上传、预览、裁剪、缩放等功能的支持,帮助开发者在Struts2应用中实现复杂的图片处理需求。 **KindEditor** KindEditor是一款开源的富文本编辑器,广泛用于网站内容编辑和管理。它提供了...
在本文中,我们将详细探讨如何将KindEditor与Struts2整合,实现图片上传功能,并使用Bootstrap来优化页面展示。 首先,我们需要下载KindEditor的中文版本,如提供的`kindeditor-4.1.10-zh-CN.zip`文件。解压后,...
在“kindeditor上传视频、图片功能实现”中,我们将探讨如何利用KindEditor与Java后端配合,实现在网页上进行图片和视频的上传功能。 1. **KindEditor的图片上传功能**: KindEditor内建了图片上传的功能,用户...
这包括如何在项目中引用KindEditor库,如何配置编辑器设置,以及如何实现图片上传和压缩的代码示例。 `kindeditor` 文件夹很可能包含了编辑器的所有核心文件,如JavaScript、CSS样式表、语言包以及可能的插件。...
2. **使用Ajax改造上传**:由于KindEditor默认的上传方式可能不支持自定义token,我们需要自定义上传逻辑。在`beforeUpload`回调函数中,我们可以使用原生的XMLHttpRequest或者现代浏览器的fetch API来发送带有token...
2、复制struts需要的jar包和kindEditor必须jar包到lib下,因为它们的jar包邮重复,选择最新的就ok 3、如果需要后台java代码获取内容,可以在action中定义content属性,getContent就可以获取到 需要注意的是,这里的 ...
在Struts2的配置文件(通常为struts.xml)中,定义一个Action类,处理图片上传和删除的操作。例如: ```xml <param name="contentType">image/jpeg <param name="inputName">fileInputStream ...
在使用Kindeditor与Struts2集成进行图片上传时,开发者可能会遇到以下错误: 1. **文件类型验证失败**:Struts2的默认配置可能不允许上传某些类型的文件,如图片文件。这可能导致“不允许的文件类型”错误。 2. **...
以上就是在.NET MVC中使用KindEditor实现图片上传和查看功能的详细步骤。在实际开发中,可能还需要根据项目需求调整配置,例如自定义上传后处理逻辑,添加文件管理功能等。理解并熟练掌握这些知识点,将有助于提升...
这个"kindeditor上传图片Demo"是一个示例项目,旨在演示如何在KindEditor中集成图片上传功能。在开发过程中,开发者可能会遇到各种问题,比如权限设置、服务器端处理、前端交互等。在这个Demo中,作者可能已经解决了...
Struts2框架与KindEditor-4.1.9在MyEclipse中的集成应用 Struts2作为一款流行的Java Web开发框架,它基于Model-View-Controller(MVC)设计模式,提供了一种组织应用程序结构和控制流程的方式。而KindEditor是一款...
"KindEditor图片批量上传工具"是一款专为网页设计者和内容创作者打造的高效图片上传解决方案。这款工具允许用户在Web界面一次性上传多张图片,极大地提升了工作效率,特别是对于那些需要频繁处理文字和图像,比如...
Kindeditor-v4.0.6 Struts2修订版是一个针对KindEditor编辑器与Struts2框架集成时出现的文件上传问题进行修复的版本。在原版的KindEditor中,当它与Struts2框架整合时,可能会遇到上传功能无法正常工作的情况。这...
在使用kindEditor4.1版本时,我们可能会遇到一个常见的问题:上传的图片无法很好地适配不同大小的屏幕,导致在某些设备上出现拉伸或失真的现象。为了改善用户体验,我们需要实现图片自适应功能,即无论页面如何缩放...
这是本人写的一个基于KindEditor-4.1.9的Java项目,采用Struts2框架,实现了KindEditor单张图片上传、批量图片上传,可以上传到image目录下的子目录中,可返回上一级目录,并实现了按名称、大小、类型排序的功能。...