Jerseyを使って画像サーバを構築する過程解析


この文章は主にJerseyを使って画像サーバーを構築する過程解析を紹介しています。ここでは例示コードを通して紹介された非常に詳細で、皆さんの学習や仕事に対して一定の参考学習価値があります。必要な友達は下記を参考にしてください。
フロントページコード

<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>
フロントJSコード

<script type="text/javascript">
	//    
	function uploadPic() {
		//    
		var options = {
			url : "/upload/uploadPic.do",
			dataType : "json",
			type : "post",
			beforeSubmit : function(formData,jqForm,options){
				//        
				//  jqForm  DOM  
				var f = jqForm[0];
				//   DOM   name logoPic  
				var v = f.logoPic.value;
				//      ,     
				var ext = v.substring(v.length-3).toLowerCase();
				//       jpg gif bmp png 
				if(ext != "jpg" && ext != "gif" && ext != "bmp" && ext != "png"){
					alert("       !");
					return false;
				}
				//       
				return true;
			},
			success : function(data) {
				//       
				$("#allImgUrl").attr("src", data.url);
				$("#path").val(data.path);
			}
		};

		// jquery.form    
		$("#jvForm").ajaxSubmit(options);
	}
</script>
Springに画像変換器を配置する

<bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver"> 
	<!--             1MB --> 
	<property name="maxUploadSize" value="1048576"/>
</bean>
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) {
		//    
		String ext = FilenameUtils.getExtension(pic.getOriginalFilename());
		//         
		DateFormat df = new SimpleDateFormat("yyyyMMddHHmmssSSS");
		//        
		String format = df.format(new Date());
		//      
		Random r = new Random();
		// n 1000 0-999 99
		for (int i = 0; i < 3; i++) {
			format += r.nextInt(10);
		}
		//      Jersey
		Client client = new Client();
		//      
		String path = "upload/" + format + "." + ext;
		//             ?
		String url = Constants.IMAGE_URL + path;
		//       
		WebResource resource = client.resource(url);

		//      POST GET PUT
		try {
			resource.put(String.class, pic.getBytes()); 
		} catch (IOException e) {
			e.printStackTrace();
		}

		//       
		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 {
	/**
	 *      
	 */
	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 {
	//     
	public static void render(HttpServletResponse response, String contentType, String text) {
		response.setContentType(contentType);
		try {
			response.getWriter().write(text);
		} catch (IOException e) {
			e.printStackTrace();
		}
	}

	//     JSON
	public static void renderJson(HttpServletResponse response, String text) {
		render(response, "application/json;charset=UTF-8", text);
	}

	//   xml
	public static void renderXml(HttpServletResponse response, String text) {
		render(response, "text/xml;charset=UTF-8", text);
	}

	//   text
	public static void renderText(HttpServletResponse response, String text) {
		render(response, "text/plain;charset=UTF-8", text);
	}
}
もう一つのTomcatを画像サーバーとして構築します。
画像サーバTomcatの設定tomcat/conf/web.xmlで内容が変更されました。

<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>
画像サーバのTomcatのポート番号を変更します。
Babasprot ProjectにいますImageServiceプロジェクトのwebappディレクトリでupladフォルダを作成します。
以上が本文の全部です。皆さんの勉強に役に立つように、私たちを応援してください。