渣渣兔 发表于 2024-8-13 17:30:35

尚医通-阿里云oss-认证接口开发-前端整合(三十二)

目录:
(1)前台用户体系-阿里云OSS先容
(2)阿里云oss代码入门案例
(3)上传文件到阿里云oss-接口开发
(4)用户认证-接口开发
(5)用户认证-前端整合
(1)前台用户体系-阿里云OSS先容
扫码登录后显示用户的昵称,点击下面会显示一些下拉列表,下面完成这些功能 
https://i-blog.csdnimg.cn/blog_migrate/df11a1fc5f32721b92e53bfe83bb914c.png
实名认证:在里面申请某些事情,注册某些软件,需要用到某些功能,需要做一个实名认证,比如说填写你的信息,上传身份证号等等,进行认证,提交之后由平台考核,考核通过之后才能进行预约挂号操作
挂号订单:通过它可以看到当天用户曾经挂了哪些 号,号是什么样的信息
就诊人管理:在挂号的时间可以填写由谁挂号,在注册用户里面可以添加多个就诊人,比如说把父母添加进去,帮他们挂号
先做实名认证功能:需要先相识一个技术:阿里云oss
做实名认证的时间需要,上传一些信息,比如说一个头像,上传身份证的正面,反面信息,上传内容需要存储到服务器里面,阿里云oss就是一个存储服务器,是阿里云为我们提供的一个文件存储体系,方便我们存储,实现文件的上传和下载功能。


[*]阿里云oss
 用户认证需要上传证件图片、首页轮播也需要上传图片,因此我们要做文件服务,阿里云oss是一个很好的分布式文件服务体系,所以我们只需要集成阿里云oss即可
1、开通“对象存储OSS”服务

(1)申请阿里云账号
(2)实名认证
(3)开通“对象存储OSS”服务
(4)进入管理控制台
1.1创建Bucket

选择:标准存储、公共读、不开通
 https://i-blog.csdnimg.cn/blog_migrate/fe5502d36200bfc696bf9cfcecbca1d4.png
1.2上传默认头像

创建文件夹avatar,上传默认的用户头像
https://i-blog.csdnimg.cn/blog_migrate/f14ba0c6979c50e31d901dd3d7def2bb.png

搜索:
https://i-blog.csdnimg.cn/blog_migrate/557207cf230805dd986b1a5472e7e0f4.png https://i-blog.csdnimg.cn/blog_migrate/6a1dfe53fcafb277d81d7695f99ae64d.png
https://i-blog.csdnimg.cn/blog_migrate/aeef4b27e866b325f57631908c31e40e.pnghttps://i-blog.csdnimg.cn/blog_migrate/e6c172eef400914e29a5a70102e48e85.png https://i-blog.csdnimg.cn/blog_migrate/06d3829036847eacb21b64a95820816a.png
创建Bucket:点击Bucket列表:
https://i-blog.csdnimg.cn/blog_migrate/256ec8773d550fb8b1490add9ccc36cb.png 
点击创建Bucket:新用户标准存储免费一段时间
https://i-blog.csdnimg.cn/blog_migrate/1573d53f8bbaaafa8d18bfa4935c7007.png 
 
https://i-blog.csdnimg.cn/blog_migrate/c1cf32d787692e822b9fbc68b8ba62c1.png 点击确定:https://i-blog.csdnimg.cn/blog_migrate/9cc9695bd5090fb8f125723c68f733a2.png
查察这个:下面有Bucket域名 
https://i-blog.csdnimg.cn/blog_migrate/3dc4e8adc1d08476f36732ec47b6111d.png 
 测试以下存储:点击文件管理
https://i-blog.csdnimg.cn/blog_migrate/d65692e63614e9ddd61e82ed83eace07.png
 点击上传文件:
