Fckeditor和JSP(Java)项目的整合实例

本文介绍如何在Java Web项目中集成FCKeditor富文本编辑器,包括必要的文件复制、配置步骤及注意事项。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

(转载标签:fckeditorit 分类:Java)

1.将FCKeditor目录下的editor拷贝到项目的WebContent目录下
2.并把ECKeditor-2.3.jar 和 commons-fileupload.jar拷贝到项目/WebContent/WEB-INF/lib目录下
3.把 FCKeditor.tld拷贝到项目/WebContent/WEB-INF下
4.在web.xml里添加如下代码


代码
<servlet>    
  
        <servlet-name>Connector</servlet-name>    
  
        <servlet-class>com.fredck.FCKeditor.connector.ConnectorServlet</servlet-class>    
  
        <init-param>    
  
            <param-name>baseDir</param-name>    
  
            <!-- 此为文件浏览路径 -->    
  
            <param-value>/UserFiles/</param-value>    
  
        </init-param>    
  
        <init-param>    
  
            <param-name>debug</param-name>    
  
            <param-value>true</param-value>    
  
        </init-param>    
  
        <load-on-startup>1</load-on-startup>    
  
    </servlet>    
  
     
  
    <servlet>    
  
        <servlet-name>SimpleUploader</servlet-name>    
  
        <servlet-class>com.fredck.FCKeditor.uploader.SimpleUploaderServlet</servlet-class>    
  
        <init-param>    
  
            <param-name>baseDir</param-name>    
  
            <!-- 此为文件上传路径,需要在WebRoot 目录下新建 UserFiles 文件夹 -->    
  
            <!-- 根据文件的类型还需要新建相关的文件夹 Image、 Flash -->    
  
            <param-value>/UserFiles/</param-value>    
  
        </init-param>    
  
        <init-param>    
  
            <param-name>debug</param-name>    
  
            <param-value>true</param-value>    
  
        </init-param>    
  
        <init-param>    
  
            <!-- 此参数为是否开启上传功能 -->    
  
            <param-name>enabled</param-name>    
  
            <param-value>true</param-value>    
  
        </init-param>    
  
        <init-param>    
  
            <param-name>AllowedExtensionsFile</param-name>    
  
            <param-value></param-value>    
  
        </init-param>    
  
        <init-param>    
  
            <!-- 此参数为文件过滤,以下的文件类型都不可以上传 -->    
  
            <param-name>DeniedExtensionsFile</param-name>    
  
            <param-value>php|php3|php5|phtml|asp|aspx|ascx|jsp|cfm|cfc|pl|bat|exe|dll|reg|cgi</param-value>    
  
        </init-param>    
  
        <init-param>    
  
            <param-name>AllowedExtensionsImage</param-name>    
  
            <param-value>jpg|gif|jpeg|png|bmp</param-value>    
  
        </init-param>    
  
        <init-param>    
  
            <param-name>DeniedExtensionsImage</param-name>    
  
            <param-value></param-value>    
  
        </init-param>    
  
        <init-param>    
  
            <param-name>AllowedExtensionsFlash</param-name>    
  
            <param-value>swf|fla</param-value>    
  
        </init-param>    
  
        <init-param>    
  
            <param-name>DeniedExtensionsFlash</param-name>    
  
            <param-value></param-value>    
  
        </init-param>    
  
        <load-on-startup>1</load-on-startup>    
  
    </servlet>    
  
     
  
  <servlet-mapping>    
  
    <servlet-name>Connector</servlet-name>    
  
    <url-pattern>/FCKeditor/editor/filemanager/browser/default/connectors/jsp/connector</url-pattern>    
  
  </servlet-mapping>    
  
     
  
  <servlet-mapping>    
  
    <servlet-name>SimpleUploader</servlet-name>    
  
    <url-pattern>/FCKeditor/editor/filemanager/upload/simpleuploader</url-pattern>    
  
  </servlet-mapping>    
在页面中使用先导入<%@ taglib uri="/tags/FCKeditor" prefix="FCK"%>当然这前提是你得在web.xml中配置<taglib>
  <taglib-uri>/tags/FCKeditor</taglib-uri>
  <taglib-location>/WEB-INF/tld/FCKeditor.tld</taglib-location>
 </taglib>

并保证/WEB-INF/tld/FCKeditor.tld存在。

然后<FCK:editor id="content" toolbarSet="Default" > </FCK:editor>

