springmvc上傳圖片,editor.md七牛云上傳圖片springboot_spring boot 若依系統整合Ueditor,部署時候上傳圖片錯誤解決.

 2023-10-24 阅读 30 评论 0

摘要:springmvc上傳圖片。spring boot 若依系統整合Ueditor,部署時候上傳圖片錯誤解決前言:國慶假期找了個ruoyi版本的cms玩玩,從git上看,介紹如下圖:后臺部分截圖:編輯?編輯?編輯?編輯?前臺blog截圖:編輯?編輯?看上去還可以不錯

c5483f0c4f031106b469b4af253e6cef.png

springmvc上傳圖片。spring boot 若依系統整合Ueditor,部署時候上傳圖片錯誤解決

前言:國慶假期找了個ruoyi版本的cms玩玩,從git上看,介紹如下圖:

后臺部分截圖:

aa827e9609ea77444a94282c5c04c644.png


編輯
?

b0f97e8e3f65653069495d3b252517b9.png


編輯
?

3e802492d186f03f20fb9dbea9c29049.png


編輯
?

fa205a61960050df512e213708d0c9bd.png


編輯
?

前臺blog截圖:

67314120eb3758fd3230112778a61e25.png


編輯
?

e7b45a810294e3fb2653e24fe8b35f04.png


編輯
?

看上去還可以不錯,于是clone下來玩玩,結果發現,發布文章的時候,編輯器有問題,上傳不了圖片,還有其他幾個地方有問題,怎么解決呢?自己上手擼代碼,修改唄。于是,下載了ueditor的源碼,加到項目中,進行修改。現在已經修改完成,并且也發布到的服務器上了,歡迎大家訪問測試。文末會有凱哥修改后的git地址o~

正文:

在spring boot整合UEditor的時候,本地idea編輯器中沒問題,但是部署服務器上,上傳圖片提示:“后端配置項沒有正常加載,上傳插件不能正常使用!”解決辦法。

出現這種情況,可以很負責任的告訴你99%是因為,在加載的時候,沒有獲取到ueditor的config.json文件。怎么處理了?

分析原因:

查看原來文件存放位置:

在resources的static下,正常來說,是沒有問題的。但是spring boot打成jar包后的路徑和war包的路徑是不一樣的。文件是在BOOT-INF下的。如下圖:

3de125d9e78496f704b40e7e89e186d0.png


編輯
?

直接獲取,是不行的。找到原因后,我們就來想辦法解決掉。

解決步驟:

1:修改文件存放位置。

如凱哥,直接就放在了resources下,文件名稱為:ueditor-config.json(這個文件名字,在后面需要用到)。如下圖:

4a804188a51044f8a3c305f4834f1e80.png


編輯
?

2:在yml文件中,配置ueditor-config.json的文件名:

uEditorConfig:
fileName: ueditor-config.json

如下圖:

42f5e0bae77563db68aa4062dcd09557.png


編輯
?

3:編寫一個controller(ps:JSP的凱哥沒有使用,修改成了controller.這樣符合習慣)

3.1:獲取json文件名稱

需要注意:把第二步配置的文件名稱,獲取到。如下圖:

2a7ff06bad759532a0cc0faf2a141f1c.png


編輯
?

3.2:編寫獲取json的類(上傳的也寫在了里面)。如下圖:

be205b725baf948a2b0d13d0dc4bdbb6.png


編輯
?

4:修改Ueditor的源碼

4.1:ActionEnter類的構造方法重寫。

/**
* 獲取config.json的
* @param request
* @param rootPath
* @param configFileName
*/
public ActionEnter (HttpServletRequest request, String rootPath,String configFileName ) {
this.request = request;
this.rootPath = rootPath;
this.actionType = request.getParameter( "action" );
this.contextPath = request.getContextPath();
this.configManager = ConfigManager.getInstance( this.rootPath, this.contextPath, request.getRequestURI(),configFileName );
}

如下圖:

69bde170b32617756e0e582a2f40b4d8.png


編輯
?

4.2:重寫ConfigManager.getInstance方法

/**
* 配置管理器構造工廠--修改后
* @param rootPath 服務器根路徑
* @param contextPath 服務器所在項目路徑
* @param uri 當前訪問的uri
* @param configFileName config.json的文件名稱
* @return 配置管理器實例或者null
*/
public static ConfigManager getInstance ( String rootPath, String contextPath, String uri,String configFileName ) {
try {
return new ConfigManager(rootPath, contextPath, uri,configFileName);
} catch ( Exception e ) {
return null;
}
}

如下圖:

325a92112848f65875a92622a8a55dd1.png


編輯
?

4.3:重寫ConfigManager構造器

/*
* 通過一個給定的路徑構建一個配置管理器, 該管理器要求地址路徑所在目錄下必須存在config.properties文件--kaigejava修改
*/
private ConfigManager ( String rootPath, String contextPath, String uri,String configFileName) throws FileNotFoundException, IOException {
rootPath = rootPath.replace( "", "/" );
this.rootPath = rootPath;
this.contextPath = contextPath;
this.configFileName = configFileName;
if ( contextPath.length() > 0 ) {
this.originalPath = this.rootPath + uri.substring( contextPath.length() );
} else {
this.originalPath = this.rootPath + uri;
}
this.initEnv();
}

如下圖:

b9b9b9bb67df6d06ec8de6a5a5e18f20.png


編輯
?

private void initEnv () throws FileNotFoundException, IOException {
File file = new File( this.originalPath );
if ( !file.isAbsolute() ) {
file = new File( file.getAbsolutePath() );
}
this.parentPath = file.getParent();
//String configContent = this.readFile( this.getConfigPath() );
String configContent = this.filter(IOUtils.toString(this.getClass().getClassLoader().getResourceAsStream(configFileName),"UTF-8"));
try{
JSONObject jsonConfig = JSONObject.parseObject(configContent);
this.jsonConfig = jsonConfig;
} catch ( Exception e ) {
this.jsonConfig = null;
}
}

其中核心的:

String configContent = this.filter(IOUtils.toString(this.getClass().getClassLoader().getResourceAsStream(configFileName),"UTF-8"));

修改后,如下圖:

3a2b3db2a310b6d0e8b96438b9601067.png


編輯
?

把ueditor.config.js文件的serverUrl修改成第一步編寫的controller對應的url.如下圖:

30da2d99157dea151d2b8d614c2eb277.png


編輯
?

修改完成之后,重新打包之后,部署完成,發布訪問試試看。就可以了。

源碼獲取:凱哥Java(kaigejava),回&|復:kaige-cms。即可獲取本系統源碼了.blog體驗域名:www|jiahaoyou|net。將|換成.

版权声明:本站所有资料均为网友推荐收集整理而来,仅供学习和研究交流使用。

原文链接:https://hbdhgg.com/4/163833.html

发表评论:

本站为非赢利网站,部分文章来源或改编自互联网及其他公众平台,主要目的在于分享信息,版权归原作者所有,内容仅供读者参考,如有侵权请联系我们删除!

Copyright © 2022 匯編語言學習筆記 Inc. 保留所有权利。

底部版权信息