把一个图片拖沓到这里:
https://i-blog.csdnimg.cn/blog_migrate/08f4df425dea88e752ed3cf1b36aec5a.png
https://i-blog.csdnimg.cn/blog_migrate/4997f3b4e5fbb4282867bff70a39917e.png 点击上传文件:
https://i-blog.csdnimg.cn/blog_migrate/a8b75aa307f2bd54f5986e3d38c05234.png
https://i-blog.csdnimg.cn/blog_migrate/19b1baff08e4b5d514850fff77ec3611.png https://i-blog.csdnimg.cn/blog_migrate/bb0376ea8d4c2c4e1f52d404e7ebc5fd.png
点击详情:
https://i-blog.csdnimg.cn/blog_migrate/f7b05ea115d4e6ae27cef2290d28d964.png 
在浏览器输入地址:
https://i-blog.csdnimg.cn/blog_migrate/2d6c818addb6ff4d6f629d18e05360d1.png 
直接下载了这个图片:
https://i-blog.csdnimg.cn/blog_migrate/457d807d32e8e6b3da1fb8efab92ab1d.png 
上面的操作我是通过控制台操作的,在实际的项目中通过代码实现,写代码需要用到 accesskeys:
 https://i-blog.csdnimg.cn/blog_migrate/8c459961f8d630fd8ff3a75163fb7c30.png
 使用当前账户的accessKeys里面的id和秘钥
 https://i-blog.csdnimg.cn/blog_migrate/903ad9624153b62e46cc72ce6b561c09.png
 
 (2)阿里云oss代码入门案例
查察资助文档:
https://i-blog.csdnimg.cn/blog_migrate/fa38b880f64c3e71894c82561f80dc81.png
 https://i-blog.csdnimg.cn/blog_migrate/99efbe775816c116854a08aae44bce99.png
新建 一个Module: 
 https://i-blog.csdnimg.cn/blog_migrate/5f8aef0edd3ece52bf2c3f56553866fd.png
 https://i-blog.csdnimg.cn/blog_migrate/3b0b358bd8d1120c08e6efb07e3cc156.png
https://i-blog.csdnimg.cn/blog_migrate/556bf0b018af3d88b50ecffcb52cd0aa.png https://i-blog.csdnimg.cn/blog_migrate/9f2caf3369b8483e5cc2a71fee4aef8f.png
https://i-blog.csdnimg.cn/blog_migrate/e90a56990a126a1a935881dbd6f82ec5.png 
在这个pom中引入依靠:
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <parent>
      <artifactId>service</artifactId>
      <groupId>com.atguigu</groupId>
      <version>0.0.1-SNAPSHOT</version>
    </parent>
    <modelVersion>4.0.0</modelVersion>

    <artifactId>service_oss</artifactId>

    <dependencies>
      <!-- 阿里云oss依赖 -->
      <dependency>
            <groupId>com.aliyun.oss</groupId>
            <artifactId>aliyun-sdk-oss</artifactId>
      </dependency>

      <!-- 日期工具栏依赖 -->
      <dependency>
            <groupId>joda-time</groupId>
            <artifactId>joda-time</artifactId>
      </dependency>
    </dependencies>


</project> https://i-blog.csdnimg.cn/blog_migrate/04555b04bbc8308d4ed08d2893e6e8fb.png 
 
 创建设置文件:application.properties:
# 服务端口
server.port=8205
# 服务名
spring.application.name=service-oss

#返回json的全局时间格式
spring.jackson.date-format=yyyy-MM-dd HH:mm:ss
spring.jackson.time-zone=GMT+8


# nacos服务地址
spring.cloud.nacos.discovery.server-addr=127.0.0.1:8848

#阿里云存储的配置
aliyun.oss.endpoint=http://oss-cn-beijing.aliyuncs.com
aliyun.oss.accessKeyId=LTAI5tF2Ej79XRwCiYbiNRyR
aliyun.oss.secret=zvSy5n0sifBKZEmD77glgqbOcuiAp8

 创建启动类:
