当前位置: 代码迷 >> JavaScript >> jsp中配备 FCKeditor2.3(转)
  详细解决方案

jsp中配备 FCKeditor2.3(转)

热度:409   发布时间:2013-08-01 15:23:18.0
jsp中配置 FCKeditor2.3(转)

现在已经升级成CKeditor了 不过这方面的教程不是很多,也没啥时间去弄,所以找了以前的文章学习了一下,先记录如下。?

1.下载?
FCKeditor2.3 (FCKeditot for java) 包括了相应的jar文件 源码 以及editor及配置文件?

2.建立项目:?
建立项目FCKeditor_Demo?

3.将FCKeditor2.3解压缩,将整个目录editor复制到项目的Webroot下?
? 将fckconfig.js、fckeditor.js、fckstyles.xml、fcktemplates.xml 文件夹到项目中的 WebRoot 目录?
? 将"web\WEB-INF\lib 下的两个 jar 文件到项目的 WebRoot"WEB-INF"lib 目录?
? 将其中的 "src 下的 FCKeditor.tld 文件到项目的 WebRoot"WEB-INF 目录?
??
4.项目的web.xml修改如下(可从web目录WEB-INF中获取web.xml)?

<!-- FCKeditor配置 --> 
<display-name>FCKeditor</display-name> 
<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> 
/editor/filemanager/browser/default/connectors/jsp/connector 
</url-pattern> 
</servlet-mapping> 
<servlet-mapping> 
<servlet-name>SimpleUploader</servlet-name> 
<url-pattern> 
/editor/filemanager/upload/simpleuploader 
</url-pattern> 
</servlet-mapping> 
<!-- FCKeditor配置 --> 

?(可选)删除无用的文件?
删除无用文件?
删除/FCKeditor/目录下除fckconfig.js, fckeditor.js, fckstyles.xml, fcktemplates.xml四个文件以外的所有文件?
删除目录/editor/_source,?
删除/editor/filemanager/browser/default/connectors/下的所有文件?
删除/editor/filemanager/upload/下的所有文件?
删除/editor/lang/下的除了fcklanguagemanager.js, en.js, zh.js, zh-cn.js四个文件的所有文件?

5.修改配置:?
打开/fckconfig.js?
修改 FCKConfig.DefaultLanguage = 'zh-cn' ;?
把FCKConfig.LinkBrowserURL等的值替换成以下内容:?
FCKConfig.LinkBrowserURL?
= FCKConfig.BasePath + "filemanager/browser/default/browser.html?Connector=connectors/jsp/connector" ;?

FCKConfig.ImageBrowserURL?
= FCKConfig.BasePath + "filemanager/browser/default/browser.html?Type=Image&Connector=connectors/jsp/connector" ;?

FCKConfig.FlashBrowserURL?
= FCKConfig.BasePath + "filemanager/browser/default/browser.html?Type=Flash&Connector=connectors/jsp/connector" ;?

FCKConfig.LinkUploadURL = FCKConfig.BasePath + 'filemanager/upload/simpleuploader?Type=File' ;?
FCKConfig.FlashUploadURL = FCKConfig.BasePath + 'filemanager/upload/simpleuploader?Type=Flash' ;?
FCKConfig.ImageUploadURL = FCKConfig.BasePath + 'filemanager/upload/simpleuploader?Type=Image' ;?

6.其它?
fckconfig.js总配置文件,可用记录本打开,修改后将文件存为utf-8 编码格式。找到:?

FCKConfig.TabSpaces = 0 ; 改为FCKConfig.TabSpaces = 1 ; 即在编辑器域内可以使用Tab键。?

如果你的编辑器还用在网站前台的话,比如说用于留言本或是日记回复时,那就不得不考虑安全了,?
在前台千万不要使用Default的toolbar,要么自定义一下功能,要么就用系统已经定义好的Basic,?
也就是基本的toolbar,找到:?
FCKConfig.ToolbarSets["Basic"] = [?
['Bold','Italic','-','OrderedList','UnorderedList','-',/*'Link',*/'Unlink','-','Style','FontSize','TextColor','BGColor','-',?
'Smiley','SpecialChar','Replace','Preview'] ] ;?
这是改过的Basic,把图像功能去掉,把添加链接功能去掉,因为图像和链接和flash和图像按钮添加功能都能让前台?
页直接访问和上传文件, fckeditor还支持编辑域内的鼠标右键功能。?

