springboot集成oss上传头像themleaf模板

1、前端页面themleaf

<form class="ui large form" method="post" action="#" th:action="@{/admin/register}" enctype="multipart/form-data">
           <div class="ui  segment">
             <div class="field">
               <div class="ui left icon input">
                 <i class="user icon"></i>
                 <input type="text" name="username" placeholder="用户名">
               </div>
             </div>
             <div class="field">
               <div class="ui left icon input">
                 <i class="lock icon"></i>
                 <input type="password" name="password" placeholder="密码">
               </div>
             </div>
             <div class="field">
               <div class="ui left icon input">
                 <i class="user icon"></i>
                 <input type="text" name="email" placeholder="邮箱">
               </div>
             </div>
             <div class="field">
               <div class="ui left icon input">
                 <i class="user icon"></i>
                 <input type="text" name="nickname" placeholder="真实姓名">
               </div>
             </div>
             <div class="field">
               <div class="ui left icon input">
                 <i class="user icon"></i>
                 <input type="file" name="file" accept="image/jpeg" placeholder="上传头像">
               </div>
             </div>
             <button class="ui fluid large teal submit button">注   册</button>
           </div>

           <div class="ui error mini message"></div>
           <div class="ui mini negative message" th:unless="${#strings.isEmpty(msg)}" th:text="${msg}">用户名和密码错误</div>

         </form>

运行效果

在这里插入图片描述

后端springboot

oss依赖

<!--阿里云对象存储oss-->
        <dependency>
            <groupId>com.aliyun.oss</groupId>
            <artifactId>aliyun-sdk-oss</artifactId>
            <version>3.10.2</version>
        </dependency>

controller层代码

public String zhuce(@RequestParam("file") MultipartFile file, User user, RedirectAttributes attributes) throws IOException {
        if (file.isEmpty()){
            attributes.addFlashAttribute("msg","头像为空!!!");
            return "redirect:/admin/register";
        }
        // yourEndpoint填写Bucket所在地域对应的Endpoint。以华东1(杭州)为例,Endpoint填写为https://oss-cn-hangzhou.aliyuncs.com。
        String endpoint = "oss-cn-shanghai.aliyuncs.com";
// 阿里云账号AccessKey拥有所有API的访问权限,风险很高。强烈建议您创建并使用RAM用户进行API访问或日常运维,请登录RAM控制台创建RAM用户。
        String accessKeyId = "LJHLTAI5tRHjXo6cYh9XyfPcWwF";
        String accessKeySecret = "554VzAx9ccw5BwFunu9CIByVAAJBHCMdJ";
        OSS ossClient = new OSSClientBuilder().build(endpoint, accessKeyId, accessKeySecret);
        String backetName="ljhyyds";
        //如果桶不存在,动态创建桶
        if(!ossClient.doesBucketExist(backetName)){
            //创建bucket
            ossClient.createBucket(backetName);
            //设置oss实例的访问权限,公共读
            ossClient.setBucketAcl(backetName, CannedAccessControlList.PublicRead);
        }
        InputStream inputStream = file.getInputStream();
        String originalFilename = file.getOriginalFilename();
        String imgSuffix = originalFilename.substring(originalFilename.lastIndexOf("."));
        String newFilename= UUID.randomUUID().toString()+imgSuffix;
        SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd");
        String datePath = dateFormat.format(new Date());
        String fileUrl=datePath+"/"+newFilename;

        PutObjectRequest putObjectRequest = new PutObjectRequest(backetName, fileUrl, inputStream);
        ossClient.putObject(putObjectRequest);
        ossClient.shutdown();
        System.out.println("=========================>图片地址:"+"https://"+backetName+"."+endpoint+"/"+fileUrl);
        user.setAvatar("https://"+backetName+"."+endpoint+"/"+fileUrl);
        user.setCreateTime(new Date());
        User user1 = loginRepository.save(user);
        attributes.addFlashAttribute("message","注册成功!!!");
        return "redirect:/admin";
    }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值