实现Base64转PNG图片存储在服务器,并通过 Nginx 映射服务器图片地址实现更换用户头像功能

本文介绍了如何处理前端上传的Base64编码的PNG图片,将其转换并存储在服务器上。利用Java IO处理Base64字符串,结合Spring MVC实现图片保存。同时,通过Nginx配置映射服务器图片路径,实现在用户头像功能中的应用。文章还展示了接口实现、业务逻辑、Nginx配置以及部署和测试过程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

前端页面将图片转为png的Base64字符传输到后台,我们需要处理字符,将 base64 转为以 png 为文件扩展名的图片,用 Nginx 映射资源

这是我们的用户头像

这是我们要修改的头像

下面是我的接口实现

@PostMapping("/v2/user/upimg")
public Object  upNewImage(@RequestBody JSONObject payLoad){
   
   
    return memberService.setMemberImage(payLoad.getString("userToken"),
                payLoad.getString("img"),payLoad.getString("url"));
}

下面使我们的业务实现


	@Autowired
	EzblockMemberMapper ezblockMemberMapper;

	@Autowired
    redisService redis;
	
	public Map<String, String> setMemberImage(String userToken, String baseImage, String url) {
   
   
        try{
   
   
        	// 判断token是否有效 返回用户Id
            Integer id = ezblockMemberMapper.getUserIdByUserToken(userToken);
            if(id!=null && id 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值