FCKConfig.ContextMenu = ['Generic',/*'Link',*/'Anchor',/*'Image',*/'Flash','Select','Textarea','Checkbox','Radio','TextField','HiddenField',?
/*'ImageButton',*/'Button','BulletedList','NumberedList','TableCell','Table','Form'] ;?

这也是改过的把鼠标右键的“链接、图像,FLASH,图像按钮”功能都去掉。?

  找到: FCKConfig.FontNames = 'Arial;Comic Sans MS;Courier New;Tahoma;Times New Roman;Verdana' ;?
加上几种我们常用的字体?
FCKConfig.FontNames?
= '宋体;黑体;隶书;楷体_GB2312;Arial;Comic Sans MS;Courier New;Tahoma;Times New Roman;Verdana' ;?

7.<%--?
三种方法调用FCKeditor?
1.FCKeditor自定义标签 (必须加头文件 <%@ taglib uri="/TestFCKeditor" prefix="FCK" %> )?
2.script脚本语言调用 (必须引用 脚本文件 <script type="text/javascript" src="/TestFCKeditor/FCKeditor/fckeditor.js"></script> )?
3.FCKeditor API 调用 (必须加头文件 <%@ page language="java" import="com.fredck.FCKeditor.*" %> )?
--%>?

//标签调用方式?
<%--?
<form action="show.jsp" method="post" target="_blank">?
<FCK:editor id="content" basePath="/FCKeditor_Demo/"?
width="700"?
height="500"?
skinPath="/FCKeditor_Demo/editor/skins/silver/"?
toolbarSet = "Default"?
>?
input?
</FCK:editor>?
<input type="submit" value="Submit">?
</form>?
--%>?

//JS调用方式?
<form action="show.jsp" method="post" target="_blank">?
<table border="0" width="700"><tr><td>?
<textarea id="content" name="content" style="WIDTH: 100%; HEIGHT: 400px">input</textarea>?
<script type="text/javascript">?
var oFCKeditor = new FCKeditor('content') ;?
oFCKeditor.BasePath = "/FCKeditor_Demo/" ;?
oFCKeditor.Height = 400;?
oFCKeditor.ToolbarSet = "Default" ;?
oFCKeditor.ReplaceTextarea();?
</script>?
<input type="submit" value="Submit">?
</td></tr></table>?
</form>?

//FCKeditor API 调用?
<%--?
<form action="show.jsp" method="post" target="_blank">?
<%?
FCKeditor oFCKeditor ;?
oFCKeditor = new FCKeditor( request, "content" ) ;?
oFCKeditor.setBasePath( "/FCKeditor_Demo/" ) ;?
oFCKeditor.setValue( "input" );?
out.println( oFCKeditor.create() ) ;?
%>?
<br>?
<input type="submit" value="Submit">?
</form>?
--%>?

只测试并成功了script方法~?

8.上传文件的时候是调用FCKeditor.jar中的Servlet 可以将src中的源码拷贝到工程中,方便功能的修改?

9.web.xml中?

?

?

<init-param> 
<param-name>baseDir</param-name> 
<!-- 此为文件浏览路径 --> 
<param-value>/UserFiles/</param-value> 
</init-param> 

?

/UserFiles/为上传文件的路径,需要在WebRoot下添加此目录,并添加Image和Flash目录分别存放图片和flash;不加的话可能会出现权限不够的警告窗口?

10.以下是转载的一些备用信息,此次配置中没碰到问题,所以也没细看~留着以防不时之需吧?

配置选项: 

