锐单电子商城 , 一站式电子元器件采购平台!
  • 电话:400-990-0325

springboot+vue+elementUI用户头像获取

时间:2022-12-21 16:30:00 ogp301光电传感器二极管kpzfxd101套管式温度传感器wtq1050f动态扭矩传感器

springboot vue elementUI获取用户头像

实现思路:

前端带token发请求—>后端解析token,获取用户名,用户ID,根据用户id查base64 图片
code 返回前端。

前端代码:

template:

<img :src=userImg style="width:30px;height:30px;margin-right:15px;margin-top:15px"> 

方法:

   getUserImg(){ 
             this.request(this.url.getUserImg,'get',{ 
        },(response)=>{ 
              // console.log(response.obj.img)      this.userImg=response.obj.img     })    } 

后端代码:

tips:

使用普通数据库varchar类型不能满足要求,图片也不能存储。它在这里使用blob类型,但转换是一个坑,需要重写mapper。

controller:

    @RequestMapping(method = RequestMethod.GET,value = "/getUserImg")     public ResultJson getUserImg(){ 
                 logger.info("获取头像和用户名");         ServletRequestAttributes rsa = (ServletRequestAttributes) RequestContextHolder.getRequestAttributes();         HttpServletRequest request = rsa.getRequest();         String token = request.getHeader("token"); UmsAdminDetail adminDetail = new UmsAdminDetail(); try { 
          UmsAdmin umsAdmin = JWTUtil.deCodeToken(token); if (umsAdmin!=null){ 
          adminDetail = umsAdminDetailService.getByUserId(umsAdmin.getId()); adminDetail.setUserName(umsAdmin.getLoginName()); logger.info(umsAdmin.getLoginName()); logger.info(adminDetail.toString()); if (adminDetail!=null){ 
          String img = new String(adminDetail.getImgCode(), "UTF-8"); if (img!=null){ 
          adminDetail.setImg(img); }else { 
          return ResultJson.error("转换头像失败"); } }else { 
          return ResultJson.error("获取用户信息失败"); } }else { 
          return ResultJson.error("获取用户失败"); } } catch (Exception e) { 
          return ResultJson.error(e.getMessage()); } return ResultJson.success(adminDetail); } 

service实现类:

    @Override
    public UmsAdminDetail getByUserId(Integer id) { 
        
        UmsAdminDetail umsAdminDetail = umsAdminDetailMapper.selectOneByUserId(id);
        return umsAdminDetail;
    }

mapper:

这里自定义了查询结果。转换typeHandler使用mybatis自带的。没有自己写



<mapper namespace="com.wy.mapper.UmsAdminDetailMapper">
    
    <resultMap id="getUmsAdminDetailResultMap" type="com.wy.pojo.UmsAdminDetail">
        <id column="id" property="id"/>
        <result column="user_id" property="userId"/>
        
        <result column="img_code" property="imgCode" typeHandler="org.apache.ibatis.type.BlobTypeHandler"/>
    resultMap>

    
    <select id="selectOneByUserId" resultMap="getUmsAdminDetailResultMap">
        select id,user_id,img_code from ums_admin_detail where 1=1
        
        <if test="id != null">
            and user_id = #{id}
        if>
        limit 1
    select>


    
    <insert id="insertImg" parameterType="com.wy.pojo.UmsAdminDetail">
        insert into ums_admin_detail(user_id,img_code)
        values (#{userId},#{imgCode})
    insert>


mapper>

测试类:

@RunWith作用
@RunWith 就是一个运行器

@RunWith(JUnit4.class) 就是指用JUnit4来运行

@RunWith(SpringJUnit4ClassRunner.class),让测试运行于Spring测试环境

@RunWith(Suite.class) 的话就是一套测试集合,

@ContextConfiguration Spring整合JUnit4测试时,使用注解引入多个配置文件

插入blobDemo:

package com.wy.test;

import com.wy.AdminApp;
import com.wy.mapper.UmsAdminDetailMapper;
import com.wy.pojo.UmsAdminDetail;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;

import javax.annotation.Resource;
import java.io.UnsupportedEncodingException;

@SpringBootTest(classes = { 
        AdminApp.class})
@RunWith(SpringJUnit4ClassRunner.class)

public class BlobTest { 
        
    @Resource
    private UmsAdminDetailMapper adminDetailMapper;
    @Test
    public void test01() throws UnsupportedEncodingException { 
        
        String str = "";
        UmsAdminDetail umsAdminDetail = new UmsAdminDetail();
        umsAdminDetail.setImgCode(str.getBytes());
        umsAdminDetail.setUserId(118);
// adminDetailMapper.insertImg(umsAdminDetail);
        UmsAdminDetail umsAdminDetail1 = adminDetailMapper.selectOneByUserId(118);
        System.out.println(umsAdminDetail1.toString());
        System.out.println(new String(umsAdminDetail1.getImgCode(),"UTF-8") );
    }
}

参考文章

https://blog.csdn.net/wild46cat/article/details/53080500

锐单商城拥有海量元器件数据手册IC替代型号,打造电子元器件IC百科大全!

相关文章