其中id指定当前这个字段的名称,工具栏设置默认只能是Default,Basic,UserSet而且首字母必须大写。这两个的具体配置在fck里面,用户可以自己定义自己的工具栏在fckconfig.js中配置。

在项目目录下建立文件夹UserFiles/Image,UserFiles/Flash,UserFiles/File,这三个目录表示文件上传后的位置,如果文件夹不存在会出现security error
FCKeditor目录精简说明:
1. 根目录下的文件只留下fckconfig.js, fckeditor.js, fckstyles.xml, fcktemplates.xml四个文件
2. 删除所有的以_开头的文件和文件夹
3. 删除FCKeditor/editor/filemanager/upload目录下的所有文件
4. 删除FCKeditor/editor/filemanager/browser/default/connectors目录下的所有文件
5. 删除FCKeditor/editor/_source目录

彻底解决fckeditor(jsp)上传中文图片乱码问题,我这里用的编码是utf-8的,这里用的fckeditor 是2.6的,fckeditor.java包是2.3的,经过我修改ConnectorServlet.javaSimpleUploaderServlet.java两个文件,重新生成fckeditor-java-2.3.jar包, 要解决所有的乱码问题,有3部要修改, 1.修改Web容器的字符编码,如果Web容器用的是Tomcat,则修改conf/server.xml文件,在两个Connector中添加“URIEncoding="utf-8"”,我这里用的是utf-8编码,所以修改成utf-8,若项目是gb2312编码,则设置为“URIEncoding="gb2312"”。 2.在“浏览服务器”页面中上传文件时,打开项目WebRoot中的文件/editor/filemanager/browser/default/frmupload.html,在head中加一个meta: <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />,看看该文件是不是utf-8格式的,若不是,则转换成utf-8,若你用的不是utf-8则转成你用的那种编码,上面charset也设置成你用的编码 3.修改ConnectorServlet.javaSimpleUploaderServlet.java两个文件,我在这两个文件中都是加了一个静态变量encoding,private static String encoding;保存项目中的编码, 若在web.xml文件中没有给这个变量传值的话,默认是gb2312,如下代码if(encoding.isEmpty()){encoding="gb2312";},在ConnectorServlet.java的doGet与doPost的开头部分加入request.setCharacterEncoding(encoding);将请求的字符集编码设置成项目中的编码,在ConnectorServlet.javaSimpleUploaderServlet.java两个文件中的DiskFileUpload upload = new DiskFileUpload();后面加入upload.setHeaderEncoding(encoding);告诉FileUpload组件处理时的编码为项目编码,在FileItem中,用getString(encoding),这项设置可以解决获取的表单字段为乱码的问题,所以在每个FileItem实例后面都执行一次getString(encoding),就告诉FileItem在取值时用的编码是encoding所设置的编码。如在ConnectorServlet.javaSimpleUploaderServlet.java两个文件中的 FileItem item后面加上一句item.getString(encoding);在FileItem uplFile后面加上一句uplFile.getString(encoding); 接下来就是设置web.xml了,在web.xml中给上面讲到的encoding传值,如下 <init-param> <param-name>encoding</param-name> <param-value>utf-8</param-value> </init-param> 一切都OK了,真正的解决了上传中文名图片乱码问题。 在上面的第3步中,要用到Ant产生jar,这时要注意, 把Tomcat安装目录下/server/lib里的catalina-ant.jar复制到项目的/WEB-INF/lib下。打开build.xml,修改property name="catalina.home"成Tomcat的安装目录。修改taskdef name="deploy"、taskdef name="list"、taskdef name="reload"、taskdef name="undeploy"如下: <taskdef name="deploy" classname="org.apache.catalina.ant.DeployTask"> <classpath refid="compile.classpath"></classpath> </taskdef> <taskdef name="list" classname="org.apache.catalina.ant.ListTask"> <classpath refid="compile.classpath"></classpath> </taskdef> <taskdef name="reload" classname="org.apache.catalina.ant.ReloadTask"> <classpath refid="compile.classpath"></classpath> </taskdef> <taskdef name="undeploy" classname="org.apache.catalina.ant.UndeployTask"> <classpath refid="compile.classpath"></classpath> </taskdef> 然后在Eclipse的Outline窗口中运行Ant的dist,就会生成的新的FCKeditor-2.3.jar。 绝对是真实的,共享出来与大家分享,少一个上传其它文件的,如RAR的,有添加过这个功能的朋友也拿出来共享下吧
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值