黑马程序员技术交流社区
标题: 【郑州校区】Java的新项目学成在线笔记-day8(四) [打印本页]
作者: 谷粒姐姐 时间: 2019-4-8 13:57
标题: 【郑州校区】Java的新项目学成在线笔记-day8(四)
保存课程图片
1.2.1 需求分析
图片上传到文件系统后,其它子系统如果想使用图片可以引用图片的地址,课程管理模块使用图片的方式是将图片 地址保存到课程数据库中。
业务流程如下:
1、上传图片到文件系统服务 2、保存图片地址到课程管理服务
在课程管理服务创建保存课程与图片对应关系的表 course_pic。
3、在course_pic保存图片成功后方可查询课程图片信息。
通过查询course_pic表数据则查询到某课程的图片信息。 1.2.2 课程管理服务端开发 1.2.2.1 API
课程管理需要使用图片则在课程管理服务中要提供保存课程图片的api。
[AppleScript] 纯文本查看 复制代码
@ApiOperation("添加课程图片")
public ResponseResult addCoursePic(String courseId,String pic);
1.2.2.2 Dao
模型:
[AppleScript] 纯文本查看 复制代码
@Data @ToString @Entity @Table(name="course_pic") @GenericGenerator(name = "jpa‐assigned", strategy = "assigned") public class CoursePic implements Serializable {
private static final long serialVersionUID = ‐916357110051689486L;
@Id
@GeneratedValue(generator = "jpa‐assigned")
private String courseid;
private String pic; }
API如下:
[AppleScript] 纯文本查看 复制代码
public interface CoursePicRepository extends JpaRepository<CoursePic, String> {
}
1.2.3.3 Service
[AppleScript] 纯文本查看 复制代码
//添加课程图片
@Transactional
public ResponseResult saveCoursePic(String courseId,String pic){
//查询课程图片
Optional<CoursePic> picOptional = coursePicRepository.findById(courseId);
CoursePic coursePic = null;
if(picOptional.isPresent()){
coursePic = picOptional.get();
}
//没有课程图片则新建对象
if(coursePic == null){
coursePic = new CoursePic();
}
coursePic.setCourseid(courseId);
coursePic.setPic(pic);
//保存课程图片
[AppleScript] 纯文本查看 复制代码
coursePicRepository.save(coursePic);
return new ResponseResult(CommonCode.SUCCESS);
}
1.2.3.4 Controller
[AppleScript] 纯文本查看 复制代码
@Override
@PostMapping("/coursepic/add")
public ResponseResult addCoursePic(@RequestParam("courseId") String courseId, @RequestParam("pic") String pic) {
//保存课程图片
return courseService.saveCoursePic(courseId,pic);
1.2.4前端开发
前端需要在上传图片成功后保存课程图片信息。
1.2.4.1 Api方法
[AppleScript] 纯文本查看 复制代码
//添加课程图片 export const addCoursePic= (courseId,pic) => {
return http.requestPost(apiUrl+'/course/coursepic/add?courseId='+courseId+"&pic="+pic)
}
1.2.4.2 页面
1)添加上传成功的钩子 :on-success="handleSuccess"
[AppleScript] 纯文本查看 复制代码
<el‐upload
action="/api/filesystem/upload" list‐type="picture‐card"
:on‐success="handleSuccess">
<i class="el‐icon‐plus"></i> </el‐upload>
2)在钩子方法 中保存课程图片信息
如果保存图片失败则上传失败,清除文件列表。
[AppleScript] 纯文本查看 复制代码
//上传成功的钩子方法
handleSuccess(response, file, fileList){
console.log(response)
if(response.success){
//alert('上传成功')
//图片上传成功将课程图片地址保存到课程数据库
let pic = response.fileSystem.filePath
courseApi.addCoursePic(this.courseid,pic).then((res) => {
if(res.success){
this.$message.success('上传成功');
}else{
this.handleError()
}
});
}else{
this.handleError()
}
},
//上传失败执行的钩子方法
handleError(err, file, fileList){
this.$message.error('上传失败');
//清空文件队列
this.fileList = []
}
欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/) |
黑马程序员IT技术论坛 X3.2 |