package com.atguigu.yygh.oss;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.boot.autoconfigure.jdbc.DataSourceAutoConfiguration;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;
import org.springframework.context.annotation.ComponentScan;

@SpringBootApplication(exclude = DataSourceAutoConfiguration.class)//取消数据源自动配置,配置文件中没有配置数据库的配置,所以这里需要取消加载数据库的配置
@EnableDiscoveryClient
@ComponentScan(basePackages = {"com.atguigu"})   //配置相同路径可以使用Swagger文档了
public class ServiceOssApplication {
    public static void main(String[] args) {
      SpringApplication.run(ServiceOssApplication.class, args);
    }
}

 设置网关:
https://i-blog.csdnimg.cn/blog_migrate/027119292695d90dd47df3b457a183bb.png
编写测试代码:
https://i-blog.csdnimg.cn/blog_migrate/a4ec2d1813c548283c1e85cd4088dc8a.png
 
 使用java代码创建bucket:
package com.oss.test;

import com.aliyun.oss.OSS;
import com.aliyun.oss.OSSClientBuilder;
import com.aliyun.oss.model.CannedAccessControlList;

public class OssTest {
    public static void main(String[] args) {
      // Endpoint以华东1(杭州)为例,其它Region请按实际情况填写。
      String endpoint = "https://oss-cn-beijing.aliyuncs.com";
      // 阿里云账号AccessKey拥有所有API的访问权限,风险很高。强烈建议您创建并使用RAM用户进行API访问或日常运维,请登录RAM控制台创建RAM用户。
      String accessKeyId = "LTAI5tF2Ej79XRwCiYbiNRyR";
      String accessKeySecret = "zvSy5n0sifBKZEmD77glgqbOcuiAp8";
      // 填写Bucket名称,例如examplebucket。
      String bucketName = "yygh-tetss";

      // 创建OSSClient实例。
      OSS ossClient = new OSSClientBuilder().build(endpoint, accessKeyId, accessKeySecret);

      // 创建存储空间。
      ossClient.createBucket(bucketName);

      // 设置存储空间的读写权限。例如将examplebucket的读写权限ACL设置为公有
      ossClient.setBucketAcl(bucketName, CannedAccessControlList.PublicRead);

      //关闭ossClient
      ossClient.shutdown();
    }
}
 https://i-blog.csdnimg.cn/blog_migrate/a7fbfa31afa272381140d9613339d889.png
查察阿里云页面:乐成创建yygh-tetss名称的Bucket:
https://i-blog.csdnimg.cn/blog_migrate/86926da270018b2fe36292dc66b096ea.pnghttps://i-blog.csdnimg.cn/blog_migrate/684457be555a8a9694e880bf3c8acac9.png 
 (3)上传文件到阿里云oss-接口开发
查察阿里云文档:上传文件:
https://i-blog.csdnimg.cn/blog_migrate/01393ee61ea5c95228f2206d365ecb59.png
 使用文件流作为我们的上传代码:
https://i-blog.csdnimg.cn/blog_migrate/cc2d562ddeb2243fb2a60b8d46941bac.png
 https://i-blog.csdnimg.cn/blog_migrate/75f5be5b7d3df6d598e27e7f071cf92f.png
 
 创建controller:
package com.atguigu.yygh.oss.controller;

import com.atguigu.yygh.common.result.Result;
import com.atguigu.yygh.oss.service.FileService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.multipart.MultipartFile;

@RestController
@RequestMapping("/api/oss/file")
public class FileApiController {

    @Autowired
    private FileService fileService;


    //上传文件到阿里云oss
    @PostMapping("fileUpload")
    public Result fileUpload(MultipartFile file) {
      //获取上传文件
      String url = fileService.upload(file);
      return Result.ok(url);
    }

}
创建service:
package com.atguigu.yygh.oss.service;

import org.springframework.web.multipart.MultipartFile;

