不依赖input file标签上传图片

由于安全策略的原因,js没法直接读本地磁盘的图片(IE不考虑)。

不用input file,就是不想去选文件,我就要用固定的图片上传,这个固定可能是固定的某一张图片,也可能是固定策略生成的图片(每次都生成,但每次都不一样,比如聊天截图。。。)。

第一种方式:图片转canvas -----》base64上传。(这种方式如果不支持canvas的情况就没法用)

第二种方式:用ajax读这个图片url,拿到blob,转成File对象,放到formdata里去post给后台(这里就是第二种方式)。注意点:图片的url路径要对,还有跨域问题

第三种方式:比如cocos和安卓交互,可以让安卓来做上传的动作,因为安卓能直接读本地资源

<!DOCTYPE html>
<html>
 
	<head>
		<meta charset="UTF-8">
		<title></title>
	</head>
 
	<body>
		<!--<input id="input" onchange="change()" type="file"></input>-->
		<img id="img" src="1.png" />
		<output id="result"></output>
	</body>
</html>
 
<script>
	function loadImageToBlob(url,callback) {

        if(!url) return false;

        var xhr = new XMLHttpRequest();

        xhr.open('get', url, true);

        xhr.responseType = 'blob';

        xhr.onload = function() {

            // 注意这里的this.response 是一个blob对象 就是文件对象

            callback(this.status == 200 ? this.response : false);

        }

        xhr.send();

        return true;

    }

    function cbk(file){
        console.log(file);
        var t = file.type;
        //这里可以根据mime决定文件名的后缀,jpg还是png。。。
        var new_file = new File([file],"name.jpg",{type:t});
        var formData = new FormData(); // Currently empty
        formData.append('a', 111);
        formData.append('b', new_file);//php端的$_FILES就能抓到图片了
        if(confirm("确认要?")){
            $.ajax({
                'type':'POST',
                'url':'/xxxxxx', //php接口地址
                'data':formData,
                'processData':false,
                'contentType':false,
                'success':function(data){
                    console.log(data);
                    if(data.status == "success")
                    {
                        window.location.reload();
                    }
                    else
                    {
                        alert(data.message);
                    }
                }
            });
        }
    }

    $(function(){
        var src = $("#img").attr('src');
        loadImageToBlob(src,cbk);
    });
</script>

 

  • 0
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
### 回答1: 可以使用 Spring Boot 中的 MultipartFile 类来实现图片。 首先,在你的 Spring Boot 应用的启动类上加上 @EnableWebMvc 注解,然后在你的 Controller 类中,使用 @RequestParam 注解来接收图片文件,如下所示: ``` @RequestMapping(value="/upload", method=RequestMethod.POST) public String handleFileUpload(@RequestParam("file") MultipartFile file) { // 进行文件上操作 } ``` 然后,可以使用 MultipartFile 的 getBytes() 方法来获取文件的字节数组,并使用 FileOutputStream 将字节数组写入到文件中,就可以完成文件的上操作了。 还有,在你的 HTML 文件中,需要使用 <form> 标签并设置 enctype 为 "multipart/form-data",才能正确的发送文件。 示例代码: ``` <form method="post" action="/upload" enctype="multipart/form-data"> <input type="file" name="file"/> <button type="submit">上</button> </form> ``` 希望这能帮到你! ### 回答2: 在Spring Boot中实现图片可以遵循以下步骤: 1. 在pom.xml文件中导入Spring Boot的web依赖。 ```xml <dependencies> <!-- Spring Boot Web依赖 --> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> </dependencies> ``` 2. 创建一个Controller类,用于处理图片请求。可以使用`@RestController`注解将该类声明为一个控制器,并使用`@PostMapping`注解指定处理POST请求。 ```java @RestController public class ImageController { @PostMapping("/upload") public String uploadImage(@RequestParam("file") MultipartFile file) { // 处理文件上,例如保存文件到本地磁盘或将文件存储到数据库等操作 // 注意:根据实际需求,可能需要进行文件格式验证、文件大小限制等操作 // 返回上成功的消息 return "文件上成功!"; } } ``` 3. 在application.properties中配置文件上的相关属性。可以指定文件上最大大小、临时文件存储路径等。 ```properties # 文件上配置 spring.servlet.multipart.max-file-size=10MB spring.servlet.multipart.max-request-size=10MB spring.servlet.multipart.enabled=true spring.http.multipart.enabled=true spring.servlet.multipart.temp-dir= # 设置临时文件目录 ``` 4. 创建一个HTML页面,用于上图片。页面中使用`<form>`标签创建一个表单,并将enctype属性设置为`multipart/form-data`,以支持文件上。通过`<input>`标签的type属性设置为`file`,用户可以选择要上图片文件。 ```html <form action="/upload" method="post" enctype="multipart/form-data"> <input type="file" name="file"> <input type="submit" value="上"> </form> ``` 5. 运行Spring Boot应用,并访问上图片页面。选择一个图片文件后,点击上按钮即可触发图片请求。Controller类中的`uploadImage`方法将会被调用,可以在该方法中处理文件上操作。 以上就是Spring Boot实现图片的简单示例。需要根据具体需求,进一步完善图片的验证、存储、处理等功能。 ### 回答3: 要使用Spring Boot实现图片,可以按照以下步骤进行操作。 1. 首先,需要在pom.xml文件中添加相关的依赖项,如spring-boot-starter-web、spring-boot-starter-actuator。 2. 在项目的配置文件application.properties中配置上文件的存储路径,如:spring.servlet.multipart.location=/upload。 3. 创建一个控制器类,用于处理上图片的请求。可以使用@Controller注解来标识该类,并使用@RequestParam注解定义文件上参数。 ```java @Controller public class FileUploadController { @RequestMapping(value = "/upload", method = RequestMethod.POST) public String uploadFile(@RequestParam("file") MultipartFile file) { // 执行文件上操作 return "success"; } } ``` 4. 在上述控制器方法中,使用MultipartFile类型的参数来接收上的文件。可以通过调用transferTo()方法将文件保存到指定路径。 ```java @RequestMapping(value = "/upload", method = RequestMethod.POST) public String uploadFile(@RequestParam("file") MultipartFile file) { if (!file.isEmpty()) { try { // 获取文件名 String fileName = file.getOriginalFilename(); // 构建文件保存路径 String filePath = "D:/upload/" + fileName; // 保存文件到指定路径 file.transferTo(new File(filePath)); return "success"; } catch (IOException e) { e.printStackTrace(); return "error"; } } else { return "error"; } } ``` 5. 最后,在前端页面中创建一个表单,用于上文件。可以使用HTML的<input type="file">元素来定义文件选择框,并通过form标签来包裹。 ```html <form action="/upload" method="post" enctype="multipart/form-data"> <input type="file" name="file" /> <input type="submit" value="上" /> </form> ``` 以上就是使用Spring Boot实现图片的基本步骤。需要注意的是,还可以根据实际需求添加文件大小、类型等的校验以及异常处理等功能。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值