SpringMVC 구현 이미지 업로드 및 주의사항 자세히 보기
jsp 코드는 다음과 같습니다.
<form action="${path}/upload/uploadPic.do" method="post" enctype="multipart/form-data">
<div>
![](${path}/mall/image/load_image.png)
<input type="file" id="input-image" name="input-image">
<input id="input-relative-path" name="imgs" type="hidden" >
<input id="input-last-path" type="hidden">
<input type="submit" value=" ">
</div>
</form>
controller 코드:spring을 통해 실현
@Controller
@RequestMapping("/upload")
public class UploadController extends BaseController {
@RequestMapping(value = "/uploadPic", method = RequestMethod.POST)
@LoginCheck
public void uploadPic(HttpServletRequest request, PrintWriter out, String lastRealPath) throws IOException {
// CommonsMultipartResolver
CommonsMultipartResolver resolver = new CommonsMultipartResolver(request.getSession().getServletContext());
// form enctype="multipart/form-data"
if (resolver.isMultipart(request)) {
// request
MultipartHttpServletRequest req = (MultipartHttpServletRequest) request;
// input
Iterator<String> iterable = req.getFileNames();
//
if (iterable.hasNext()) {
String inputName = iterable.next();
//
MultipartFile mf = req.getFile(inputName);
byte[] mfs = mf.getBytes();
//
String fileName = new SimpleDateFormat("yyyyMMddHHmmssSSS").format(new Date());
Random random = new Random();
for (int i = 0; i < 3; i++) {
fileName = fileName + random.nextInt(10);
}
//
String oriFileName = mf.getOriginalFilename();
String suffix = oriFileName.substring(oriFileName.lastIndexOf("."));
//
String localPath = "/Users/ZR/Desktop/webPro/console/src/main/webapp/image/" + fileName + suffix;
mf.transferTo(new File(localPath));
//
BufferedImage bufferedImage = ImageIO.read(new FileInputStream(new File(localPath)));
int width = bufferedImage.getWidth();
int height = bufferedImage.getHeight();
//
long size = mf.getSize();
}
}
}
}
spring-mvc.xml 코드:
<!--
,id
-->
<bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver">
<property name="maxUploadSize" value="1024000"/>
<!-- -->
</bean>
기능의 실현은 사실 매우 간단하지만, 초보자에 대해서는 다음과 같은 몇 가지 점을 주의해야 한다이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
thymeleaf로 HTML 페이지를 동적으로 만듭니다 (spring + gradle)지난번에는 에서 화면에 HTML을 표시했습니다. 이번에는 화면을 동적으로 움직여보고 싶기 때문에 입력한 문자를 화면에 표시시키고 싶습니다. 초보자의 비망록이므로 이상한 점 등 있으면 지적 받을 수 있으면 기쁩니다! ...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.