public interface FileService {
    //上传文件到阿里云oss
    String upload(MultipartFile file);
}
在配之类中添加:
https://i-blog.csdnimg.cn/blog_migrate/bb551d24e75e46b68cfd187f9df3cf0c.png 
 
添加工具类,获取这些数据:
 
package com.atguigu.yygh.oss.utils;

import org.springframework.beans.factory.InitializingBean;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.stereotype.Component;

@Component
public class ConstantOssPropertiesUtils implements InitializingBean {

    @Value("${aliyun.oss.endpoint}")
    private String endpoint;

    @Value("${aliyun.oss.accessKeyId}")
    private String accessKeyId;

    @Value("${aliyun.oss.secret}")
    private String secret;

    @Value("${aliyun.oss.bucket}")
    private String bucket;

    public static String EDNPOINT;
    public static String ACCESS_KEY_ID;
    public static String SECRECT;
    public static String BUCKET;

    @Override
    public void afterPropertiesSet() throws Exception {
      EDNPOINT=endpoint;
      ACCESS_KEY_ID=accessKeyId;
      SECRECT=secret;
      BUCKET=bucket;
    }
}
实现类:FileServiceImpl 
package com.atguigu.yygh.oss.service.impl;

import com.aliyun.oss.OSS;
import com.aliyun.oss.OSSClientBuilder;
import com.atguigu.yygh.oss.service.FileService;
import com.atguigu.yygh.oss.utils.ConstantOssPropertiesUtils;
import org.joda.time.DateTime;
import org.springframework.stereotype.Service;
import org.springframework.web.multipart.MultipartFile;

import java.io.IOException;
import java.io.InputStream;
import java.util.UUID;

@Service
public class FileServiceImpl implements FileService {

    //上传文件到阿里云oss
    @Override
    public String upload(MultipartFile file) {
      String endpoint = ConstantOssPropertiesUtils.EDNPOINT;//工具类中的地域节点
      String accessKeyId = ConstantOssPropertiesUtils.ACCESS_KEY_ID;//工具类中的access-key
      String accessKeySecret = ConstantOssPropertiesUtils.SECRECT;//工具类中的secrect
      String bucketName = ConstantOssPropertiesUtils.BUCKET;//工具类上的指定的Bucket存储地址
      try {
            // 创建OSSClient实例。
            OSS ossClient = new OSSClientBuilder().build(endpoint, accessKeyId, accessKeySecret);
            // 上传文件流。
            InputStream inputStream = file.getInputStream();
            String fileName = file.getOriginalFilename();

            //生成随机唯一值,使用uuid,添加到文件名称里面,防止相同文件名导致文件覆盖,因为用户上传的文件名可能会一致
            String uuid = UUID.randomUUID().toString().replaceAll("-",""); //把生成的uuid里面的-替换掉
            fileName = uuid+fileName;

            //按照当前日期,创建文件夹2021/02/02/,上传到创建的文件夹里面, 结果形式为:2021/02/02/uuid01.jpg。
            //因为前面引入了依赖joda-time,所以转日期可以直接.toString("yyyy/MM/dd")
            String timeUrl = new DateTime().toString("yyyy/MM/dd");
            fileName = timeUrl+"/"+fileName;

            //调用方法实现上传
            ossClient.putObject(bucketName, fileName, inputStream);
            // 关闭OSSClient。
            ossClient.shutdown();

            //上传之后文件路径格式要和阿里云上面的一致
            // https://yygh-atguigu.oss-cn-beijing.aliyuncs.com/uuid01.jpg
            String url = "https://"+bucketName+"."+endpoint+"/"+fileName;
            //返回
            return url;
      } catch (IOException e) {
            e.printStackTrace();
            return null;
      }
    }

}
使用swaggert文档进行测试:
https://i-blog.csdnimg.cn/blog_migrate/31bb325e7095f4d66c216217a50efa2c.png
https://i-blog.csdnimg.cn/blog_migrate/45080423576ecba520ebd8825f4fd834.png 选择文件上传:
https://i-blog.csdnimg.cn/blog_migrate/c908c046cde86199ed95cb6fa0b5febd.png 
https://i-blog.csdnimg.cn/blog_migrate/4813aec8a0ce2df5f4140ce1a0aad769.png 在Bucket中乐成上传:
https://i-blog.csdnimg.cn/blog_migrate/095fb9ee21e10c3993af836433107cbb.png
https://i-blog.csdnimg.cn/blog_migrate/742ba1e07ff5a3e0b96ed37e591db7ed.png  
https://i-blog.csdnimg.cn/blog_migrate/139a29c42a6c7b02965a9a1f433f0e28.png
 (4)用户认证-接口开发
 
