package com.stylefeng.guns.modular.api;
|
|
import com.alibaba.fastjson.JSONObject;
|
import com.baomidou.mybatisplus.mapper.EntityWrapper;
|
import com.stylefeng.guns.core.common.constant.JwtConstants;
|
import com.stylefeng.guns.core.shiro.ShiroKit;
|
import com.stylefeng.guns.core.util.ToolUtil;
|
import com.stylefeng.guns.modular.account.server.UserWithdrawalService;
|
import com.stylefeng.guns.modular.account.util.OssUploadUtil;
|
import com.stylefeng.guns.modular.shunfeng.model.DriverRide;
|
import com.stylefeng.guns.modular.shunfeng.service.IDriverRideService;
|
import com.stylefeng.guns.modular.system.model.*;
|
import com.stylefeng.guns.modular.system.service.*;
|
import com.stylefeng.guns.modular.system.util.ResultUtil;
|
import com.stylefeng.guns.modular.system.util.WeChatUtil;
|
import com.stylefeng.guns.modular.system.util.qianyuntong.EmployeeUtil;
|
import com.stylefeng.guns.modular.system.util.qianyuntong.UserUtil;
|
import com.stylefeng.guns.modular.system.util.zhenglian.TokenUtil;
|
import com.stylefeng.guns.modular.system.util.zhenglian.ZhengLianUtil;
|
import com.stylefeng.guns.modular.system.util.zhenglian.model.TokenRequest;
|
import com.stylefeng.guns.modular.system.util.zhenglian.model.TradeTerminalInfo;
|
import com.stylefeng.guns.modular.system.util.zhenglian.model.ZLUserInfo;
|
import com.stylefeng.guns.modular.system.warpper.LoginWarpper;
|
import com.stylefeng.guns.modular.system.warpper.UserInfoWarpper;
|
import com.stylefeng.guns.modular.system.warpper.VerifiedWarpper;
|
import io.swagger.annotations.Api;
|
import io.swagger.annotations.ApiImplicitParam;
|
import io.swagger.annotations.ApiImplicitParams;
|
import io.swagger.annotations.ApiOperation;
|
import org.apache.commons.lang.time.DateUtils;
|
import org.springframework.beans.factory.annotation.Autowired;
|
import org.springframework.data.redis.core.RedisTemplate;
|
import org.springframework.web.bind.annotation.*;
|
|
import javax.annotation.Resource;
|
import javax.servlet.http.HttpServletRequest;
|
import java.io.InputStream;
|
import java.net.InetAddress;
|
import java.net.NetworkInterface;
|
import java.util.Date;
|
import java.util.HashMap;
|
import java.util.Map;
|
|
/**
|
* 用户控制器
|
*/
|
@Api
|
@RestController
|
@RequestMapping("")
|
public class UserInfoController {
|
|
@Autowired
|
private IUserInfoService userInfoService;
|
/*顺风车司机*/
|
@Autowired
|
private IDriverRideService driverRideService;
|
|
@Autowired
|
private IVerifiedService verifiedService;
|
|
@Autowired
|
private ISmsrecordService smsrecordService;
|
|
@Resource
|
private RedisTemplate<String, Object> redisTemplate;
|
|
@Autowired
|
private WeChatUtil weChatUtil;
|
|
@Autowired
|
private IDriverService driverService;
|
|
@Autowired
|
private IRegionService regionService;
|
|
@Autowired
|
private HttpServletRequest request;
|
|
private String salt = "&a.s";
|
|
@Autowired
|
private TDriverPromotionActivityService driverPromotionActivityService;
|
|
|
/**
|
* 获取短信验证码
|
* @param phone
|
* @return
|
*/
|
@ResponseBody
|
@PostMapping("/base/queryCaptcha")
|
@ApiOperation(value = "获取短信验证码", tags = {"用户端-登录"}, notes = "")
|
@ApiImplicitParams({
|
@ApiImplicitParam(value = "手机号码", name = "phone", required = true, dataType = "String"),
|
@ApiImplicitParam(value = "场景类型(1=身份验证,2=登录确认,3=用户注册,4=修改密码)", name = "type", required = true, dataType = "String")
|
})
|
public ResultUtil queryCaptcha(String phone, Integer type){
|
if(ToolUtil.isNotEmpty(phone)){
|
try {
|
return userInfoService.queryCaptcha(phone, type);
|
}catch (Exception e){
|
e.printStackTrace();
|
return ResultUtil.runErr();
|
}
|
}else{
|
return ResultUtil.paranErr();
|
}
|
}
|
|
|
/**
|
* 手机验证码登录
|
* @param phone
|
* @param code
|
* @param registIp
|
* @param registAreaCode
|
* @return
|
*/
|
@ResponseBody
|
@PostMapping("/base/user/captchaLogin")
|
@ApiOperation(value = "手机验证码登录", tags = {"用户端-登录"}, notes = "")
|
@ApiImplicitParams({
|
@ApiImplicitParam(value = "手机号码", name = "phone", required = true, dataType = "String"),
|
@ApiImplicitParam(value = "短信验证码", name = "code", required = true, dataType = "String"),
|
@ApiImplicitParam(value = "ip地址", name = "registIp", required = false, dataType = "String"),
|
@ApiImplicitParam(value = "登录端口-小程序传Applets", name = "loginType", required = false, dataType = "String"),
|
@ApiImplicitParam(value = "当前定位区县行政编号", name = "registAreaCode", required = false, dataType = "String"),
|
})
|
public ResultUtil<LoginWarpper> captchaLogin(String phone, String code, String registIp, String registAreaCode,String loginType,String jsCode){
|
try {
|
return userInfoService.captchaLogin(phone, code, registIp, registAreaCode,loginType);
|
}catch (Exception e){
|
e.printStackTrace();
|
return ResultUtil.runErr();
|
}
|
}
|
|
|
|
|
@ResponseBody
|
@PostMapping("/base/user/oneClickLogin")
|
@ApiOperation(value = "手机一键登录", tags = {"用户端-登录"}, notes = "")
|
@ApiImplicitParams({
|
@ApiImplicitParam(value = "app端SDK获取的登录token。", name = "accessToken", required = true, dataType = "String"),
|
@ApiImplicitParam(value = "ip地址", name = "registIp", required = false, dataType = "String"),
|
@ApiImplicitParam(value = "登录端口-小程序传Applets", name = "loginType", required = false, dataType = "String"),
|
@ApiImplicitParam(value = "当前定位区县行政编号", name = "registAreaCode", required = false, dataType = "String"),
|
@ApiImplicitParam(value = "安卓或者苹果 安卓传android 苹果传ios", name = "androidOrIos", required = false, dataType = "String")
|
})
|
public ResultUtil<LoginWarpper> oneClickLogin(String accessToken, String registIp, String registAreaCode,String loginType,String androidOrIos){
|
try {
|
return userInfoService.oneClickLogin(accessToken, registIp, registAreaCode,loginType,androidOrIos);
|
}catch (Exception e){
|
e.printStackTrace();
|
return ResultUtil.runErr();
|
}
|
}
|
|
/**
|
* 手机验证码登录
|
* @param phone
|
* @param code
|
* @return
|
*/
|
@ResponseBody
|
@PostMapping("/base/user/captchaLogin_")
|
@ApiOperation(value = "手机验证码登录", tags = {"分享专用"}, notes = "")
|
@ApiImplicitParams({
|
@ApiImplicitParam(value = "手机号码", name = "phone", required = true, dataType = "String"),
|
@ApiImplicitParam(value = "短信验证码", name = "code", required = true, dataType = "String"),
|
@ApiImplicitParam(value = "分享的用户id", name = "uid", required = true, dataType = "int"),
|
@ApiImplicitParam(value = "登录端口-小程序传Applets", name = "loginType", required = false, dataType = "String"),
|
@ApiImplicitParam(value = "用户类型(1=用户,2=司机)", name = "type", required = true, dataType = "int"),
|
@ApiImplicitParam(value = "注册类型(1=司机注册,2=用户注册)", name = "userType", required = true, dataType = "int")
|
})
|
public ResultUtil<LoginWarpper> captchaLogin_(String phone, String code, Integer uid, Integer type, Integer userType,String loginType){
|
try {
|
return userInfoService.captchaLogin(phone, code, uid, type, userType,loginType);
|
}catch (Exception e){
|
e.printStackTrace();
|
return ResultUtil.runErr();
|
}
|
}
|
|
|
|
|
|
/**
|
* 账号密码登录
|
* @param phone
|
* @param password
|
* @return
|
*/
|
@ResponseBody
|
@PostMapping("/base/user/userLogin")
|
@ApiOperation(value = "账号密码登录", tags = {"用户端-登录"}, notes = "")
|
@ApiImplicitParams({
|
@ApiImplicitParam(value = "手机号码", name = "phone", required = true, dataType = "String"),
|
@ApiImplicitParam(value = "登录端口-小程序传Applets", name = "loginType", required = false, dataType = "String"),
|
@ApiImplicitParam(value = "登录密码", name = "password", required = true, dataType = "String")
|
})
|
public ResultUtil<LoginWarpper> userLogin(String phone, String password,String loginType){
|
if(ToolUtil.isNotEmpty(phone) && ToolUtil.isNotEmpty(password)){
|
try {
|
return userInfoService.userLogin(phone, password,loginType);
|
}catch (Exception e){
|
e.printStackTrace();
|
return ResultUtil.runErr();
|
}
|
}else{
|
return ResultUtil.paranErr();
|
}
|
}
|
|
|
/**
|
* 忘记密码
|
* @param phone
|
* @param code
|
* @param password
|
* @return
|
*/
|
@ResponseBody
|
@PostMapping("/base/user/forgetPassword")
|
@ApiOperation(value = "忘记密码操作", tags = {"用户端-登录"}, notes = "")
|
@ApiImplicitParams({
|
@ApiImplicitParam(value = "手机号码", name = "phone", required = true, dataType = "String"),
|
@ApiImplicitParam(value = "验证码", name = "code", required = true, dataType = "String"),
|
@ApiImplicitParam(value = "新密码", name = "password", required = true, dataType = "String")
|
})
|
public ResultUtil forgetPassword(String phone, String code, String password){
|
if(ToolUtil.isNotEmpty(phone) && ToolUtil.isNotEmpty(code) && ToolUtil.isNotEmpty(password)){
|
try {
|
return userInfoService.forgetPassword(phone, code, password);
|
|
}catch (Exception e){
|
e.printStackTrace();
|
return ResultUtil.runErr();
|
}
|
}else{
|
return ResultUtil.paranErr();
|
}
|
}
|
|
|
/**
|
* 微信授权登录
|
* @param type 登录端口(1:APP登录,2:小程序)
|
* @param openid 微信openid
|
* @param unionid 微信unionid
|
* @param jscode 小程序登录时的jscode临时凭证
|
* @param registIp ip地址
|
* @param registAreaCode 当前定位区县行政编号(6位)
|
* @return
|
*/
|
@ResponseBody
|
@PostMapping("/base/user/wxLogins")
|
@ApiOperation(value = "微信授权登录", tags = {"用户端-登录"}, notes = "")
|
@ApiImplicitParams({
|
@ApiImplicitParam(value = "登录端口(1:APP,2:小程序)", name = "type", required = true, dataType = "int"),
|
@ApiImplicitParam(value = "微信openid(APP登录上传)", name = "openid", required = false, dataType = "String"),
|
@ApiImplicitParam(value = "微信unionid(APP登录上传)", name = "unionid", required = false, dataType = "String"),
|
@ApiImplicitParam(value = "微信jscode(小程序登录上传)", name = "jscode", required = false, dataType = "String"),
|
@ApiImplicitParam(value = "ip地址", name = "registIp", required = false, dataType = "String"),
|
@ApiImplicitParam(value = "当前定位区县行政编号", name = "registAreaCode", required = true, dataType = "String"),
|
@ApiImplicitParam(value = "头像", name = "avatar", required = false, dataType = "String"),
|
@ApiImplicitParam(value = "昵称", name = "nickName", required = false, dataType = "String"),
|
@ApiImplicitParam(value = "登录端口-小程序传Applets", name = "loginType", required = false, dataType = "String"),
|
@ApiImplicitParam(value = "性别(1=男,2=女)", name = "sex", required = false, dataType = "int"),
|
@ApiImplicitParam(value = "手机号", name = "phone", required = false, dataType = "String"),
|
@ApiImplicitParam(value = "encryptedData", name = "encryptedData", required = false, dataType = "String"),
|
@ApiImplicitParam(value = "iv", name = "iv", required = false, dataType = "String")
|
})
|
public ResultUtil<LoginWarpper> wxLogins(Integer type, String openid, String unionid, String jscode, String registIp, String registAreaCode, Integer sex, String nickName, String avatar,String loginType,String phone,String encryptedData, String iv){
|
try {
|
System.out.println(encryptedData);
|
System.out.println(iv);
|
return userInfoService.wxLogins(type, openid, unionid, jscode, registIp, registAreaCode, sex, nickName, avatar,loginType,phone,encryptedData,iv);
|
}catch (Exception e){
|
e.printStackTrace();
|
return ResultUtil.runErr();
|
}
|
}
|
|
|
|
|
|
@ResponseBody
|
@PostMapping("/base/user/wxLogin")
|
@ApiOperation(value = "微信授权登录", tags = {"用户端-登录"}, notes = "")
|
@ApiImplicitParams({
|
@ApiImplicitParam(value = "登录端口(1:APP,2:小程序)", name = "type", required = true, dataType = "int"),
|
@ApiImplicitParam(value = "微信openid(APP登录上传)", name = "openid", required = false, dataType = "String"),
|
@ApiImplicitParam(value = "微信unionid(APP登录上传)", name = "unionid", required = false, dataType = "String"),
|
@ApiImplicitParam(value = "微信jscode(小程序登录上传)", name = "jscode", required = false, dataType = "String"),
|
@ApiImplicitParam(value = "ip地址", name = "registIp", required = false, dataType = "String"),
|
@ApiImplicitParam(value = "当前定位区县行政编号", name = "registAreaCode", required = true, dataType = "String"),
|
@ApiImplicitParam(value = "头像", name = "avatar", required = false, dataType = "String"),
|
@ApiImplicitParam(value = "昵称", name = "nickName", required = false, dataType = "String"),
|
@ApiImplicitParam(value = "登录端口-小程序传Applets", name = "loginType", required = false, dataType = "String"),
|
@ApiImplicitParam(value = "性别(1=男,2=女)", name = "sex", required = false, dataType = "int")
|
})
|
public ResultUtil<LoginWarpper> wxLogin(Integer type, String openid, String unionid, String jscode, String registIp, String registAreaCode, Integer sex, String nickName, String avatar,String loginType){
|
try {
|
return userInfoService.wxLogin(type, openid, unionid, jscode, registIp, registAreaCode, sex, nickName, avatar,loginType);
|
}catch (Exception e){
|
e.printStackTrace();
|
return ResultUtil.runErr();
|
}
|
}
|
|
|
|
|
|
|
@ResponseBody
|
@PostMapping("/base/user/wxLoginIsBind")
|
@ApiOperation(value = "微信授权登录--查看是否绑定手机号", tags = {"用户端-登录"}, notes = "")
|
@ApiImplicitParams({
|
@ApiImplicitParam(value = "微信jscode(小程序登录上传)", name = "jscode", required = false, dataType = "String"),
|
})
|
public ResultUtil<LoginWarpper> wxLoginIsBind(String jscode){
|
try {
|
return userInfoService.wxLoginIsBind( jscode);
|
}catch (Exception e){
|
e.printStackTrace();
|
return ResultUtil.runErr();
|
}
|
}
|
|
|
|
/**
|
* 设置电话号码
|
* @param phone
|
* @param code
|
* @param request
|
* @return
|
*/
|
@ResponseBody
|
@PostMapping("/api/user/bindingPhone")
|
@ApiOperation(value = "设置电话号码", tags = {"用户端-登录"}, notes = "")
|
@ApiImplicitParams({
|
@ApiImplicitParam(value = "电话号码", name = "phone", required = true, dataType = "String"),
|
@ApiImplicitParam(value = "验证码", name = "code", required = false, dataType = "String"),
|
@ApiImplicitParam(value = "登录端口-小程序传Applets", name = "loginType", required = false, dataType = "String"),
|
@ApiImplicitParam(name = "Authorization", value = "Bearer +token", required = true, dataType = "String", paramType = "header", defaultValue = "Bearer eyJhbGciOiJIUzUxMiJ9.....")
|
})
|
public ResultUtil<LoginWarpper> bindingPhone(String phone, String code, HttpServletRequest request,String loginType){
|
try {
|
Integer uid = userInfoService.getUserIdFormRedis(request);
|
if(null == uid){
|
return ResultUtil.tokenErr();
|
}
|
return userInfoService.bindingPhone(uid, phone, code,loginType);
|
}catch (Exception e){
|
e.printStackTrace();
|
return ResultUtil.runErr();
|
}
|
}
|
/**
|
* 设置绑定司机
|
* @param driverId
|
* @param request
|
* @return
|
*/
|
@ResponseBody
|
@PostMapping("/api/user/bindingDriver")
|
@ApiOperation(value = "绑定司机", tags = {"用户端-登录"}, notes = "")
|
@ApiImplicitParams({
|
@ApiImplicitParam(value = "司机id", name = "driverId", required = true, dataType = "int"),
|
@ApiImplicitParam(name = "Authorization", value = "Bearer +token", required = true, dataType = "String", paramType = "header", defaultValue = "Bearer eyJhbGciOiJIUzUxMiJ9.....")
|
})
|
public ResultUtil<LoginWarpper> bindingDriver(Integer driverId,HttpServletRequest request){
|
try {
|
Integer uid = userInfoService.getUserIdFormRedis(request);
|
if(null == uid){
|
return ResultUtil.tokenErr();
|
}
|
UserInfo userInfo = userInfoService.selectById(uid);
|
Driver driver = driverService.selectById(driverId);
|
// 是否需要绑定司机
|
TDriverPromotionActivity tDriverPromotionActivity = driverPromotionActivityService.selectOne(new EntityWrapper<TDriverPromotionActivity>()
|
.eq("districtCode", driver.getPlaceOfEmployment()).le("startTime", new Date()).ge("endTime", new Date()).last(" limit 1"));
|
System.out.println("111232"+tDriverPromotionActivity);
|
if(tDriverPromotionActivity!=null){
|
System.out.println("11111");
|
if(userInfo.getBindDriverId()==null || userInfo.getBindExpireDate().getTime()<=System.currentTimeMillis()){
|
System.out.println("222222");
|
Integer bindingDays = tDriverPromotionActivity.getBindingDays();
|
// 当前时间+绑定天数
|
Date endTime = DateUtils.addDays(new Date(), bindingDays);
|
userInfo.setBindDriverId(driverId);
|
userInfo.setBindExpireDate(endTime);
|
userInfo.setBindDate(new Date());
|
userInfoService.updateById(userInfo);
|
}
|
}else {
|
Region code = regionService.selectOne(new EntityWrapper<Region>().eq("code", driver.getPlaceOfEmployment()));
|
if(null != code){
|
Region region = regionService.selectById(code.getParentId());
|
TDriverPromotionActivity tDriverPromotionActivity1 = driverPromotionActivityService.selectOne(new EntityWrapper<TDriverPromotionActivity>().eq("cityCode", region.getCode()).le("startTime", new Date()).ge("endTime", new Date()).last(" limit 1"));
|
if(tDriverPromotionActivity1!=null) {
|
if (userInfo.getBindDriverId() == null || userInfo.getBindExpireDate().getTime() <= System.currentTimeMillis()) {
|
Integer bindingDays = tDriverPromotionActivity1.getBindingDays();
|
// 当前时间+绑定天数
|
Date endTime = DateUtils.addDays(new Date(), bindingDays);
|
userInfo.setBindDriverId(driverId);
|
userInfo.setBindExpireDate(endTime);
|
userInfo.setBindDate(new Date());
|
userInfoService.updateById(userInfo);
|
}
|
}
|
}
|
|
}
|
return ResultUtil.success();
|
}catch (Exception e){
|
e.printStackTrace();
|
return ResultUtil.runErr();
|
}
|
}
|
|
|
@Autowired
|
private UserWithdrawalService userWithdrawalService;
|
/**
|
* 获取用户个人信息
|
* @param request
|
* @return
|
*/
|
@ResponseBody
|
@PostMapping("/api/user/queryUserInfo")
|
@ApiOperation(value = "获取用户详情", tags = {"用户端-个人中心"}, notes = "")
|
@ApiImplicitParams({
|
@ApiImplicitParam(name = "Authorization", value = "Bearer +token", required = true, dataType = "String", paramType = "header", defaultValue = "Bearer eyJhbGciOiJIUzUxMiJ9.....")
|
})
|
public ResultUtil<UserInfoWarpper> queryUserInfo(HttpServletRequest request){
|
try {
|
Integer uid = userInfoService.getUserIdFormRedis(request);
|
if(null == uid){
|
return ResultUtil.tokenErr();
|
}
|
UserInfo userInfo = userInfoService.selectById(uid);
|
if(ToolUtil.isEmpty(userInfo.getOnconUUID())){
|
String onconUUIDByMobile = UserUtil.getOnconUUIDByMobile(userInfo.getPhone());
|
userInfo.setOnconUUID(onconUUIDByMobile);
|
userInfoService.updateById(userInfo);
|
}
|
|
Map<String, Object> map = userInfoService.queryUserInfo(uid);
|
UserWithdrawal userWithdrawal1 = userWithdrawalService.selectOne(new EntityWrapper<UserWithdrawal>()
|
.eq("phone", map.get("phone"))
|
.last("LIMIT 1"));
|
if(userWithdrawal1!=null){
|
map.put("isCloud",1);
|
}else {
|
map.put("isCloud",0);
|
}
|
return ResultUtil.success(UserInfoWarpper.getUserInfoWarpper(map));
|
}catch (Exception e){
|
e.printStackTrace();
|
return ResultUtil.runErr();
|
}
|
}
|
|
|
/**
|
* 手机号码获取用户
|
* @param phone
|
* @return
|
*/
|
@ResponseBody
|
@PostMapping("/api/user/queryUser")
|
@ApiOperation(value = "手机号码获取用户", tags = {"用户端-个人中心"}, notes = "")
|
@ApiImplicitParams({
|
@ApiImplicitParam(value = "电话号码", name = "phone", required = true, dataType = "String"),
|
@ApiImplicitParam(name = "Authorization", value = "Bearer +token", required = true, dataType = "String", paramType = "header", defaultValue = "Bearer eyJhbGciOiJIUzUxMiJ9.....")
|
})
|
public ResultUtil<Object> queryUser(String phone){
|
try {
|
Map<String, Object> map = userInfoService.queryUser(phone);
|
if(null != map){
|
UserWithdrawal userWithdrawal1 = userWithdrawalService.selectOne(new EntityWrapper<UserWithdrawal>()
|
.eq("phone", map.get("phone"))
|
.last("LIMIT 1"));
|
if(userWithdrawal1!=null){
|
map.put("isCloud",1);
|
}else {
|
map.put("isCloud",0);
|
}
|
return ResultUtil.success(UserInfoWarpper.getUserInfoWarpper(map));
|
}
|
return ResultUtil.success(new JSONObject());
|
}catch (Exception e){
|
e.printStackTrace();
|
return ResultUtil.runErr();
|
}
|
}
|
|
|
/**
|
* 实名认证操作
|
* @param verifiedWarpper
|
* @param request
|
* @return
|
*/
|
@ResponseBody
|
@PostMapping("/api/user/verified")
|
@ApiOperation(value = "实名认证操作", tags = {"用户端-个人中心"}, notes = "")
|
@ApiImplicitParams({
|
@ApiImplicitParam(name = "Authorization", value = "Bearer +token", required = true, dataType = "String", paramType = "header", defaultValue = "Bearer eyJhbGciOiJIUzUxMiJ9.....")
|
})
|
public ResultUtil verified(VerifiedWarpper verifiedWarpper, HttpServletRequest request){
|
try {
|
Integer uid = userInfoService.getUserIdFormRedis(request);
|
if(null == uid){
|
return ResultUtil.tokenErr();
|
}
|
return verifiedService.verified(VerifiedWarpper.getVerified(verifiedWarpper), uid);
|
}catch (Exception e){
|
e.printStackTrace();
|
return ResultUtil.runErr();
|
}
|
}
|
|
|
/**
|
* 设置紧急联系人
|
* @param name
|
* @param phone
|
* @param request
|
* @return
|
*/
|
@ResponseBody
|
@PostMapping("/api/user/setUrgentUser")
|
@ApiOperation(value = "设置紧急联系人", tags = {"用户端-个人中心"}, notes = "")
|
@ApiImplicitParams({
|
@ApiImplicitParam(value = "姓名,没有传空字符串", name = "name", required = true, dataType = "String"),
|
@ApiImplicitParam(value = "电话号码,没有传空字符串", name = "phone", required = true, dataType = "String"),
|
@ApiImplicitParam(name = "Authorization", value = "Bearer +token", required = true, dataType = "String", paramType = "header", defaultValue = "Bearer eyJhbGciOiJIUzUxMiJ9.....")
|
})
|
public ResultUtil setUrgentUser(String name, String phone, HttpServletRequest request){
|
try {
|
Integer uid = userInfoService.getUserIdFormRedis(request);
|
if(null == uid){
|
return ResultUtil.tokenErr();
|
}
|
userInfoService.setUrgentUser(name, phone, uid);
|
return ResultUtil.success();
|
}catch (Exception e){
|
e.printStackTrace();
|
return ResultUtil.runErr();
|
}
|
}
|
|
|
/**
|
* 用户充值余额
|
* @param payType
|
* @param money
|
* @param request
|
* @return
|
*/
|
@ResponseBody
|
@PostMapping("/api/user/depositBalance")
|
@ApiOperation(value = "余额充值", tags = {"用户端-个人中心"}, notes = "")
|
@ApiImplicitParams({
|
@ApiImplicitParam(value = "支付方式(1=微信,2=支付宝,4-云闪付)", name = "payType", required = true, dataType = "int"),
|
@ApiImplicitParam(value = "充值金额", name = "money", required = true, dataType = "double"),
|
@ApiImplicitParam(value = "支付端(1=用户APP端,2=司机APP端,3=用户小程序端)", name = "type", required = false, dataType = "int"),
|
@ApiImplicitParam(name = "Authorization", value = "Bearer +token", required = true, dataType = "String", paramType = "header", defaultValue = "Bearer eyJhbGciOiJIUzUxMiJ9.....")
|
})
|
public ResultUtil depositBalance(Integer payType, Double money, Integer type, HttpServletRequest request){
|
try {
|
Integer uid = userInfoService.getUserIdFormRedis(request);
|
if(null == uid){
|
return ResultUtil.tokenErr();
|
}
|
return userInfoService.depositBalance(payType, money, uid, type);
|
}catch (Exception e){
|
e.printStackTrace();
|
return ResultUtil.runErr();
|
}
|
}
|
|
|
/**
|
* 修改手机号码
|
* @param code
|
* @param phone
|
* @param request
|
* @return
|
*/
|
@ResponseBody
|
@PostMapping("/api/user/updatePhone")
|
@ApiOperation(value = "修改手机号码", tags = {"用户端-个人中心"}, notes = "")
|
@ApiImplicitParams({
|
@ApiImplicitParam(value = "验证码", name = "code", required = true, dataType = "string"),
|
@ApiImplicitParam(value = "新手机号", name = "phone", required = true, dataType = "string"),
|
@ApiImplicitParam(name = "Authorization", value = "Bearer +token", required = true, dataType = "String", paramType = "header", defaultValue = "Bearer eyJhbGciOiJIUzUxMiJ9.....")
|
})
|
public ResultUtil updatePhone(String code, String phone, HttpServletRequest request){
|
try {
|
Integer uid = userInfoService.getUserIdFormRedis(request);
|
if(null == uid){
|
return ResultUtil.tokenErr();
|
}
|
return userInfoService.updatePhone(code, phone, uid);
|
}catch (Exception e){
|
e.printStackTrace();
|
return ResultUtil.runErr();
|
}
|
}
|
|
@ResponseBody
|
@PostMapping("/api/user/checkCaptcha")
|
@ApiOperation(value = "验证短信验证码", tags = {"用户端-个人中心"}, notes = "1=正确,0=错误")
|
@ApiImplicitParams({
|
@ApiImplicitParam(value = "电话号码", name = "phone", required = true, dataType = "string"),
|
@ApiImplicitParam(value = "短信验证码", name = "code", required = true, dataType = "string"),
|
@ApiImplicitParam(name = "Authorization", value = "Bearer +token", required = true, dataType = "String", paramType = "header", defaultValue = "Bearer eyJhbGciOiJIUzUxMiJ9.....")
|
})
|
public ResultUtil checkCaptcha(String phone, String code, HttpServletRequest request){
|
try {
|
Integer uid = userInfoService.getUserIdFormRedis(request);
|
if(null == uid){
|
return ResultUtil.tokenErr();
|
}
|
UserInfo userInfo = userInfoService.selectById(uid);
|
smsrecordService.saveData(4, userInfo.getPhone(), code, "短信验证码【" + code + "】已发到您的手机,验证码将在5分钟后失效,请及时登录!");
|
boolean b = userInfoService.checkCaptcha(phone, code);
|
Map<String, Object> map = new HashMap<>();
|
map.put("ok", b ? 1 : 0);
|
return ResultUtil.success(map);
|
}catch (Exception e){
|
e.printStackTrace();
|
return ResultUtil.runErr();
|
}
|
}
|
|
|
|
/**
|
* 修改登录密码
|
* @param password
|
* @param request
|
* @return
|
*/
|
@ResponseBody
|
@PostMapping("/api/user/updatePassword")
|
@ApiOperation(value = "修改登录密码", tags = {"用户端-个人中心"}, notes = "")
|
@ApiImplicitParams({
|
@ApiImplicitParam(value = "新密码", name = "password", required = true, dataType = "string"),
|
@ApiImplicitParam(name = "Authorization", value = "Bearer +token", required = true, dataType = "String", paramType = "header", defaultValue = "Bearer eyJhbGciOiJIUzUxMiJ9.....")
|
})
|
public ResultUtil updatePassword(String password, HttpServletRequest request){
|
try {
|
Integer uid = userInfoService.getUserIdFormRedis(request);
|
if(null == uid){
|
return ResultUtil.tokenErr();
|
}
|
return userInfoService.updatePass(password, uid);
|
}catch (Exception e){
|
e.printStackTrace();
|
return ResultUtil.runErr();
|
}
|
}
|
|
|
/**
|
* 修改个人信息
|
* @param avatar
|
* @param nickname
|
* @param sex
|
* @param birthday
|
* @param request
|
* @return
|
*/
|
@ResponseBody
|
@PostMapping("/api/user/updateInfo")
|
@ApiOperation(value = "修改个人信息", tags = {"用户端-个人中心"}, notes = "")
|
@ApiImplicitParams({
|
@ApiImplicitParam(value = "头像", name = "avatar", required = false, dataType = "string"),
|
@ApiImplicitParam(value = "昵称", name = "nickname", required = false, dataType = "string"),
|
@ApiImplicitParam(value = "性别(1=男,2=女)", name = "sex", required = false, dataType = "int"),
|
@ApiImplicitParam(value = "生日(2020-06-15)", name = "birthday", required = false, dataType = "string"),
|
@ApiImplicitParam(name = "Authorization", value = "Bearer +token", required = true, dataType = "String", paramType = "header", defaultValue = "Bearer eyJhbGciOiJIUzUxMiJ9.....")
|
})
|
public ResultUtil updateInfo(String avatar, String nickname, Integer sex, Date birthday, HttpServletRequest request){
|
try {
|
Integer uid = userInfoService.getUserIdFormRedis(request);
|
if(null == uid){
|
return ResultUtil.tokenErr();
|
}
|
userInfoService.updateInfo(avatar, nickname, sex, birthday, uid);
|
return ResultUtil.success();
|
}catch (Exception e){
|
e.printStackTrace();
|
return ResultUtil.runErr();
|
}
|
}
|
|
|
@ResponseBody
|
@PostMapping("/api/user/queryRealName")
|
@ApiOperation(value = "获取实名认证的数据", tags = {"用户端-个人中心"}, notes = "")
|
@ApiImplicitParams({
|
@ApiImplicitParam(name = "Authorization", value = "Bearer +token", required = true, dataType = "String", paramType = "header", defaultValue = "Bearer eyJhbGciOiJIUzUxMiJ9.....")
|
})
|
public ResultUtil queryRealName(HttpServletRequest request){
|
try {
|
Integer uid = userInfoService.getUserIdFormRedis(request);
|
if(null == uid){
|
return ResultUtil.tokenErr();
|
}
|
Map<String, Object> map = userInfoService.queryRealName(uid);
|
return ResultUtil.success(null != map ? map : new HashMap<>());
|
}catch (Exception e){
|
e.printStackTrace();
|
return ResultUtil.runErr();
|
}
|
}
|
|
|
/**
|
* 后台调用禁用用户
|
* @param uid
|
* @return
|
*/
|
@ResponseBody
|
@PostMapping("/base/user/freeze")
|
public ResultUtil freeze(Integer uid){
|
try {
|
UserInfo userInfo = userInfoService.selectById(uid);
|
String value = (String) redisTemplate.opsForValue().get(userInfo.getPhone());
|
redisTemplate.delete(value);
|
redisTemplate.delete(userInfo.getPhone());
|
return ResultUtil.success();
|
}catch (Exception e){
|
e.printStackTrace();
|
return ResultUtil.runErr();
|
}
|
}
|
|
|
/**
|
* 仿socket接口(单点登录)
|
* @param request
|
* @return
|
*/
|
@ResponseBody
|
@PostMapping("/api/user/comparisonToken")
|
@ApiOperation(value = "单点登录", tags = {"用户端-仿socket接口"}, notes = "match=1(匹配),match=2(不匹配)")
|
@ApiImplicitParams({
|
@ApiImplicitParam(name = "Authorization", value = "Bearer +token", required = true, dataType = "String", paramType = "header", defaultValue = "Bearer eyJhbGciOiJIUzUxMiJ9.....")
|
})
|
public ResultUtil comparisonToken(HttpServletRequest request){
|
try {
|
Integer uid = userInfoService.getUserIdFormRedis(request);
|
if(null == uid){
|
return ResultUtil.tokenErr();
|
}
|
String requestHeader = request.getHeader(JwtConstants.AUTH_HEADER);
|
requestHeader = requestHeader.substring(requestHeader.indexOf(" ") + 1);
|
String value = (String) redisTemplate.opsForValue().get("USER_" + uid);
|
Map<String, Object> map = new HashMap<>();
|
map.put("match", requestHeader.equals(value) ? 1 : 2);
|
return ResultUtil.success(map);
|
}catch (Exception e){
|
e.printStackTrace();
|
return ResultUtil.runErr();
|
}
|
}
|
|
/**
|
* 注销账号
|
* @param request
|
* @return
|
*/
|
@ResponseBody
|
@PostMapping("/api/user/cancellation")
|
@ApiOperation(value = "注销账号", tags = {"用户端-个人中心"}, notes = "")
|
@ApiImplicitParams({
|
@ApiImplicitParam(name = "Authorization", value = "Bearer +token", required = true, dataType = "String", paramType = "header", defaultValue = "Bearer eyJhbGciOiJIUzUxMiJ9.....")
|
})
|
public ResultUtil cancellation(HttpServletRequest request){
|
try {
|
Integer uid = userInfoService.getUserIdFormRedis(request);
|
if(null == uid){
|
return ResultUtil.tokenErr();
|
}
|
UserInfo userInfo = userInfoService.selectById(uid);
|
userInfo.setState(2);
|
userInfoService.updateById(userInfo);
|
//开始验证当前账号是否在别处登录
|
String value = (String) redisTemplate.opsForValue().get("USER_" + uid);
|
if(ToolUtil.isNotEmpty(value)) {//将另外设备上的强迫下线
|
//开始清除redis中无效的数据
|
String key = (String) redisTemplate.opsForValue().get("USER_" + userInfo.getPhone());
|
redisTemplate.delete(key);//删除个人信息数据
|
redisTemplate.delete("USER_" + userInfo.getPhone());//删除后台冻结相关缓存
|
redisTemplate.delete("USER_" + uid);//清除存储的token
|
}
|
return ResultUtil.success();
|
}catch (Exception e){
|
e.printStackTrace();
|
return ResultUtil.runErr();
|
}
|
}
|
|
|
|
|
@ResponseBody
|
@PostMapping("/base/user/dxlcLogin")
|
@ApiOperation(value = "道行龙城登录", tags = {"用户端-道行龙城"}, notes = "")
|
@ApiImplicitParams({
|
@ApiImplicitParam(value = "道行龙城获取的授权", name = "authCode", required = true, dataType = "String"),
|
@ApiImplicitParam(value = "登录端口-小程序和H5传Applets", name = "loginType", required = false, dataType = "String"),
|
@ApiImplicitParam(value = "当前定位区县行政编号", name = "registAreaCode", required = false, dataType = "String")
|
})
|
public ResultUtil dxlcLogin(String authCode, String registAreaCode,String loginType){
|
try {
|
return userInfoService.dxlcLogin(authCode, registAreaCode, loginType);
|
}catch (Exception e){
|
e.printStackTrace();
|
return ResultUtil.runErr();
|
}
|
}
|
|
|
@ResponseBody
|
@PostMapping("/base/user/getSignatureConfig")
|
@ApiOperation(value = "获取微信JS-SDK", tags = {"用户端-道行龙城"}, notes = "")
|
@ApiImplicitParams({
|
@ApiImplicitParam(value = "授权地址", name = "url", required = true, dataType = "String"),
|
})
|
public ResultUtil getSignatureConfig(String url){
|
try {
|
Map<String, Object> signatureConfig = weChatUtil.getSignatureConfig(url);
|
return ResultUtil.success(signatureConfig);
|
}catch (Exception e){
|
e.printStackTrace();
|
return ResultUtil.runErr();
|
}
|
}
|
|
/**
|
* 手机号码获取用户
|
* @return
|
*/
|
@ResponseBody
|
@PostMapping("/api/user/phoneLoginBindingWeChat")
|
@ApiOperation(value = "微信小程序手机号登录后调用此接口保存微信openid", tags = {"用户端-登录"}, notes = "")
|
@ApiImplicitParams({
|
@ApiImplicitParam(value = "微信登录临时凭证", name = "jscode", required = true, dataType = "String"),
|
@ApiImplicitParam(name = "Authorization", value = "Bearer +token", required = true, dataType = "String", paramType = "header", defaultValue = "Bearer eyJhbGciOiJIUzUxMiJ9.....")
|
})
|
public ResultUtil phoneLoginBindingWeChat(String jscode, HttpServletRequest request){
|
try {
|
Integer userId = userInfoService.getUserIdFormRedis(request);
|
if(null == userId){
|
return ResultUtil.tokenErr();
|
}
|
return userInfoService.phoneLoginBindingWeChat(userId, jscode);
|
}catch (Exception e){
|
e.printStackTrace();
|
return ResultUtil.runErr();
|
}
|
}
|
|
|
/**
|
* 临时补发注册券
|
* @return
|
*/
|
@ResponseBody
|
@PostMapping("/base/user/reissueCoupon")
|
public ResultUtil reissueCoupon(){
|
try {
|
return userInfoService.reissueCoupon();
|
}catch (Exception e){
|
e.printStackTrace();
|
return ResultUtil.runErr();
|
}
|
}
|
|
|
|
@ResponseBody
|
@GetMapping("/base/user/getDriverCode")
|
@ApiOperation(value = "获取司机端的二维码", tags = {"获取司机端的二维码"}, notes = "")
|
@ApiImplicitParams({
|
@ApiImplicitParam(value = "司机ID", name = "driverId", required = true, dataType = "String"),
|
})
|
public ResultUtil getDriverCode(Integer driverId){
|
try {
|
Driver driver = driverService.selectById(driverId);
|
if(driver!=null){
|
String fileName = driver.getQrCode();
|
if(fileName==null || "".equals(fileName) ){
|
String appletPath = "pages/home/scanPage/scanPage";
|
//HttpURLConnection httpURLConnection = weChatUtil.getwxacodeunlimit(appletPath, "d=" + driverId + "&k=" + 0, "release",driverId);
|
InputStream inputStream = weChatUtil.getwxacodeunlimit(appletPath, "driverId=" + driverId , "release");
|
if(inputStream!=null){
|
fileName = OssUploadUtil.ossUploadByStream(driverId,inputStream);
|
System.out.println(fileName);
|
driver.setQrCode(fileName);
|
driverService.updateById(driver);
|
}
|
}
|
return ResultUtil.success(fileName);
|
}
|
return ResultUtil.runErr();
|
}catch (Exception e){
|
e.printStackTrace();
|
return ResultUtil.runErr();
|
}
|
}
|
|
|
/**
|
* 代驾系统添加用户接口
|
* @param phone
|
* @return
|
*/
|
@ResponseBody
|
@PostMapping("/base/user/addAppUser")
|
public String addAppUser(String phone, String code, String areaCode, String onconUUID){
|
try {
|
return userInfoService.addAppUser(phone, code, areaCode, onconUUID);
|
}catch (Exception e){
|
e.printStackTrace();
|
}
|
return null;
|
}
|
|
/**
|
* 代驾系统验证短信验证码
|
* @param phone
|
* @param code
|
* @param request
|
* @return
|
*/
|
@ResponseBody
|
@PostMapping("/base/user/checkCaptcha")
|
public Boolean checkCaptcha1(String phone, String code, HttpServletRequest request){
|
try {
|
String device = request.getHeader("device");
|
if(ToolUtil.isEmpty(device)){
|
return false;
|
}
|
boolean b = userInfoService.checkCaptcha(phone, code);
|
return b;
|
}catch (Exception e){
|
e.printStackTrace();
|
return false;
|
}
|
}
|
|
/**
|
* 代驾系统验根据用户id获取电话号码
|
* @param id
|
* @return
|
*/
|
@ResponseBody
|
@GetMapping("/base/user/getUserPhone/{id}")
|
public String getUserPhone(@PathVariable("id") Integer id){
|
UserInfo userInfo = userInfoService.selectById(id);
|
if(null != userInfo){
|
return userInfo.getPhone();
|
}
|
return null;
|
}
|
|
|
@ResponseBody
|
@PostMapping("/api/driver/getZLToken")
|
@ApiOperation(value = "获取证联token(黔云通)", tags = {"司机端-首页"}, notes = "")
|
@ApiImplicitParams({
|
@ApiImplicitParam(name = "Authorization", value = "Bearer +token", required = true, dataType = "String", paramType = "header", defaultValue = "Bearer eyJhbGciOiJIUzUxMiJ9....."),
|
@ApiImplicitParam(value = "当前设备IP地址", name = "ip", required = true, dataType = "String"),
|
@ApiImplicitParam(value = "当前设备mac地址", name = "mac", required = true, dataType = "String"),
|
@ApiImplicitParam(value = "01 证联收银台支付\n" +
|
"\t 04 HOME 页\n" +
|
"\t 06 申请免密签约\n" +
|
"\t 07 商户收银台支付\n" +
|
"\t 08 开户(绑卡)\n" +
|
"\t 09 开通支付账户\n" +
|
"\t 10 打开付款码", name = "type", required = true, dataType = "String"),
|
})
|
public ResultUtil<String> getZLToken(String ip, String mac, String type, HttpServletRequest request){
|
try {
|
Integer userId = userInfoService.getUserIdFormRedis(request);
|
if (null == userId) {
|
return ResultUtil.tokenErr();
|
}
|
UserInfo userInfo = userInfoService.selectById(userId);
|
if(null == userInfo.getDriverId()){
|
return ResultUtil.error("请先开通顺风车司机");
|
}
|
if(null == userInfo.getIdCard()){
|
return ResultUtil.error("请先完成实名认证");
|
}
|
DriverRide driverRide = driverRideService.selectById(userInfo.getDriverId());
|
TokenRequest tokenRequest = new TokenRequest();
|
tokenRequest.setAppUserId(driverRide.getEmpId().toString());
|
tokenRequest.setUserName(userInfo.getName());
|
tokenRequest.setCertNo(userInfo.getIdCard());
|
tokenRequest.setPhone(userInfo.getPhone());
|
TradeTerminalInfo tradeTerminalInfo = new TradeTerminalInfo();
|
tradeTerminalInfo.setIp(ip);
|
tradeTerminalInfo.setTerminal("1");
|
tradeTerminalInfo.setMac(mac);
|
tokenRequest.setTradeTerminalInfo(tradeTerminalInfo);
|
tokenRequest.setType(type);
|
String token = TokenUtil.getToken(tokenRequest);
|
return ResultUtil.success(token);
|
}catch (Exception e){
|
e.printStackTrace();
|
return ResultUtil.runErr();
|
}
|
}
|
}
|