package com.nq.controller; import cn.hutool.core.util.ObjectUtil; import com.nq.common.ServerResponse; import com.nq.dao.SiteBannerMapper; import com.nq.dao.UserMapper; import com.nq.pojo.SiteBanner; import com.nq.pojo.SiteSpread; import com.nq.pojo.User; import com.nq.service.ISiteSpreadService; import com.nq.service.IUserService; import com.nq.utils.PropertiesUtil; import com.nq.utils.redis.CookieUtils; import com.nq.utils.redis.JsonUtil; import com.nq.utils.redis.RedisConst; import com.nq.utils.redis.RedisShardedPoolUtils; import com.nq.vo.user.UserLoginResultVO; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import javax.servlet.http.HttpSession; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Controller; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RequestMethod; import org.springframework.web.bind.annotation.RequestParam; import org.springframework.web.bind.annotation.ResponseBody; import java.math.BigDecimal; import java.util.List; @Controller @RequestMapping({"/api/user/"}) public class UserApiController { private static final Logger log = LoggerFactory.getLogger(UserApiController.class); @Autowired IUserService iUserService; @Autowired UserMapper userMapper; @Autowired ISiteSpreadService iSiteSpreadService; @Autowired SiteBannerMapper siteBannerMapper; //注册 @RequestMapping(value = {"reg.do"}, method = {RequestMethod.POST}) @ResponseBody public ServerResponse reg( @RequestParam("phone") String phone, @RequestParam("userPwd") String userPwd, HttpServletRequest httpServletRequest) { return this.iUserService.reg(phone, userPwd, httpServletRequest); } //修改头像 @RequestMapping(value = {"updatePhoto.do"}, method = {RequestMethod.POST}) @ResponseBody public ServerResponse updatePhoto(@RequestParam("userId") String userId, @RequestParam("photoUrl") String photoUrl,HttpServletRequest httpServletRequest) { User user = userMapper.selectById(userId); if(ObjectUtil.isEmpty(user)){ return ServerResponse.createByErrorMsg("用户不存在!"); } user.setPhotoUrl(photoUrl); userMapper.updateById(user); return ServerResponse.createBySuccess(); } //登录 @RequestMapping(value = {"login.do"}, method = {RequestMethod.POST}) @ResponseBody public ServerResponse login(@RequestParam("phone") String phone, @RequestParam("userPwd") String userPwd, HttpSession httpSession, HttpServletRequest request, HttpServletResponse response) { String pc_cookie_name = PropertiesUtil.getProperty("user.cookie.name"); String token = RedisConst.getUserRedisKey(httpSession.getId()); ServerResponse serverResponse = this.iUserService.login(phone, userPwd, request); if (serverResponse.isSuccess()) { CookieUtils.writeLoginToken(response, token, pc_cookie_name); String redisSetExResult = RedisShardedPoolUtils.setEx(token, JsonUtil.obj2String(serverResponse.getData()), 9999); log.info("redis setex user result : {}", redisSetExResult); UserLoginResultVO resultVO = new UserLoginResultVO(); resultVO.setKey(pc_cookie_name); resultVO.setToken(token); return ServerResponse.createBySuccess("登陆成功", resultVO); } return serverResponse; } //注销 @RequestMapping({"logout.do"}) @ResponseBody public ServerResponse logout(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse) { String cookie_name = PropertiesUtil.getProperty("user.cookie.name"); String logintoken = CookieUtils.readLoginToken(httpServletRequest, cookie_name); log.info("用户 token = {} ,退出登陆", logintoken); RedisShardedPoolUtils.del(logintoken); CookieUtils.delLoginToken(httpServletRequest, httpServletResponse, cookie_name); return ServerResponse.createBySuccess(); } //查询手机号是否存在 @RequestMapping({"checkPhone.do"}) @ResponseBody public ServerResponse checkPhone(String phoneNum) { return this.iUserService.checkPhone(phoneNum); } //找回密码 @RequestMapping({"updatePwd.do"}) @ResponseBody public ServerResponse updatePwd(String phoneNum, String code, String newPwd) { return this.iUserService.updatePwd(phoneNum, code, newPwd); } /** * 查询点差费率 * @author lr * @date 2020/07/01 * applies:涨跌幅 * turnover:成交额 * code:股票代码 * unitprice:股票单价 **/ @RequestMapping({"findSpreadRateOne.do"}) @ResponseBody public ServerResponse findSpreadRateOne(BigDecimal applies, BigDecimal turnover, String code, BigDecimal unitprice) { SiteSpread siteSpread = this.iSiteSpreadService.findSpreadRateOne(applies,turnover,code,unitprice); return ServerResponse.createBySuccess("获取成功", siteSpread); } @RequestMapping({"getSiteBanner.do"}) @ResponseBody public ServerResponse getSiteBanner() { List siteBanners = this.siteBannerMapper.listByAdmin(); return ServerResponse.createBySuccess(siteBanners); } }