需求分析
用户登录乐成后都要进行身份认证,认证通事后才可以预约挂号
认证过程:用户填写信息(姓名、证件类型、证件号码和证件照片)==> 平台审批
用户认证设计接口:

[*]提交认证
[*]上传证件图片
[*]获取提交认证信息
 
 起首创建一个工具类,获取用户的信息,这个工具类,在别的地方可能会用到,所以放在common-utils模块中:
创建utils:
https://i-blog.csdnimg.cn/blog_migrate/64d22567a04a39a7764372359b130dfc.png
package com.atguigu.yygh.common.utils;

import com.atguigu.yygh.common.helper.JwtHelper;

import javax.servlet.http.HttpServletRequest;

//获取当前用户信息工具类
public class AuthContextHolder {

    //获取当前用户id
    public static Long getUserId(HttpServletRequest request) {
      //从header获取token
      String token = request.getHeader("token");
      //jwt从token获取userid
      Long userId = JwtHelper.getUserId(token);
      return userId;
    }

    //获取当前用户名称
    public static String getUserName(HttpServletRequest request) {
      //从header获取token
      String token = request.getHeader("token");
      //jwt从token获取userid
      String userName = JwtHelper.getUserName(token);
      return userName;
    }
}
 用户认证的操作在service-user中进行编写:
创建认证的实体类:封装的条件
https://i-blog.csdnimg.cn/blog_migrate/79644c7ed2cb8a1d8a20df9409578bc8.png
UserAuthVo : 
package com.atguigu.yygh.vo.user;

import com.baomidou.mybatisplus.annotation.TableField;
import io.swagger.annotations.ApiModel;
import io.swagger.annotations.ApiModelProperty;
import lombok.Data;

@Data
@ApiModel(description="会员认证对象")
public class UserAuthVo {

    @ApiModelProperty(value = "用户姓名")
    @TableField("name")
    private String name;

    @ApiModelProperty(value = "证件类型")
    @TableField("certificates_type")
    private String certificatesType;

    @ApiModelProperty(value = "证件编号")
    @TableField("certificates_no")
    private String certificatesNo;

    @ApiModelProperty(value = "证件路径")
    @TableField("certificates_url")
    private String certificatesUrl;

}
 在UserInfoApiController:继续添加接口访问:用户认证接口:
//用户认证接口
    @PostMapping("auth/userAuth")
    public Result userAuth(@RequestBody UserAuthVo userAuthVo, HttpServletRequest request) {
      //其实就是往user_info补充添加一些认证数据进去,根据id查出记录会修改记录
      //传递两个参数,第一个参数用户id,第二个参数认证数据vo对象
      userInfoService.userAuth(AuthContextHolder.getUserId(request),userAuthVo);
      return Result.ok();
    }  service接口:UserInfoService 
https://i-blog.csdnimg.cn/blog_migrate/679cd68c116f7d1568c9575af3c52bc2.png
package com.atguigu.yygh.user.service;

import com.atguigu.yygh.model.user.UserInfo;
import com.atguigu.yygh.vo.user.LoginVo;
import com.atguigu.yygh.vo.user.UserAuthVo;
import com.baomidou.mybatisplus.extension.service.IService;

import java.util.Map;

