From 423f27b076fcd75df04005ae00e47ec26192434a Mon Sep 17 00:00:00 2001 From: xufenglei <xufenglei> Date: Tue, 12 Jun 2018 09:03:58 +0800 Subject: [PATCH] 实体更新 --- src/main/java/com/moral/controller/MobileController.java | 199 ++++++++++++++++++++++++++++++++++++++----------- 1 files changed, 155 insertions(+), 44 deletions(-) diff --git a/src/main/java/com/moral/controller/MobileController.java b/src/main/java/com/moral/controller/MobileController.java index 09b9c68..b9f1174 100644 --- a/src/main/java/com/moral/controller/MobileController.java +++ b/src/main/java/com/moral/controller/MobileController.java @@ -2,27 +2,24 @@ import static com.moral.common.util.WebUtils.getParametersStartingWith; +import java.util.HashMap; import java.util.List; import java.util.Map; import javax.annotation.Resource; import javax.servlet.http.HttpServletRequest; -import org.springframework.web.bind.annotation.CrossOrigin; -import org.springframework.web.bind.annotation.GetMapping; -import org.springframework.web.bind.annotation.RequestMapping; -import org.springframework.web.bind.annotation.RequestParam; -import org.springframework.web.bind.annotation.RestController; +import com.moral.common.util.Crypto; +import com.moral.entity.*; +import com.moral.entity.adapter.EquDeviceAdapter; +import com.moral.service.*; +import com.moral.util.MessageUtils; +import com.taobao.api.ApiException; +import org.apache.commons.lang3.StringUtils; +import org.springframework.cglib.beans.BeanMap; +import org.springframework.web.bind.annotation.*; -import com.moral.common.bean.ResultBean; -import com.moral.entity.Device; -import com.moral.entity.MonitorPoint; -import com.moral.entity.OperateUser; -import com.moral.entity.Organization; -import com.moral.service.DeviceService; -import com.moral.service.MonitorPointService; -import com.moral.service.OperateUserService; -import com.moral.service.OrganizationService; +import com.moral.common.bean.AppData; /** * The Class MobileController. @@ -48,6 +45,9 @@ @Resource private MonitorPointService monitorPointService; + @Resource + private ProfessionService professionService; + /** * Mobile login.������ * @@ -55,10 +55,10 @@ * @param password the password * @return the result bean */ - @GetMapping("accountlogin") - public ResultBean<OperateUser> mobileLogin(String username, String password) { + @RequestMapping("accountlogin") + public AppData<OperateUser> mobileLogin(String username, String password) { OperateUser operateUser = operateUserService.mobileLogin(username,password); - return new ResultBean<OperateUser>(operateUser); + return new AppData<OperateUser>(operateUser); } /** @@ -69,22 +69,28 @@ * @param newpassword the newpassword * @return the result bean */ - @GetMapping("upPassword") - public ResultBean<OperateUser> updatePassword(Integer uid, String password, String newpassword) { + @RequestMapping("upPassword") + public AppData<OperateUser> updatePassword(Integer uid, String password, String newpassword) { OperateUser operateUser = operateUserService.updatePassword(uid,password,newpassword); - return new ResultBean<OperateUser>(operateUser); + return new AppData<OperateUser>(operateUser); } - /** - * Install device.������������ - * - * @param device the device - * @return the result bean + * ������ ������id ��������������������� */ - @GetMapping("reportDevice") - public ResultBean<String> installDevice(Device device) { - deviceService.saveOrUpdateDevice(device); - return new ResultBean<String>(""); + @RequestMapping("deviceInfo") + public AppData<Device> deviceInfo(Integer id){ + Device device = deviceService.queryById(id); + return new AppData<Device>(device); + } + /** + * + * @param equDeviceAdapter + * @return + */ + @RequestMapping("reportDevice") + public AppData<String> installDevice(EquDeviceAdapter equDeviceAdapter) { + deviceService.addOrModify(equDeviceAdapter.toDevice()); + return new AppData<String>(""); } /** @@ -95,11 +101,11 @@ * @param pageSize the page size * @return the install devices by operate user */ - @GetMapping("myRelease") - public ResultBean<List<Device>> getInstallDevicesByOperateUser(@RequestParam(value="uid", required=true)Integer uid, + @RequestMapping("myRelease") + public AppData<List<Device>> getInstallDevicesByOperateUser(@RequestParam(value="uid", required=true)Integer uid, @RequestParam(defaultValue="0")Integer pageIndex, @RequestParam(defaultValue="0")Integer pageSize) { List<Device> devices = deviceService.getInstallDevicesByOperateUser(uid, pageIndex, pageSize); - return new ResultBean<List<Device>>(devices); + return new AppData<List<Device>>(devices); } /** @@ -108,35 +114,140 @@ * @param mac the mac * @return the device by mac */ - @GetMapping("getEquInfoByMac") - public ResultBean<Device> getDeviceByMac(@RequestParam(value="mac", required=true)String mac) { - Device device = deviceService.getDeviceByMac(mac); - return new ResultBean<Device>(device); + @RequestMapping("getEquInfoByMac") + public AppData<Map> getDeviceByMac(@RequestParam(value="mac", required=true)String mac) { + Device device = deviceService.getDeviceByMac(mac,false);//��������������� + if(device!=null){ + Map<String,Object> deviceMap = new HashMap<>(BeanMap.create(device)); + deviceMap.put("monitorpointDetail",deviceMap.get("monitorPoint")); + deviceMap.remove("monitorPoint"); + return new AppData<Map>(deviceMap); + }else{ + return new AppData("mac���������������",AppData.FAIL); + } } /** * Gets the monitor points by area name. * - * @param areaName the area name + * @param request the area name * @return the monitor points by area name */ - @GetMapping("getMpointsByAreaName") - public ResultBean<List<MonitorPoint>> getMonitorPointsByAreaName(HttpServletRequest request) { + @RequestMapping("getMpointsByAreaName") + public AppData<List<MonitorPoint>> getMonitorPointsByAreaName(HttpServletRequest request) { Map<String, Object> parameters = getParametersStartingWith(request, null); List<MonitorPoint> monitorPoints = monitorPointService.getMonitorPointsByAreaName(parameters); - return new ResultBean<List<MonitorPoint>>(monitorPoints); + return new AppData<List<MonitorPoint>>(monitorPoints); } /** * Gets the organizations by area name. * - * @param areaName the area name + * @param request the area name * @return the organizations by area name */ - @GetMapping("getOrgsByAreaName") - public ResultBean<List<Organization>> getOrganizationsByAreaName(HttpServletRequest request) { + @RequestMapping("getOrgsByAreaName") + public AppData<List<Organization>> getOrganizationsByAreaName(HttpServletRequest request) { Map<String, Object> parameters = getParametersStartingWith(request, null); List<Organization> organizations = organizationService.getOrganizationsByAreaName(parameters); - return new ResultBean<List<Organization>>(organizations); + return new AppData<List<Organization>>(organizations); + } + + /** + * Send SMS + * + * @param mobile + * @return + */ + @RequestMapping("sendSms") + public AppData<String> sendSms(String mobile) { + AppData apiData = new AppData(); + + if (StringUtils.isBlank(mobile)){ + apiData.setErrno(1); + apiData.setMessage("������������������������"); + apiData.setData("{}"); + return apiData; + } + OperateUser user = operateUserService.getOperateUserByMobile(mobile); + if (user==null){ + apiData.setErrno(1); + apiData.setMessage("���������������������������"); + apiData.setData("{}"); + return apiData; + } + //��������������� + int code = (int)((Math.random() * 9 + 1) * 100000); + user.setCode(String.valueOf(code)); + operateUserService.updateOperateUser(user); + + //��������������� + try { + int state = MessageUtils.sendMsg(mobile, String.valueOf(code)); + if(state==0){ + apiData.setErrno(0); + apiData.setMessage("���������������������"); + apiData.setData("{}"); + return apiData; + } + if(state==1){ + apiData.setErrno(1); + apiData.setMessage("���������������������"); + apiData.setData("{}"); + return apiData; + } + } catch (ApiException e) { + e.printStackTrace(); + } + return new AppData<String>(""); + } + + /** + * + * @param username + * @param password + * @param code + * @return + */ + @RequestMapping("password") + public AppData<String> password(String username, String password, String code){ + AppData apiData = new AppData(); + + if (StringUtils.isBlank(code)){ + apiData.setErrno(1); + apiData.setMessage("������������������������������������������"); + apiData.setData("{}"); + return apiData; + } + OperateUser user = operateUserService.getOperateUserByMobile(username); + if (user==null){ + apiData.setErrno(1); + apiData.setMessage("���������������������������"); + apiData.setData("{}"); + return apiData; + } + if (user.getCode().equals(code)){ + user.setPassword(Crypto.md5(password)); + int new_code = (int)((Math.random() * 9 + 1) * 100000); + user.setCode(String.valueOf(new_code)); + operateUserService.updateOperateUser(user); + + apiData.setErrno(0); + apiData.setMessage("������������������"); + apiData.setData("{}"); + return apiData; + } else { + apiData.setErrno(1); + apiData.setMessage("������������������������"); + apiData.setData("{}"); + return apiData; + } + } + + @RequestMapping("profession") + public AppData<List<Profession>> profession(){ + + List<Profession> professions = professionService.getProfessiontList(); + return new AppData<List<Profession>>(professions); } } -- Gitblit v1.8.0