/* * Copyright 2017-2020 吴学文 and java110 team. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package com.java110.boot.controller.app; import com.alibaba.fastjson.JSONObject; import com.java110.boot.smo.login.IOwnerAppLoginSMO; import com.java110.boot.smo.login.IWxLoginSMO; import com.java110.boot.smo.staff.IStaffAuthSMO; import com.java110.core.base.controller.BaseController; import com.java110.core.context.IPageData; import com.java110.core.context.PageData; import com.java110.core.factory.WechatFactory; import com.java110.core.log.LoggerFactory; import com.java110.utils.cache.CommonCache; import com.java110.utils.constant.CommonConstant; import com.java110.utils.util.StringUtil; import com.java110.vo.ResultVo; import org.slf4j.Logger; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.http.HttpStatus; import org.springframework.http.ResponseEntity; import org.springframework.web.bind.annotation.*; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import java.util.Map; /** * 微信小程序登录处理类 */ @RestController @RequestMapping(path = "/app") public class OwnerController extends BaseController { private final static Logger logger = LoggerFactory.getLogger(OwnerController.class); @Autowired private IOwnerAppLoginSMO ownerAppLoginSMOImpl; @Autowired private IStaffAuthSMO staffAuthSMOImpl; @Autowired private IWxLoginSMO wxLoginSMOImpl; /** * 微信登录接口 * * @param postInfo * @param request */ @RequestMapping(path = "/loginOwner", method = RequestMethod.POST) public ResponseEntity loginOwner(@RequestBody String postInfo, HttpServletRequest request) { /*IPageData pd = (IPageData) request.getAttribute(CommonConstant.CONTEXT_PAGE_DATA);*/ String appId = request.getHeader("APP_ID"); if (StringUtil.isEmpty(appId)) { appId = request.getHeader("APP-ID"); } IPageData pd = PageData.newInstance().builder("", "", "", postInfo, "login", "", "", "", appId ); ResponseEntity responseEntity = ownerAppLoginSMOImpl.doLogin(pd); if (responseEntity.getStatusCode() != HttpStatus.OK) { return responseEntity; } JSONObject outParam = JSONObject.parseObject(responseEntity.getBody()); pd.setToken(outParam.getString("token")); request.setAttribute(CommonConstant.CONTEXT_PAGE_DATA, pd); return responseEntity; } /** * 微信登录接口 * * @param postInfo * @param request */ @RequestMapping(path = "/loginOwnerByKey", method = RequestMethod.POST) public ResponseEntity loginOwnerByKey(@RequestBody String postInfo, HttpServletRequest request) { /*IPageData pd = (IPageData) request.getAttribute(CommonConstant.CONTEXT_PAGE_DATA);*/ String appId = request.getHeader("APP_ID"); if (StringUtil.isEmpty(appId)) { appId = request.getHeader("APP-ID"); } IPageData pd = PageData.newInstance().builder("", "", "", postInfo, "login", "", "", "", appId ); ResponseEntity responseEntity = ownerAppLoginSMOImpl.doLoginByKey(pd); if (responseEntity.getStatusCode() != HttpStatus.OK) { return responseEntity; } JSONObject outParam = JSONObject.parseObject(responseEntity.getBody()); pd.setToken(outParam.getString("token")); request.setAttribute(CommonConstant.CONTEXT_PAGE_DATA, pd); return responseEntity; } /** * 微信登录接口 * * @param request */ @RequestMapping(path = "/loginOwnerWechatAuth") public ResponseEntity loginOwnerWechatAuth(HttpServletRequest request) { Map params = getParameterStringMap(request); String appId = params.get("appId"); IPageData pd = PageData.newInstance().builder("", "", "", JSONObject.toJSONString(params), "login", "", "", "", appId ); ResponseEntity responseEntity = ownerAppLoginSMOImpl.getPageAccessToken(pd, request); request.setAttribute(CommonConstant.CONTEXT_PAGE_DATA, pd); return responseEntity; } /** * 微信公众号号鉴权 * * @param request */ @RequestMapping(path = "/refreshToken") public ResponseEntity refreshToken(@RequestParam String redirectUrl, @RequestParam String errorUrl, @RequestParam String loginFlag, HttpServletRequest request, HttpServletResponse response) { IPageData pd = PageData.newInstance().builder("", "", "", "", "login", "", "", "", request.getHeader("app-id") ); return ownerAppLoginSMOImpl.refreshToken(pd, redirectUrl, errorUrl, loginFlag, request, response); } /** * 微信登录接口 * * @param request */ @RequestMapping(path = "/openServiceNotifyOpenId") public ResponseEntity openServiceNotifyOpenId(HttpServletRequest request) { Map params = getParameterStringMap(request); String appId = params.get("appId"); IPageData pd = PageData.newInstance().builder("", "", "", JSONObject.toJSONString(params), "login", "", "", "", appId ); ResponseEntity responseEntity = ownerAppLoginSMOImpl.openServiceNotifyOpenId(pd, request); request.setAttribute(CommonConstant.CONTEXT_PAGE_DATA, pd); return responseEntity; } /** * 微信公众号号鉴权 * * @param request */ @RequestMapping(path = "/refreshOpenId") public ResponseEntity refreshOpenId(@RequestParam String redirectUrl, @RequestParam(required = false) String wAppId, HttpServletRequest request, HttpServletResponse response) { IPageData pd = PageData.newInstance().builder("", "", "", "", "login", "", "", "", request.getHeader("app-id") ); return ownerAppLoginSMOImpl.refreshOpenId(pd, redirectUrl,wAppId, request, response); } @RequestMapping(path = "/getWId") public ResponseEntity getWId(@RequestParam String appId) { return ResultVo.createResponseEntity(WechatFactory.getWId(appId)); } /** * 微信登录接口 * /app/loginStaffWechatAuth * * @param request */ @RequestMapping(path = "/loginStaffWechatAuth") public ResponseEntity loginStaffWechatAuth(HttpServletRequest request) { Map params = getParameterStringMap(request); String appId = params.get("appId"); IPageData pd = PageData.newInstance().builder("", "", "", JSONObject.toJSONString(params), "login", "", "", "", appId ); ResponseEntity responseEntity = staffAuthSMOImpl.getPageAccessToken(pd, request); request.setAttribute(CommonConstant.CONTEXT_PAGE_DATA, pd); return responseEntity; } /** * 微信公众号号鉴权 * /app/staffAuth * * @param request */ @RequestMapping(path = "/staffAuth") public ResponseEntity staffAuth(@RequestParam(value = "communityId") String communityId, @RequestParam(value = "staffId") String staffId, @RequestParam(value = "storeId") String storeId, @RequestParam(value = "appId") String appId, HttpServletRequest request, HttpServletResponse response) { IPageData pd = PageData.newInstance().builder("", "", "", "", "login", "", "", "", appId); return staffAuthSMOImpl.refreshToken(pd, communityId, staffId, storeId, request, response); } /** * 微信登录接口 * * @param postInfo * @param request */ @RequestMapping(path = "/loginWx", method = RequestMethod.POST) public ResponseEntity loginWx(@RequestBody String postInfo, HttpServletRequest request) { ResponseEntity responseEntity = null; JSONObject postObj = JSONObject.parseObject(postInfo); String code = JSONObject.parseObject(postInfo).getString("code"); JSONObject userInfo = postObj.getJSONObject("userInfo"); if (code == null || userInfo == null) { logger.error("code is null"); responseEntity = new ResponseEntity<>("code is null", HttpStatus.BAD_REQUEST); return responseEntity; } String appId = request.getHeader("APP_ID"); if (StringUtil.isEmpty(appId)) { appId = request.getHeader("APP-ID"); } IPageData pd = PageData.newInstance().builder("", "", "", postInfo, "", "", "", "", appId); return wxLoginSMOImpl.doLogin(pd); } @RequestMapping(path = "/getWxPhoto", method = RequestMethod.POST) public ResponseEntity getWxPhoto(@RequestBody String postInfo) { JSONObject postObj = JSONObject.parseObject(postInfo); String photoInfo = WechatFactory.getPhoneNumberBeanS5(postObj.getString("decryptData"), postObj.getString("key"), postObj.getString("iv")); JSONObject photoObj = JSONObject.parseObject(photoInfo); CommonCache.setValue(postObj.getString("key"), photoObj.getString("phoneNumber"), CommonCache.defaultExpireTime); return ResultVo.createResponseEntity(photoObj); } }