public interface UserInfoService extends IService<UserInfo> {
    //用户手机登录接口
    Map<String, Object> login(LoginVo loginVo);

    //根据openid判断数据库是否存在微信的扫描人信息
    UserInfo selectWxInfoOpenId(String openid);

    //用户认证接口
    void userAuth(Long userId, UserAuthVo userAuthVo);
}
 实现类:UserInfoService Impl:
//用户认证接口
    @Override
    public void userAuth(Long userId, UserAuthVo userAuthVo) {
      //刚开始数据库中有这条用户信息,只是信息不完善,需要先把他查询出来,在进行更新
      //根据用户id查询用户信息
      UserInfo userInfo = baseMapper.selectById(userId);
      //设置认证信息
      //认证人姓名
      userInfo.setName(userAuthVo.getName());
      //其他认证信息
      userInfo.setCertificatesType(userAuthVo.getCertificatesType());
      userInfo.setCertificatesNo(userAuthVo.getCertificatesNo());
      userInfo.setCertificatesUrl(userAuthVo.getCertificatesUrl());
      userInfo.setAuthStatus(AuthStatusEnum.AUTH_RUN.getStatus());
      //进行信息更新
      baseMapper.updateById(userInfo);
    } 就是更新表中字段的其他信息:
https://i-blog.csdnimg.cn/blog_migrate/be96c6d2ddf3c69367982e5768d66a82.png
在UserInfoApiController:中继续添加用去用户信息接口
https://i-blog.csdnimg.cn/blog_migrate/e5f35f881ac039585980939101a4bebe.png
 