AutoDetectLanguage=true/false 自动检测语言 
BaseHref="" 相对链接的基地址 
ContentLangDirection="ltr/rtl" 默认文字方向 
ContextMenu=字符串数组,右键菜单的内容 
CustomConfigurationsPath="" 自定义配置文件路径和名称 
Debug=true/false 是否开启调试功能,这样,当调用FCKDebug.Output()时,会在调试窗中输出内容 
DefaultLanguage="" 缺省语言 
EditorAreaCss="" 编辑区的样式表文件 
EnableSourceXHTML=true/false 为TRUE时,当由可视化界面切换到代码页时,把HTML处理成XHTML 
EnableXHTML=true/false 是否允许使用XHTML取代HTML 
FillEmptyBlocks=true/false 使用这个功能,可以将空的块级元素用空格来替代 
FontColors="" 设置显示颜色拾取器时文字颜色列表 
FontFormats="" 设置显示在文字格式列表中的命名 
FontNames="" 字体列表中的字体名 
FontSizes="" 字体大小中的字号列表 
ForcePasteAsPlainText=true/false 强制粘贴为纯文本 
ForceSimpleAmpersand=true/false 是否不把&符号转换为XML实体 
FormatIndentator="" 当在源码格式下缩进代码使用的字符 
FormatOutput=true/false 当输出内容时是否自动格式化代码 
FormatSource=true/false 在切换到代码视图时是否自动格式化代码 
FullPage=true/false 是否允许编辑整个HTML文件,还是仅允许编辑BODY间的内容 
GeckoUseSPAN=true/false 是否允许SPAN标记代替B,I,U标记 
IeSpellDownloadUrl=""下载拼写检查器的网址 
ImageBrowser=true/false 是否允许浏览服务器功能 
ImageBrowserURL="" 浏览服务器时运行的URL 
ImageBrowserWindowHeight="" 图像浏览器窗口高度 
ImageBrowserWindowWidth="" 图像浏览器窗口宽度 
LinkBrowser=true/false 是否允许在插入链接时浏览服务器 
LinkBrowserURL="" 插入链接时浏览服务器的URL 
LinkBrowserWindowHeight=""链接目标浏览器窗口高度 
LinkBrowserWindowWidth=""链接目标浏览器窗口宽度 
Plugins=object 注册插件 
PluginsPath="" 插件文件夹 
ShowBorders=true/false 合并边框 
SkinPath="" 皮肤文件夹位置 
SmileyColumns=12 图符窗列数 
SmileyImages=字符数组 图符窗中图片文件名数组 
SmileyPath="" 图符文件夹路径 
SmileyWindowHeight 图符窗口高度 
SmileyWindowWidth 图符窗口宽度 
SpellChecker="ieSpell/Spellerpages" 设置拼写检查器 
StartupFocus=true/false 开启时FOCUS到编辑器 
StylesXmlPath="" 设置定义CSS样式列表的XML文件的位置 
TabSpaces=4 TAB键产生的空格字符数 
ToolBarCanCollapse=true/false 是否允许展开/折叠工具栏 
ToolbarSets=object 允许使用TOOLBAR集合 
ToolbarStartExpanded=true/false 开启是TOOLBAR是否展开 
UseBROnCarriageReturn=true/false 当回车时是产生BR标记还是P或者DIV标记 
解决上传乱码:在SimpleUploaderServlet.java和ConnectorServlet.java两个文件里找到DiskFileUpload upload = new DiskFileUpload(); 
分别在其后加入 upload.setHeaderEncoding("utf-8");这样解决了文件上传的中文乱码问题.但是在控制台显示的中文内容还是乱码,但是没关系,我们没必要去看控制台下的中文 

500错误: 
          如果你上传时,出现500的错误,试试加上serializer.jar、xalan.jar、commons-fileupload.jar三个包。 
二、根据自己的需求修改: 
       点击上传图片,将图片信息上传到数据库。 
      修改connector/ConnectorServlet.java dopost/doget方法。 
   我用的是post方式提交的: 

