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实现类:

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

mapper:

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

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<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"/><!-- 数据库中字段类型为Blob,所以这里必须加上BlobTypeHandler进行处理 --><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><!-- 添加,类型为Blob =》 添加typeHandler --><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 {@Resourceprivate UmsAdminDetailMapper adminDetailMapper;@Testpublic 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

springboot+vue+elementUI用户头像获取相关推荐

  1. 基于springboot+vue+element-ui开发的大型智慧校园电子班牌系统源码

    Java智慧校园系统源码 智慧学校源码 小程序+电子班牌 开发环境:Java+springboot+vue+element-ui+mysql 有演示,可正常上手项目+正版授权. 智慧校园云平台实现了智 ...

  2. springboot + vue + elementUI项目实战——简洁清新的员工管理系统(一)

    springboot + vue + elementUI + mybatis + redis 清新的员工管理系统 前言   从这期,项目从需求分析开始,一步步实现一个老经典的清新的员工管理系统,适合有 ...

  3. SpringBoot+Vue+ElementUI实现文件上传与文件下载

    作者: Memory(星哥) Wechat:/QQ: 574373426 整理不易,感谢支持,欢迎 收藏 转发 分享 专注IT职业教育多年,学编程找星哥 SpringBoot+Vue+ElementU ...

  4. SpringBoot+Vue+ElementUI实现后台管理系统

    前言 今天学习了如何搭建一个后台管理系统,因此打算记录并总结一下今天的学习内容. 该项目是一个非常好用的后台管理系统模板,代码比较简单,项目功能比较通用,总之就是很推荐初学者学习. 项目的大体项目框架 ...

  5. java计算机毕业设计基于springboot+vue+elementUI的口腔管理平台管理系统(前后端分离)

    项目介绍 口腔卫生是关系民生的一个重要问题.口腔健康会直接影响全身的健康,口腔基本常见的有龋齿,牙周炎等问题,而且人类的牙齿只有2次更换周期,一旦牙齿彻底完成更换终生将不再更换,所以越来越多的人开始关 ...

  6. springboot+vue+Elementui会议室预约管理系统

    通过对当今互联网的发展的方式现状进行调查.统计和分析,明确网上会议室预约系统对于现代企业办公资源管理的方式影响,同时考虑到了未来几年的发展需求,设计了一个界面美观,公共能完善,满足用户需求的会议室预约 ...

  7. 计算机毕业设计springboot+vue+elementUI智慧养老平台

    项目介绍 随着社会的发展我国的人口老龄化严重,为了让这些在年前是给社会做出过贡献的老人老有所依,老有所养,度过一个安详的晚年,很多地方都实现了智慧养老,为此我们通过springboot+vue+ele ...

  8. 基于springboot+vue+elementui的游戏攻略分享平台

    随着时代的发展,越来越多的人喜欢在下班之后躺在沙发上来玩儿一盘儿游戏.但是很多时候人们在玩游戏的时候,并没有一个交流和分享的平台.尤其是对一个新的游戏来说.如何更好的进行交流分享显的尤为重要.游戏攻略 ...

  9. 基于javaweb的调查问卷管理系统(java+springboot+vue+elementui+mysql)

    基于javaweb的调查问卷管理系统(java+springboot+vue+elementui+mysql) 运行环境 Java≥8.MySQL≥5.7.Node.js≥10 开发工具 后端:ecl ...

最新文章

  1. php主机转发ipv6,php实现ipv4转换ipv6
  2. .net开发微信公众平台
  3. SAP Spartacus user和org user form两处不同的checkbox风格
  4. java 匿名对象有引用,封闭对象的引用通过匿名类java进行转义
  5. Myecplise Tomcat 启动很慢
  6. Spring AspectJ Execution 表达式
  7. 一行命令轻松获取JVM默认配置
  8. 坐标偏差大_三坐标常见撞针原因,总结的太到位了!
  9. 阶段3 2.Spring_10.Spring中事务控制_6 spring基于XML的声明式事务控制-配置步骤
  10. JavaScript + jQuery 知识复习总结(附超实用jQuery中文文档)
  11. xrd连续扫描和步进扫描_深度解析XRD
  12. 易语言dchp服务器,易语言模拟DHCP报文源码
  13. 2022Java后端之美团笔试题
  14. ECharts为X轴Y轴添加单位
  15. 社会性动物(艾略特•阿伦森)
  16. DDSM+RetinaNet数据处理进展
  17. 用加密算法给女朋友写封情书
  18. 发现一款好用的在线项目管理工具(有免费版)
  19. 阿里全球数学竞赛赛题曝光!5万余选手奋战三天三夜争夺1%决赛门票
  20. CMYK模式(cmyk模式导出的图片颜色变了)

热门文章

  1. 《人本界面》读书笔记
  2. [springboot一本通]-1.6.开发过程中常用IDEA插件
  3. Linux下最全的redis安装教程
  4. 大学物理·第11章【光学】
  5. 在线 加密解密 工具
  6. CODA数据集 -- 出租车存MySQL源码
  7. matlab中累加的小程序,微信小程序学习用demo:数字累加,动态效果
  8. 浅谈Jmockit使用
  9. 企业微信和个人微信在朋友圈上有何区别?
  10. 集成学习之 如何进行多样性增强