package com.atguigu.yygh.user.controller;import com.atguigu.yygh.common.result.Result;import com.atguigu.yygh.common.utils.AuthContextHolder;import com.atguigu.yygh.model.user.UserInfo;import com.atguigu.yygh.user.service.UserInfoService;import com.atguigu.yygh.vo.user.LoginVo;import com.atguigu.yygh.vo.user.UserAuthVo;import io.swagger.annotations.ApiOperation;import org.springframework.beans.factory.annotation.Autowired;import org.springframework.web.bind.annotation.*;import javax.servlet.http.HttpServletRequest;import java.util.Map;@RestController@RequestMapping("/api/user")public class UserInfoApiController {    @Autowired    private UserInfoService userInfoService;    //用户手机登录接口    @ApiOperation(value = "用户登录")    @PostMapping("login")    public Result login(@RequestBody LoginVo loginVo) {      Map<String, Object> info = userInfoService.login(loginVo);      return Result.ok(info);    }    //用户认证接口
    @PostMapping("auth/userAuth")
    public Result userAuth(@RequestBody UserAuthVo userAuthVo, HttpServletRequest request) {
      //其实就是往user_info补充添加一些认证数据进去,根据id查出记录会修改记录
      //传递两个参数,第一个参数用户id,第二个参数认证数据vo对象
      userInfoService.userAuth(AuthContextHolder.getUserId(request),userAuthVo);
      return Result.ok();
    }    //用户id获取信息接口    @GetMapping("auth/getUserInfo")    public Result getUserInfo(HttpServletRequest request) {      Long userId = AuthContextHolder.getUserId(request);      UserInfo userInfo = userInfoService.getById(userId);      return Result.ok(userInfo);    }} (5)用户认证-前端整合
https://i-blog.csdnimg.cn/blog_migrate/bd2ba00a88bfaadf7151d0452f9c2029.png
 https://i-blog.csdnimg.cn/blog_migrate/877a8038afb798221b9e0accef1b5ccd.png
在userInfo.js中继续添加两个路径 :
https://i-blog.csdnimg.cn/blog_migrate/0ba4497b43a97b17cd0e7641dde04f44.png
 在page目录下创建
https://i-blog.csdnimg.cn/blog_migrate/9dc498a1ad7456bdcf0bce6128ae7a41.png
 
<template>
<!-- header -->
<div class="nav-container page-component">
    <!--左侧导航 #start -->
    <div class="nav left-nav">
      <div class="nav-item selected">
      <span
          class="v-link selected dark"
          onclick="javascript:window.location='/user'"
          >实名认证
      </span>
      </div>
      <div class="nav-item">
      <span
          class="v-link selected dark"
          onclick="javascript:window.location='/order'"
      >
          挂号订单
      </span>
      </div>
      <div class="nav-item">
      <span
          class="v-link clickable dark"
          onclick="javascript:window.location='/patient'"
      >
          就诊人管理
      </span>
      </div>
      <div class="nav-item">
      <span class="v-link clickable dark"> 修改账号信息 </span>
      </div>
      <div class="nav-item">
      <span class="v-link clickable dark"> 意见反馈 </span>
      </div>
    </div>
    <!-- 左侧导航 #end -->
    <!-- 右侧内容 #start -->
    <div class="page-container">
      <div>
      <div class="title">实名认证</div>
      <div class="status-bar">
          <div class="status-wrapper">
            <span class="iconfont"></span>{{ userInfo.param.authStatusString }}
          </div>
      </div>
      <div class="tips">
          <span class="iconfont"></span>
          完成实名认证后才能添加就诊人,正常进行挂号,为了不影响后续步骤,建议提前实名认证。
      </div>
      <div class="form-wrapper" v-if="userInfo.authStatus == 0">
          <div>
            <el-form
            :model="userAuah"
            label-width="110px"
            label-position="left"
            >
            <el-form-item prop="name" label="姓名:" class="form-normal">
                <div class="name-input">
                  <el-input
                  v-model="userAuah.name"
                  placeholder="请输入联系人姓名全称"
                  class="input v-input"
                  />
                </div>
            </el-form-item>
            <el-form-item prop="certificatesType" label="证件类型:">
                <el-select
                  v-model="userAuah.certificatesType"
                  placeholder="请选择证件类型"
                  class="v-select patient-select"
                >
                  <el-option
                  v-for="item in certificatesTypeList"
                  :key="item.value"
                  :label="item.name"
                  :value="item.name"
                  >
                  </el-option>
                </el-select>
            </el-form-item>
            <el-form-item prop="certificatesNo" label="证件号码:">
                <el-input
                  v-model="userAuah.certificatesNo"
                  placeholder="请输入联系人证件号码"
                  class="input v-input"
                />
            </el-form-item>
            <el-form-item prop="name" label="上传证件:">
                <div class="upload-wrapper">
                  <div class="avatar-uploader">
                  <el-upload
                      class="avatar-uploader"
                      :action="fileUrl"
                      :show-file-list="false"
                      :on-success="onUploadSuccess"
                  >
                      <div class="upload-inner-wrapper">
                        <img
                        v-if="userAuah.certificatesUrl"
                        :src="userAuah.certificatesUrl"
                        class="avatar"
                        />
                        <i v-else class="el-icon-plus avatar-uploader-icon"></i>
                        <div v-if="!userAuah.certificatesUrl" class="text">
                        上传证件合照
                        </div>
                      </div>
                  </el-upload>
                  </div>
                  <img
                  src="//img.114yygh.com/static/web/auth_example.png"
                  class="example"
                  />
                </div>
            </el-form-item>
            </el-form>
            <div class="bottom-wrapper">
            <div class="button-wrapper">
                <div class="v-button" @click="saveUserAuah()">
                  {{ submitBnt }}
                </div>
            </div>
            </div>
          </div>
      </div>
      <div class="context-container" v-if="userInfo.authStatus != 0">
          <div>
            <el-form
            :model="formData"
            label-width="110px"
            label-position="right"
            >
            <el-form-item prop="name" label="姓名:" class="form-normal">
                <div class="name-input">
                  {{ userInfo.name }}
                </div>
            </el-form-item>
            <el-form-item prop="name" label="证件类型:">
                {{ userInfo.certificatesType }}
            </el-form-item>
            <el-form-item prop="name" label="证件号码:">
                {{ userInfo.certificatesNo }}
            </el-form-item>
            </el-form>
          </div>
      </div>
      </div>
    </div>
    <!-- 右侧内容 #end -->
    <!-- 登录弹出框 -->
</div>
<!-- footer -->
</template>
   
    <script>
import "~/assets/css/hospital_personal.css";
import "~/assets/css/hospital.css";
import "~/assets/css/personal.css";
import dictApi from "@/api/dict";
import userInfoApi from "@/api/userInfo";
const defaultForm = {
name: "",
certificatesType: "", //证件类型
certificatesNo: "", //证件编号
certificatesUrl: "", //
};
export default {
data() {
    return {
      userAuah: defaultForm,
      certificatesTypeList: [],
      fileUrl: "http://localhost/api/oss/file/fileUpload",
      userInfo: {
      param: {},
      },
      submitBnt: "提交",
    };
},
created() {
    this.init();
},
methods: {
    init() {
      this.getUserInfo(); //得到用户信息
      this.getDict(); //得到字典信息
    },
    //得到用户信息
    getUserInfo() {
      userInfoApi.getUserInfo().then((response) => {
      this.userInfo = response.data;
      });
    },
    //认证操作方法
    saveUserAuah() {
      if (this.submitBnt == "正在提交...") {
      this.$message.info("重复提交");
      return;
      }
      this.submitBnt = "正在提交...";
      userInfoApi
      .saveUserAuah(this.userAuah)
      .then((response) => {
          this.$message.success("提交成功");
          window.location.reload();
      })
      .catch((e) => {
          this.submitBnt = "提交";
      });
    },
    getDict() {
      dictApi.findByDictCode("CertificatesType").then((response) => {
      this.certificatesTypeList = response.data;
      });
    },
    onUploadSuccess(response, file) {
      if (response.code !== 200) {
      this.$message.error("上传失败");
      return;
      }
      // 填充上传文件列表
      this.userAuah.certificatesUrl = file.response.data;
    },
},
};
</script>
    <style>
.header-wrapper .title {
font-size: 16px;
margin-top: 0;
}
.content-wrapper {
margin-left: 0;
}
.patient-card .el-card__header .detail {
font-size: 14px;
}
.page-container .title {
letter-spacing: 1px;
font-weight: 700;
color: #333;
font-size: 16px;
margin-top: 0;
margin-bottom: 20px;
}
.page-container .tips {
width: 100%;
padding-left: 0;
}
.page-container .form-wrapper {
padding-left: 92px;
width: 580px;
}
.form-normal {
height: 40px;
}
.bottom-wrapper {
width: 100%;
padding: 0;
margin-top: 0;
}
</style> https://i-blog.csdnimg.cn/blog_migrate/df11a1fc5f32721b92e53bfe83bb914c.png
https://i-blog.csdnimg.cn/blog_migrate/3d432fd407831a93793a237e2acf987d.png 
https://i-blog.csdnimg.cn/blog_migrate/dd915d92545a6a1f64163e6081dae76c.png 
 https://i-blog.csdnimg.cn/blog_migrate/5f66fe7c125fddfd8bd04648634c9f42.png
 https://i-blog.csdnimg.cn/blog_migrate/74272070351c6b0c17305287b27f106a.png
 点击提交:
https://i-blog.csdnimg.cn/blog_migrate/a7fbc786651605ba10a1b7275f60f81b.png
 数据库中:user_info:中的登录的用户数据乐成进行了认证,数据进行了更新
https://i-blog.csdnimg.cn/blog_migrate/1f17a92ccd83ec8eb660289355ca56de.png
https://i-blog.csdnimg.cn/blog_migrate/e4061cc459891c623a72e61e77a95eb0.png 
 


免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
页: [1]
查看完整版本: 尚医通-阿里云oss-认证接口开发-前端整合(三十二)