1.案例演示
(1).制作一个简单的表单,点击上传
(2).oss管理控制台会存储当前照片信息
(3).跳转页面会显示图片
2.设计步骤
首先先简单的设计两个数据库来存储表单信息
设计前台页面,这里我主要使element-ui来设计页面,这里我直接在html页面引入element-ui相关文件,便于设计
我的目录结构
导入相关依赖
com.aliyun.oss
aliyun-sdk-oss
3.8.1
相关配置
#阿里云OSS
#不同的服务器,地址不同
aliyun.oss.file.endpoint=oss-cn-beijing.aliyuncs.com
aliyun.oss.file.keyid=LTAI4G3DxLCmrmF2pD8PHc84
aliyun.oss.file.keysecret=WraTKDlqJFL4vaI0UCWsnZZp7R0Wka
#bucket可以在控制台创建,也可以使用java代码创建
aliyun.oss.file.bucketname=edu-day01
相关类
@Component
public class ConstantPropertiesUtilsimplements InitializingBean {
//取得配置文件内容
@Value("${aliyun.oss.file.endpoint}")
private Stringendpoint;
@Value("${aliyun.oss.file.keyid}")
private StringkeyId;
@Value("${aliyun.oss.file.keysecret}")
private StringkeySecret;
@Value("${aliyun.oss.file.bucketname}")
private StringbucketName;
//定义公开静态常量
public static StringEND_POIND;
public static StringACCESS_KEY_ID;
public static StringACCESS_KEY_SECRET;
public static StringBUCKET_NAME;
@Override
public void afterPropertiesSet()throws Exception {
END_POIND =endpoint;
ACCESS_KEY_ID =keyId;
ACCESS_KEY_SECRET =keySecret;
BUCKET_NAME =bucketName;
}
}
@Service
public class OssServiceImplimplements OssService {
//上传头像到oss
@Override
public String uploadFileAvatar(MultipartFile file) {
// 工具类获取值
String endpoint = ConstantPropertiesUtils.END_POIND;
String accessKeyId = ConstantPropertiesUtils.ACCESS_KEY_ID;
String accessKeySecret = ConstantPropertiesUtils.ACCESS_KEY_SECRET;
String bucketName = ConstantPropertiesUtils.BUCKET_NAME;
try {
// 创建OSS实例。
OSS ossClient =new OSSClientBuilder().build(endpoint, accessKeyId, accessKeySecret);
//获取上传文件输入流
InputStream inputStream = file.getInputStream();
//获取文件名称
String fileName = file.getOriginalFilename();
//1 在文件名称里面添加随机唯一的值
String uuid = UUID.randomUUID().toString().replaceAll("-","");
// yuy76t5rew01.jpg
fileName = uuid+fileName;
//2 把文件按照日期进行分类
//获取当前日期
// 2019/11/12
String datePath =new DateTime().toString("yyyy/MM/dd");
//拼接
// 2019/11/12/ewtqr313401.jpg
fileName = datePath+"/"+fileName;
//调用oss方法实现上传
//第一个参数 Bucket名称
//第二个参数 上传到oss文件路径和文件名称aa/bb/1.jpg
//第三个参数 上传文件输入流
//设置请求头
ObjectMetadata meta =new ObjectMetadata();
meta.setContentType("image/jpg");
ossClient.putObject(bucketName,fileName , inputStream,meta);
// 关闭OSSClient。
ossClient.shutdown();
//把上传之后文件路径返回
//需要把上传到阿里云oss路径手动拼接出来
// https://edu-guli-1010.oss-cn-beijing.aliyuncs.com/01.jpg
String url ="https://"+bucketName+"."+endpoint+"/"+fileName;
return url;
}catch(Exception e) {
e.printStackTrace();
return null;
}
}
}
页面代码
上传图片
:multiple="multiple"
action="http://localhost:8009/img"
list-type="picture"
:auto-upload="false"
:http-request="uploadFile"
ref="upload"
>
点击上传
提交
new Vue({
el:"#image",
data(){
return{
ruleForm: {},
multiple:true,
formDate:""
}
},
methods:{
uploadFile(file){
this.formDate.append('file', file.file);
},
// subPicForm(){
// this.formDate = new FormData()
// this.$refs.upload.submit();
// this.formDate.append('WS_CODE', "12133");
// let config = {
// headers: {
// 'Content-Type': 'multipart/form-data'
// }
// }
// axios.post("http://localhost:8009/img", this.formDate,config).then( res => {
// console.log(res)
// }).catch( res => {
// console.log(res)
// })
// },
submitForm(formName) {
this.$refs[formName].validate((valid) => {
if (valid) {
this.formDate =new FormData()
this.$refs.upload.submit();
this.formDate.append('username',this.ruleForm.username);
this.formDate.append('email',this.ruleForm.email);
let config = {
headers: {
'Content-Type':'multipart/form-data'
}
}
axios.post("http://localhost:8009/img",this.formDate,config).then( res => {
console.log(res.data.user)
id=res.data.user
window.location.href="/showImage.html?id="+id
}).catch( res => {
console.log(res)
})
}else {
console.log('error submit!!');
return false;
}
});
}
},
})
显示页面代码
{{tableData.username}}
{{tableData.username}}