使用Jersey構(gòu)建圖片服務(wù)器過程解析
這篇文章主要介紹了使用Jersey構(gòu)建圖片服務(wù)器過程解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
前臺(tái)頁面代碼
<form id="jvForm" action="add.do" method="post" enctype="multipart/form-data"> <table> <tr> <td width="20%" class="pn-flabel pn-flabel-h"></td> <td width="80%" class="pn-fcontent"> <img width="100" height="100" id="allImgUrl" /> <input type="hidden" name="imgUrl" id="path" /> <input type="file" onchange="uploadPic()" name="pic" id="logoPic"/> </td> </tr> </table> </form>
前臺(tái)JS代碼
<script type="text/javascript">
//上傳圖片
function uploadPic() {
//定義參數(shù)
var options = {
url : "/upload/uploadPic.do",
dataType : "json",
type : "post",
beforeSubmit : function(formData,jqForm,options){
// 判斷是否為圖片
// 將jqForm轉(zhuǎn)成DOM對(duì)象
var f = jqForm[0];
// 獲取DOM對(duì)象中name為logoPic的值
var v = f.logoPic.value;
// 獲取擴(kuò)展名,并轉(zhuǎn)成小寫
var ext = v.substring(v.length-3).toLowerCase();
// 比對(duì)擴(kuò)展名 jpg gif bmp png
if(ext != "jpg" && ext != "gif" && ext != "bmp" && ext != "png"){
alert("只允許上傳圖片!");
return false;
}
//校驗(yàn)提交的表單
return true;
},
success : function(data) {
// 回顯圖片內(nèi)容
$("#allImgUrl").attr("src", data.url);
$("#path").val(data.path);
}
};
// jquery.form使用方式
$("#jvForm").ajaxSubmit(options);
}
</script>
在Spring中配置圖片轉(zhuǎn)換器
<bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver"> <!-- 設(shè)置上傳文件的最大尺寸為1MB --> <property name="maxUploadSize" value="1048576"/> </bean>
創(chuàng)建UploadController以及工具類
package cn.itcast.core.controller.admin;
import java.io.IOException;
import java.text.DateFormat;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.Random;
import javax.servlet.http.HttpServletResponse;
import org.apache.commons.io.FilenameUtils;
import org.json.JSONObject;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.multipart.MultipartFile;
import com.sun.jersey.api.client.Client;
import com.sun.jersey.api.client.WebResource;
import cn.itcast.common.web.ResponseUtils;
import cn.itcast.core.web.Constants;
@Controller
public class UploadController {
// 上傳圖片
@RequestMapping(value = "/upload/uploadPic.do")
public void uploadPic(@RequestParam(required = false) MultipartFile pic, HttpServletResponse response) {
// 擴(kuò)展名
String ext = FilenameUtils.getExtension(pic.getOriginalFilename());
// 圖片名稱生成策略
DateFormat df = new SimpleDateFormat("yyyyMMddHHmmssSSS");
// 圖片名稱一部分
String format = df.format(new Date());
// 隨機(jī)三位數(shù)
Random r = new Random();
// n 1000 0-999 99
for (int i = 0; i < 3; i++) {
format += r.nextInt(10);
}
// 實(shí)例化一個(gè)Jersey
Client client = new Client();
// 保存數(shù)據(jù)庫
String path = "upload/" + format + "." + ext;
// 另一臺(tái)服務(wù)器的請(qǐng)求路徑是?
String url = Constants.IMAGE_URL + path;
// 設(shè)置請(qǐng)求路徑
WebResource resource = client.resource(url);
// 發(fā)送開始 POST GET PUT
try {
resource.put(String.class, pic.getBytes());
} catch (IOException e) {
e.printStackTrace();
}
// 返回二個(gè)路徑
JSONObject jsonObject = new JSONObject();
jsonObject.put("url", url);
jsonObject.put("path", path);
ResponseUtils.renderJson(response, jsonObject.toString());
}
}
package cn.itcast.core.web;
public interface Constants {
/**
* 圖片服務(wù)器
*/
public static final String IMAGE_URL = "http://localhost:8088/BabasportProject_ImageService/";
}
package cn.itcast.common.web;
import java.io.IOException;
import javax.servlet.http.HttpServletResponse;
public class ResponseUtils {
// 發(fā)送內(nèi)容
public static void render(HttpServletResponse response, String contentType, String text) {
response.setContentType(contentType);
try {
response.getWriter().write(text);
} catch (IOException e) {
e.printStackTrace();
}
}
// 發(fā)送的是JSON
public static void renderJson(HttpServletResponse response, String text) {
render(response, "application/json;charset=UTF-8", text);
}
// 發(fā)送xml
public static void renderXml(HttpServletResponse response, String text) {
render(response, "text/xml;charset=UTF-8", text);
}
// 發(fā)送text
public static void renderText(HttpServletResponse response, String text) {
render(response, "text/plain;charset=UTF-8", text);
}
}
搭建另一個(gè)Tomcat,作為圖片服務(wù)器
圖片服務(wù)器Tomcat的設(shè)置 tomcat/conf/web.xml中內(nèi)容更改
<servlet> <servlet-name>default</servlet-name> <servlet-class>org.apache.catalina.servlets.DefaultServlet</servlet-class> <init-param> <param-name>debug</param-name> <param-value>0</param-value> </init-param> <init-param> <param-name>readonly</param-name> <param-value>false</param-value> </init-param> <init-param> <param-name>listings</param-name> <param-value>false</param-value> </init-param> <load-on-startup>1</load-on-startup> </servlet>
修改圖片服務(wù)器的Tomcat的端口號(hào)
在BabasprotProject_ImageService項(xiàng)目的webapp目錄下創(chuàng)建upload文件夾
以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Spring Cloud 配置中心多環(huán)境配置bootstrap.yml的實(shí)現(xiàn)方法
spring cloud用上了配置中心,就一個(gè)boostrap.yml,本文就來介紹一下Spring Cloud 配置中心多環(huán)境配置bootstrap.yml的實(shí)現(xiàn)方法,感興趣的可以了解一下2024-03-03
解析Arthas協(xié)助排查線上skywalking不可用問題
這篇文章主要為大家介紹了解析Arthas協(xié)助排查線上skywalking不可用的問題詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-02-02
關(guān)于SpringBoot中事務(wù)失效的幾種情況
這篇文章主要介紹了關(guān)于SpringBoot中事務(wù)失效的幾種情況,Spring AOP默認(rèn)使用動(dòng)態(tài)代理,會(huì)給被代理的類生成一個(gè)代理類,事務(wù)相關(guān)的操作都通過代理來完成,使用內(nèi)部方法調(diào)用時(shí),使用的是實(shí)例調(diào)用,沒有通過代理類調(diào)用方法,因此事務(wù)不會(huì)檢測到失敗,需要的朋友可以參考下2023-08-08
詳解如何在SpringBoot項(xiàng)目中使用統(tǒng)一返回結(jié)果
在一個(gè)完整的項(xiàng)目中,如果每一個(gè)控制器的方法都返回不同的結(jié)果,那么對(duì)項(xiàng)目的維護(hù)和擴(kuò)展都會(huì)很麻煩。因此,本文為大家準(zhǔn)備了SpringBoot項(xiàng)目中使用統(tǒng)一返回結(jié)果的方法,需要的可以參考一下2022-10-10