public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { 

        if (debug) System.out.println("--- BEGIN DOPOST ---"); 

        response.setContentType("text/html; charset=UTF-8"); 
        response.setHeader("Cache-Control","no-cache"); 
        PrintWriter out = response.getWriter(); 
        
        String commandStr=request.getParameter("Command"); 
        String typeStr=request.getParameter("Type"); 
        String currentFolderStr=request.getParameter("CurrentFolder"); 
        
        String currentPath=baseDir+typeStr+currentFolderStr; 
//        System.out.println(currentPath); 
        String currentDirPath=getServletContext().getRealPath(currentPath); 
        
        if (debug) System.out.println(currentDirPath); 
        
        String retVal="0"; 
        String newName=""; 
        
        if(!commandStr.equals("FileUpload")) 
            retVal="203"; 
        else { 
            DiskFileUpload upload = new DiskFileUpload(); 
            try { 
                List items = upload.parseRequest(request); 
                
                Map fields=new HashMap(); 
                
                Iterator iter = items.iterator(); 
                while (iter.hasNext()) { 
                    FileItem item = (FileItem) iter.next(); 
                    if (item.isFormField()) 
                        fields.put(item.getFieldName(),item.getString()); 
                    else 
                        fields.put(item.getFieldName(),item); 
                } 
                FileItem uplFile=(FileItem)fields.get("NewFile"); 
                String fileNameLong=uplFile.getName(); 
//                System.out.println(fileNameLong); 
                fileNameLong=fileNameLong.replace('\\','/'); 
                String[] pathParts=fileNameLong.split("/"); 
                String fileName=pathParts[pathParts.length-1]; 
//                System.out.println(fileName+"ccccccccccc"); 
                String nameWithoutExt=getNameWithoutExtension(fileName); 
                System.out.println(nameWithoutExt); 
                String ext=getExtension(fileName); 
                System.out.println(ext); 
//            上传图片信息,添加到数据库中 开始 
                List <ImageMessage> imlist=new ArrayList<ImageMessage>(); 
                   ImageMessage img=new ImageMessage(); 
                   img.setImageName(fileName); 
                   img.setImagePaht(currentDirPath); 
                   imlist.add(img); 
                   LinkDatabase link=new LinkDatabase(); 
                   link.insertMessage(imlist); 
            //结束 
                File pathToSave=new File(currentDirPath,fileName); 
                int counter=1; 
                while(pathToSave.exists()){ 
                    newName=nameWithoutExt+"("+counter+")"+"."+ext; 
                    retVal="201"; 
                    pathToSave=new File(currentDirPath,newName); 
                    counter++; 
                    } 
                uplFile.write(pathToSave); 
            }catch (Exception ex) { 
                retVal="203"; 
            } 
            
        } 
        
        out.println("<script type=\"text/javascript\">"); 
        out.println("window.parent.frames['frmUpload'].OnUploadCompleted("+retVal+",'"+newName+"');"); 
        out.println("</script>"); 
        out.flush(); 
        out.close(); 
    
        if (debug) System.out.println("--- END DOPOST ---");    
        
    } 
三、动态的修改工具栏 
     
       修改fckconfig.js文件。 
   在添加下面代码,把“Default”,改为自定义工具名称。在jsp 页面设置FCKeditor实例      oFCKeditor.setToolbarSet("自定义工具名称"); 

     FCKConfig.ToolbarSets["Default"] = [ 
    ['Source','DocProps','-','Save','NewPage','Preview','-','Templates'], 
    ['Cut','Copy','Paste','PasteText','PasteWord','-','Print','SpellCheck'], 
    ['Undo','Redo','-','Find','Replace','-','SelectAll','RemoveFormat'], 
    ['Form','Checkbox','Radio','TextField','Textarea','Select','Button','ImageButton','HiddenField'], 
       '/', 
    ['Style','FontFormat','FontName','FontSize'], 
    ['TextColor','BGColor'], 
    ['FitWindow','-','About'] 
] ; 

?附件中包括了完整的FCKeditor文件以及配置好的工程源码?

PS:项目中用到了struts2,上传时候同样碰到了权限问题,原来是因为struts2的拦截器导致,所以修改filter-mapping即可以:?

?

?

?

<filter-mapping>   
        <filter-name>struts2</filter-name>   
        <url-pattern>*.action</url-pattern>   
    </filter-mapping>   
  
  
    <filter-mapping>   
        <filter-name>struts2</filter-name>   
        <url-pattern>*.jsp</url-pattern>   
    </filter-mapping> 

?