Java用Springmvc上传图片到阿里云OSS

前端布局:

<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
    <title>Title</title>
    <!--引入element得css样式-->
    <link type="text/css" rel="stylesheet" href="css/index.css"/>
    <!--引入vue得js文件 这个必须在element之前引入-->
    <script type="text/javascript" src="js/vue.js"></script>
    <script type="text/javascript" src="js/qs.min.js"></script>
    <script type="text/javascript" src="js/axios.min.js"></script>
    <!--element得js文件-->
    <script type="text/javascript" src="js/index.js"></script>
</head>
<style>
    .avatar-uploader .el-upload {
        border: 1px dashed #d9d9d9;
        border-radius: 6px;
        cursor: pointer;
        position: relative;
        overflow: hidden;
    }

    .avatar-uploader .el-upload:hover {
        border-color: #409EFF;
    }

    .avatar-uploader-icon {
        font-size: 28px;
        color: #8c939d;
        width: 80px;
        height: 80px;
        line-height: 100px;
        text-align: center;
    }

    .avatar {
        width: 200px;
        height: 200px;
        display: block;
    }
</style>
<body>
<div id="app">
    <el-form label-width="80px" :model="formLabelAlign">
        <el-form-item label="头像">
            <el-upload
                    class="avatar-uploader"
                    action="/user/uploadAvatar"
                    :show-file-list="false"
                    :on-success="handleAvatarSuccess"
            >
                <img v-if="imageUrl" :src="imageUrl" class="avatar">
                <i v-else class="el-icon-plus avatar-uploader-icon"></i>
            </el-upload>
        </el-form-item>
        <el-form-item label="名称">
            <el-input v-model="formLabelAlign.name"></el-input>
        </el-form-item>
        <el-form-item label="密码">
            <el-input v-model="formLabelAlign.pwd"></el-input>
        </el-form-item>
        <el-form-item label="地址">
            <el-input v-model="formLabelAlign.address"></el-input>
        </el-form-item>
        <el-button type="primary" round @click="onSubmit">确定添加</el-button>
    </el-form>
</div>
</body>
<script>
    var app = new Vue({
        el: "#app",
        data: {
            formLabelAlign: {},
            imageUrl: "",
        },
        methods: {
            handleAvatarSuccess(res, file) {
                this.imageUrl = res.data;
                this.formLabelAlign.avatar = this.imageUrl;
                console.log(this.formLabelAlign)
            },
            onSubmit() {
                axios.post("/user/upForm", this.formLabelAlign).then(function (result) {
                    if (result.data.code === 2000) {//===:比较值和引用是否相同
                        window.location.replace("/indexAd.jsp");
                    }
                });
            },

        }
    })
</script>
</html>

选择阿里的OSS服务

引入Java的jar包

引入官方代码

 

 

package cn.wd.until;

import com.aliyun.oss.OSS;
import com.aliyun.oss.OSSClientBuilder;
import org.springframework.web.multipart.MultipartFile;

import java.io.InputStream;
import java.util.Calendar;
import java.util.UUID;

/**
 * @author DouZi
 * @Blog areone.top
 */
public class OSSUntil {
    public static String upload(MultipartFile myfile) {
        // Endpoint以华东1(杭州)为例,其它Region请按实际情况填写。
        String endpoint = "oss-cn-hangzhou.aliyuncs.com";
        // 阿里云账号AccessKey拥有所有API的访问权限,风险很高。强烈建议您创建并使用RAM用户进行API访问或日常运维,请登录RAM控制台创建RAM用户。
        String accessKeyId = "XXXXXXXXXXX";
        String accessKeySecret = "XXXXXXXXXXXXXX";
        // 填写Bucket名称,例如examplebucket。
        String bucketName = "zsbzzz";
        //你上传到oss后的名字 会根据日期帮你创建文件夹。
        String objectName = fileName(myfile);
        // 创建OSSClient实例。
        OSS ossClient = new OSSClientBuilder().build(endpoint, accessKeyId, accessKeySecret);

        try {
            InputStream inputStream = myfile.getInputStream();
            // 创建PutObject请求。
            ossClient.putObject(bucketName, objectName, inputStream);
        } catch (Exception oe) {

        } finally {
            if (ossClient != null) {
                ossClient.shutdown();
            }
        }
        //https://qy151.oss-cn-hangzhou.aliyuncs.com/2022/6/10/20d3d7e6b5bb455cb548675501f7270fgdnj.jpg
        String url = "https://" + bucketName + "." + endpoint + "/" + objectName;
        return url;
    }

