问题
之前工作因队友离开,只一天接手其部分且第二天就要上线此工具产品,测试提了一些Bug,在Bug中有一个是添加商品图片。前端告知不能用、电话离职队友说能用。没办法自己上、追踪代码。
en队友跟同事两合伙开发的是下载图片再上传,这块代码跟需求好像不太相符,重写。
淘宝开放平台文档中心:开放平台-文档中心
请求示例:
TaobaoClient client = new DefaultTaobaoClient(url, appkey, secret);
PictureUploadRequest req = new PictureUploadRequest();
req.setPictureId(10000L);
req.setPictureCategoryId(123L);
req.setImg(new FileItem("/tmp/file.txt"));
req.setImageInputTitle("Bule.jpg");
req.setTitle("图片名称");
req.setClientType("client:computer");
req.setIsHttps(true);
PictureUploadResponse rsp = client.execute(req, sessionKey);
System.out.println(rsp.getBody());
解决
一开始想着用流直传过去试试。
req.setImg(new FileItem("", file.getBytes()));
不行。
换个思路,先上传到服务器再上传到淘宝。
file.transferTo(new File(allPath));
上传到服务器ok,上传到淘宝不行。
直接用队友的封装的
PictureUtils.downloadPicture(url, filePath);
不行。
自己封装了一个工具类。上传到服务器ok,上传到淘宝不行。
同事帮提供了一个工具。
public static void uploadFile(byte[] file, String filePath, String fileName) throws Exception {
File targetFile = new File(filePath);
if(!targetFile.exists()){
targetFile.mkdirs();
}
try (FileOutputStream out = new FileOutputStream(filePath + fileName)) {
out.write(file);
out.flush();
out.close();
}
}
上传到服务器也ok,上传到淘宝不行。
想着可能是提供的PictureCategoryId值有点问题,重新要值和ok的图片,都行。
把这部分的代码封装到Service,结果报错。算了,就放Controller层。
@PostMapping(value = "/upload/img",name = "添加天猫商品图片")
public JSONResult uploadImg(@RequestParam("file") MultipartFile file) {
String fileName = file.getOriginalFilename();
String filePath = "/www/pictures/";
//String filePath = "D:\\picture\\";
String allPath = filePath + fileName;
try {
FileUtil.uploadFile(file.getBytes(), filePath, fileName);
//这里视情况可不做校验
/*String suffix = Objects.requireNonNull(file.getOriginalFilename())
.substring(file.getOriginalFilename().lastIndexOf(".") + 1,
file.getOriginalFilename().length());
if (!"jpg,jpeg,gif,png".toUpperCase().contains(suffix.toUpperCase())) {
return JSONResult.error("请选择jpg,jpeg,gif,png格式的图片");
}*/
Path path = Paths.get(allPath);
if (Files.exists(path)) {
PictureUploadResponse rsp = taobaoService.pictureUpload(allPath);
log.info( "rsp::" + JSON.toJSONString(rsp));
if(rsp.isSuccess()){
return JSONResult.success(rsp.getPicture().getPicturePath());
}
return JSONResult.error(rsp.getSubMsg());
}
return JSONResult.success("文件已存在");
} catch (Exception e) {
return JSONResult.error("上传失败");
}
}
return JSONResult.error(rsp.getSubMsg());这里因为淘宝那边有校验结果,所以直接返回。
同事建议说在后端对图片做调整处理成符合淘宝的图片,个人觉得在前端调整处理比较合适、所见即所得。
打包部署配置Nginx联调ok。当时ld只给一天时间解决这些别人的问题没时间紧搞,还是应该先评估再合理分配资源。就这样先了接手别人的问题还很多、自己的任务也还在收尾。🤣