base64加密图片上传至腾讯云cos服务器

下面是图片上传的逻辑:

import java.io.UnsupportedEncodingException;
import java.util.UUID;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.util.Base64Utils;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;
import com.platform.app.document.service.impl.ElectronicPolicyServiceImpl;
import com.platform.tools.utils.COSClientUtil;


@RestController
public class UploadController {

	private Logger logger = LoggerFactory.getLogger(ElectronicPolicyServiceImpl.class);
	/**
	 * 上传图片至腾讯云cos
	 * @param base64Img     base64加密图片数据
	 * @param strName      上传图片的后缀类型,例如:.jpg
	 * @return url         图片在cos上的url
	 */ 
	@RequestMapping(value = "/admin/upload", method = RequestMethod.POST)
	public String upload(@RequestParam("base64Img") String base64Img, @RequestParam("strName") String strName) {
		logger.info("base64加密图片数据:"+base64Img.toString());
		logger.info("上传图片的后缀类型:"+strName.toString());
		
		// 获取base64加密内容
        String fileImg = base64Img.split(",")[1];
		byte[] bytes = null;
		try {
			// 解密base64,转换成数组
			bytes = Base64Utils.decode(fileImg.getBytes("UTF-8"));
		} catch (UnsupportedEncodingException e) {
			e.printStackTrace();
		}
		// 图片的名称用uuid生成
		strName = UUID.randomUUID().toString()+"."+strName;
		// 调用工具类上传图片
		COSClientUtil cosClientUtil = new COSClientUtil();
		// 返回图片在cos服务器上的url
		String url = cosClientUtil.uploadFile(bytes, strName);
		logger.info("图片在cos服务器上的url:"+url.toString());
		return url;
	}
}

下面是工具类:

public static String uploadFile(byte[] bytes, String fileName) {
		String backUrl = "";

		// String bucket = BUCKETNAME + "-" + APPID;
		// String bucket="claim-1252337168";
		System.out.println(BUCKETNAME);
		String key = KEY + fileName;

		ObjectMetadata metadata = new ObjectMetadata();
		// metadata.setContentType("image/jpeg");

		metadata.setContentLength(bytes.length);
		PutObjectRequest putObjectRequest = new PutObjectRequest(BUCKETNAME, key, new ByteArrayInputStream(bytes),
				metadata);

		// 设置存储类型, 默认是标准(Standard), 低频(standard_ia)
		putObjectRequest.setStorageClass(StorageClass.Standard_IA);
		COSClient cc = getCosClient();
		try {
			PutObjectResult putObjectResult = cc.putObject(putObjectRequest);
			// putobjectResult会返回文件的etag
			backUrl = host + "/" + key;
			System.out.println(backUrl);
			return backUrl;
		} catch (CosServiceException e) {
			e.printStackTrace();
		} catch (CosClientException e) {
			e.printStackTrace();
		}
		// 关闭客户端
		cc.shutdown();

		return backUrl;
	}

其中有个坑困扰了我一下午;

上传图片方法的参数有2个:

base64Img:base64加密图片数据

strName:上传图片的后缀类型,例如:.jpg

而图片经过base64加密之后会生成一串字符串,大致是下面的数据格式:

data:image/jpeg;base64,/9j/4AAQSkZJRgABAQEAYABgAAD/2wBDAAkGBggGBQkIBwgKCQkKDRYODQwMDRoTFBAWHxwhIB8cHh4jJzIqIyUvJR4eKzssLzM1ODg4ISo9QTw2QTI3ODX/2wBDAQkKCg0LDRkODhk1JB4kNTU1NTU1NTU

 不经过处理将上图的数据当成参数base64Img传入,会一直报错:Illegal base64 character a ;百度给的建议是换个base64解密的方法;在经过N多次尝试后,依然报错;

后来请教大神发现是传入的base64参数有问题,但是不会直接报参数问题;

base64加密后会生成一个头信息“data:image/jpeg;base64,” 需要将此信息去掉才是真正的base64数据信息;

上面是完整的上传图片至腾讯云cos服务器的代码,希望有用~

  • 0
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
ThinkPHP 是一款流行的 PHP 框架,它提供了丰富的功能和便利的API来处理文件上传。将Base64编码的图片上传服务器,你可以按照以下步骤操作: 1. **解码Base64字符串:** 首先,你需要将Base64编码的图片数据转换回原始二进制格式。这可以通过PHP内置的`base64_decode()`函数完成。 ```php $data = base64_decode($base64ImageString); ``` 2. **获取文件名或随机生成:** 为上传的文件创建一个唯一的文件名,可以使用当前时间戳或者随机字符串。 ```php $filename = time() . '_' . md5(rand(0, 999999)) . '.jpg'; ``` 3. **设置临时保存路径:** 在服务器上设置一个临时目录来存储上传的文件,直到正式保存到目标位置。 ```php $tmpPath = '/path/to/your/upload/temporary/directory/'; $tmpFile = $tmpPath . $filename; ``` 4. **保存文件:** 使用PHP的`file_put_contents()`函数将解码后的二进制数据写入临时文件。 ```php file_put_contents($tmpFile, $data); ``` 5. **调用ThinkPHP的上传方法:** ThinkPHP提供了`upload()`方法,用于处理文件上传,包括验证、移动文件等。在这个方法中,指定临时目录和目标目录(通常是public/upload目录)。 ```php $upload = new \Think\File\Upload(); $upload->save(array( 'rootPath' => 'public/upload/', 'tempName' => $tmpFile, 'saveName' => $filename, 'maxSize' => 1048576 // 设置最大上传文件大小 )); ``` 6. **检查上传结果:** `upload()`方法会返回一个包含上传信息的数组,检查`status`字段是否为0(成功)。 ```php if ($upload['status'] == 0) { // 上传成功,将文件移动到目标位置 $targetFile = $upload['savePath'] . $upload['saveName']; rename($tmpFile, $targetFile); } else { // 处理上传失败的情况 } ```

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值