    //获取上传到oss后的名字
    private static String fileName(MultipartFile myfile) {
        Calendar calendar = Calendar.getInstance();
        String name = calendar.get(Calendar.YEAR) + "/" + (calendar.get(Calendar.MONTH) + 1) + "/" +
                calendar.get(Calendar.DATE) + "/" + UUID.randomUUID().toString().replace("-", "") +
                myfile.getOriginalFilename();
        return name;
    }
}

 这里的代码是封装了一下直接在后端调用

 

package cn.wd.controller;

import cn.wd.dao.UserDao;
import cn.wd.entity.User;
import cn.wd.until.CommonResult;
import cn.wd.until.OSSUntil;
import com.aliyun.oss.internal.OSSUtils;
import com.fasterxml.jackson.databind.ObjectMapper;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.multipart.MultipartFile;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.io.PrintWriter;
import java.util.List;

/**
 * @author DouZi
 * @Blog areone.top
 */
@RestController
@RequestMapping(value = "user")
public class AdController {
    @RequestMapping("uploadAvatar")
    public CommonResult uploadAvatar(MultipartFile file) {
        try {
            String avatar = OSSUntil.upload(file);
            return new CommonResult(2000, "上传成功", avatar);
        } catch (Exception e) {
            e.printStackTrace();
        }
        return new CommonResult(5000, "失败", null);
    }

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在Tomcat和Spring MVC中将照片上传到本地,你可以按照以下步骤进行操作: 1. 配置文件上传的相关依赖: 在你的项目中添加Apache Commons FileUpload和Apache Commons IO的依赖。你可以使用Maven或Gradle来管理依赖。 2. 创建文件上传表单: 在你的前端页面中创建一个表单,用于选择要上传的照片文件。 ```html <form method="POST" action="/upload" enctype="multipart/form-data"> <input type="file" name="photo" /> <input type="submit" value="Upload" /> </form> ``` 3. 创建Controller处理上传请求: 创建一个Spring MVC的Controller类,用于处理上传请求,并保存照片到本地。 ```java import org.springframework.web.bind.annotation.PostMapping; import org.springframework.web.bind.annotation.RequestParam; import org.springframework.web.multipart.MultipartFile; import org.springframework.web.bind.annotation.RestController; @RestController public class UploadController { @PostMapping("/upload") public String handleFileUpload(@RequestParam("photo") MultipartFile file) { if (!file.isEmpty()) { try { byte[] bytes = file.getBytes(); // 将照片保存到本地文件系统 // 这里可以根据你的需求,指定保存的路径和文件名 // 例如:Files.write(bytes, new File("D:/uploads/photo.jpg")); return "File uploaded successfully!"; } catch (IOException e) { e.printStackTrace(); return "Error uploading file!"; } } else { return "No file selected!"; } } } ``` 在上述代码中,`handleFileUpload`方法会接收名为"photo"的文件参数,并将其保存到本地文件系统。你可以根据需要进行修改。 4. 配置文件上传的临时目录: 在Tomcat的配置文件(如`server.xml`)中,你可以配置一个临时目录用于存储上传的文件。找到一个可写的目录,并添加以下配置: ```xml <Context docBase="your_app_path" path="/" reloadable="true"> <WatchedResource>WEB-INF/web.xml</WatchedResource> <Resources allowLinking="true" cachingAllowed="false" className="org.apache.naming.resources.FileDirContext" /> <Parameter name="org.apache.tomcat.util.http.fileupload.DefaultFileItemFactory.repository" value="/path/to/temp/dir" /> </Context> ``` 将上述代码中的`your_app_path`替换为你的应用程序路径,将`/path/to/temp/dir`替换为你想要的临时目录路径。 5. 部署并启动Tomcat服务器: 将你的应用程序打包成WAR文件,并将其部署到Tomcat服务器中。启动Tomcat服务器。 现在,当你选择一个照片文件并提交表单时,该文件会被上传到服务器,并保存到你指定的本地目录中。请根据你的实际需求修改代码中的路径和文件名。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值