91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

分析Java中CRM之項目思路

發布時間:2021-11-03 17:15:35 來源:億速云 閱讀:138 作者:iii 欄目:開發技術

這篇文章主要講解了“分析Java中CRM之項目思路”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“分析Java中CRM之項目思路”吧!

一、登錄模塊全程思路分析

登錄模塊:
1、對用戶名和密碼的校驗,并存儲在cookie中,方便后期的免登錄操作。
2、對用戶基本信息的修改,通過獲取表單用戶修改的數據,進行Ajax請求,對修改之后id對應用戶進行數據庫信息修改
3、修改密碼,獲取用戶輸入的表單數據,進行service層校驗,判斷原密碼,新密碼確認密碼,最后對數據庫用戶密碼進行修改
4、每次修改信息后會自動清楚cookie內的數據,退出重新登錄
5、service層會調用很多工具類提供便潔業務處理

?核心代碼

controller層UserController.java

@Controller
@RequestMapping("user")
public class UserController extends BaseController {

    @Autowired
    UserService userService;

    //修改密碼頁面跳轉
    @RequestMapping("toPasswordPage")
    public String updatePwd(){
        return "user/password";
    }

    //登錄
    @RequestMapping("login")
    @ResponseBody
    public ResultInfo login(User user){
        ResultInfo result=new ResultInfo();
        try{
            //捕獲異常
            UserModel userModel=userService.userLogin(user.getUserName(),user.getUserPwd());
            //登錄成功
            result.setCode(200);
            result.setMsg("登錄成功~");
            result.setResult(userModel);
        }catch (ParamsException ex){
            ex.printStackTrace();
            result.setCode(ex.getCode());
            result.setMsg(ex.getMsg());
        }catch (Exception e){
            e.printStackTrace();
            result.setCode(500);
            result.setMsg("操作失敗~");
        }
        return result;

    }

    /*修改密碼*/
    @PostMapping("updatePwd")
    @ResponseBody
    public ResultInfo updatePwd(HttpServletRequest req,String oldPwd,String newPwd,String againPwd){
        ResultInfo result=new ResultInfo();
        //獲取cookie獲取用戶ID
        int userId=LoginUserUtil.releaseUserIdFromCookie(req);
       userService.updatePwd(userId,oldPwd,newPwd,againPwd);
        return result;
    }
}

Service層UserService.java

@Service
public class UserService extends BaseService<User,Integer> {

    @Resource
    UserMapper userMapper;
    /*用戶登錄*/
    public UserModel userLogin(String userName,String userPwd){
        //判斷用戶名和密碼是否為空
        checkNull(userName,userPwd);
        //檢查是否已經存在
        User user=userMapper.selectByuserName(userName);
        AssertUtil.isTrue(user==null,"用戶名不存在!");
        //檢查密碼
        checkPwd(userPwd,user.getUserPwd());
        return buildInfo(user);
    }
    //設置返回信息
    private UserModel buildInfo(User user) {
        UserModel um=new UserModel();
        um.setUserName(user.getUserName());
        um.setUserId(UserIDBase64.encoderUserID(user.getId()));//對ID加密
        um.setTrueName(user.getTrueName());
        return um;
    }
    //密碼驗證
    private void checkPwd(String userPwd, String userPwd1) {
        String enPwd=Md5Util.encode(userPwd);
        AssertUtil.isTrue(!enPwd.equals(userPwd1),"密碼不正確!");
    }
    //判斷是否為空
    private  void checkNull(String userName,String userPwd){
        //判斷用戶名和密碼是否為空
        AssertUtil.isTrue(StringUtils.isBlank(userName),"用戶名不能為空!");
        AssertUtil.isTrue(StringUtils.isBlank(userPwd),"用戶密碼不能為空!");
    }

    /*修改密碼*/
    public void updatePwd(int userId,String oldPwd,String newPwd,String againPwd){
        //通過id獲取用戶
        System.out.println(userId);
        User user=userMapper.selectByPrimaryKey(userId);
        System.out.println(user);
        //檢驗并修改密碼
        isOkForPwd(user,oldPwd,newPwd,againPwd);
        //修改密碼
        user.setUserPwd(Md5Util.encode(newPwd));
        //修改數據庫內容
        AssertUtil.isTrue(userMapper.updateByPrimaryKeySelective(user)<1,"操作失敗");

    }
    //檢驗密碼
    private void isOkForPwd(User user, String oldPwd, String newPwd, String againPwd) {
        //判斷用戶是否為空
        AssertUtil.isTrue(user==null,"用戶未登錄或不存在!");
        //原密碼是否為空
        AssertUtil.isTrue(StringUtils.isBlank(oldPwd),"原密碼不能為空!");
        //新密碼判斷是否為空
        AssertUtil.isTrue(StringUtils.isBlank(newPwd),"新密碼不能為空!");
        //對原密碼判斷是否正確
        AssertUtil.isTrue(!(user.getUserPwd().equals(Md5Util.encode(oldPwd))),"原密碼不正確!");
        //對新密碼和原密碼進行判斷
        AssertUtil.isTrue(oldPwd.equals(newPwd),"原密碼和新密碼不能一致!");
        //對再次輸入判斷是否為空
        AssertUtil.isTrue(StringUtils.isBlank(againPwd),"二次驗證密碼不能為空!");
        //判斷新密碼與二次輸入
        AssertUtil.isTrue(!(newPwd.equals(againPwd)),"新密碼與第二次輸入不一致!");

    }

}

全局異常具體代碼:GlobalExceptionResolver.java

@Component
public class GlobalExceptionResolver implements HandlerExceptionResolver {
    @Override
    public ModelAndView resolveException(HttpServletRequest req, HttpServletResponse resp, Object handler, Exception ex) {
      //登錄異常處理
        if(ex instanceof NoLoginException){
            // 如果捕獲的是未登錄異常,則重定向到登錄頁面
            ModelAndView mv = new ModelAndView("redirect:/index");
            return mv;
        }

        //實例化ModelandView 異常則跳轉error
        ModelAndView mv=new ModelAndView("error");
        mv.addObject("code",400);
        mv.addObject("msg","系統異常~");

        if(handler instanceof HandlerMethod){
            //則返回頁面
            HandlerMethod hm=(HandlerMethod) handler;
            //通過反射獲取注解@responseBody對象
            ResponseBody resquestBody=hm.getMethod().getDeclaredAnnotation(ResponseBody.class);
            //判斷是否被注解
            if(resquestBody==null){
                //返回頁面
                if(ex instanceof ParamsException){
                    ParamsException param=(ParamsException) ex;
                    //設置
                    mv.addObject("code",param.getCode());
                    mv.addObject("msg",param.getMsg());
                }

            }else{
                //返回json
                ResultInfo result=new ResultInfo();
                result.setCode(300);
                result.setMsg("系統異常~");
                //異常處理
                if(ex instanceof ParamsException){
                    ParamsException param=(ParamsException) ex;
                    //設置
                    result.setCode(param.getCode());
                    result.setMsg(param.getMsg());
                    // 設置響應類型和編碼格式 (響應JSON格式)
                    resp.setContentType("application/json;charset=utf-8");

                    //通過數據流寫出
                    PrintWriter out= null;
                    try {
                        out = resp.getWriter();
                        out.write(JSON.toJSONString(result));
                        out.flush();
                    } catch (IOException e) {
                        e.printStackTrace();
                    }finally {
                        if(out!=null){
                            out.close();
                        }
                    }
                    return null;
                }
            }
        }

        return mv;
    }
}

攔截器NoLoginInterceptor.java

public class NoLoginInterceptor extends HandlerInterceptorAdapter {
    @Resource
    UserService userService;

    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
        //根據cookie中id值登錄攔截
        //獲取cookie用戶id
        Integer userId = LoginUserUtil.releaseUserIdFromCookie(request);
        if(userId==null || userService.selectByPrimaryKey(userId)==null){
            throw new NoLoginException("未登錄異常~");
        }
        return true;
    }
}

dao層與mappers映射層直接生成,其余靜態頁面和素材略....(詳情代碼看上傳資源)

二、營銷模塊全程思路分析

分析Java中CRM之項目思路

分析Java中CRM之項目思路

分析Java中CRM之項目思路

營銷模塊:
1、主要進行營銷機會的添加、刪除、編輯
2、首先通過靜態頁面的監聽,判斷執行什么操作
2.1、點擊添加:對應js調用addorupdata()方法-->open開啟規定好大小的頁面,
跳轉controller下addorupdata(Integer id,Model model)方法進行判斷是
否有id,無則直接轉發靜態資源頁面addorupdata.ftl頁面,此時open的小頁面便
有一個空的表單頁面了。
2.2、點擊修改:對js調用addorupdata(id)方法-->open開啟規定好大小的頁面,
帶id轉發至controller層addorupdata(Integer id,Model model)方法判斷
id是否有值,有則存入對應id的User對象于model中,轉發至addorupdata.ftl頁
面,此時open的小頁面便是一個有內容的表單。
2.3、點擊刪除:js文件會直接調用deletesale(data),直接獲取要刪除對象的id,
多個這返回拼接一個ids=1&ids=2&ids=3發送Ajax請求至controller層調用delete(Integer[] ids)
方法對其進行處理。
3、其次,判斷什么操作之后,便會彈出對應窗口addorupdata.ftl,此時對應js對其監聽是否提交
3.1、點擊提交,則會判斷表單提交數據中是否含有id值,有則發送Ajax請求至controller層
調用updata(User user)方法對其進行修改。
3.2、點擊提交,id無值,則發送Ajax請求至controller層調用add(User user)方法對其進行添加
4、刪除這里直接寫一個批量刪除即可,無序打開小窗口,直接Ajax請求,調用controller層的delete方法進行處理

其余模塊的邏輯,于營銷模塊思路一致,不做更多概述~,源碼直接看上傳資源

?核心代碼

SaleChanceController.java

@Controller
@RequestMapping("sale_chance")
public class SaleChanceController extends BaseController {
    @Autowired
    private SaleChanceService saleChanceService;

    @Autowired
    private UserService userService;

    //營銷機會頁面跳轉
    @RequestMapping("index")
    public String toSale(){
        return "/saleChance/sale_chance";
    }


    //添加和修改頁面
    @RequestMapping("addOrUpdateDialog")
    public String addorUpdata(Integer id, Model model){
        //如果id有值
        if(id!=null){
            //通過ID獲取對象
            SaleChance saleChance=saleChanceService.selectByPrimaryKey(id);
            model.addAttribute("saleChance",saleChance);
        }
        return "saleChance/add_update";
    }

    @RequestMapping("list")
    @ResponseBody
    public Map<String,Object> manyPage(SaleChanceQuery query){
        return saleChanceService.manyPage(query);
    }

    /*添加商機*/
    @RequestMapping("save")
    @ResponseBody
    public ResultInfo save(HttpServletRequest req, SaleChance saleChance){
        //獲取cookie中的id
       int id= LoginUserUtil.releaseUserIdFromCookie(req);
       //通過id創建者
       String createName=userService.selectByPrimaryKey(id).getTrueName();
       //設置創建者
        saleChance.setCreateMan(createName);
        //添加
        saleChanceService.addSaleChance(saleChance);
        return success("添加成功");
    }

    /*修改營銷機會*/
    @RequestMapping("updata")
    @ResponseBody
    public ResultInfo updata(SaleChance saleChance){
        saleChanceService.updataSale(saleChance);
        return success("修改成功");
    }

    /*批量刪除*/
    @RequestMapping("dels")
    @ResponseBody
    public ResultInfo delete(Integer[] ids){
        System.out.println(Arrays.toString(ids));
        saleChanceService.deleteall(ids);
        return success("刪除成功~");
    }
}

SaleChanceService.java

@Service
public class SaleChanceService extends BaseService<SaleChance,Integer> {
    @Resource
    private SaleChanceMapper saleChanceMapper;

    /*//分頁顯示*/
    public Map<String,Object> manyPage(SaleChanceQuery query){
        Map<String, Object> map = new HashMap<>();
        //設置分頁
        PageHelper.startPage(query.getPage(), query.getLimit());
        //對數據進行分頁
        PageInfo<SaleChance> pageInfo = new PageInfo<>(saleChanceMapper.selectByParams(query));
        map.put("code",0);
        map.put("msg", "success");
        map.put("count", pageInfo.getTotal());
        map.put("data", pageInfo.getList());
        return map;
    }
   /* //添加商機*/
    @Transactional(propagation = Propagation.REQUIRED)
    public void addSaleChance(SaleChance saleChance){
        //判斷客戶名稱,機會來源,聯系人,聯系電話,
        checkInfo(saleChance.getCustomerName(),saleChance.getChanceSource(),saleChance.getLinkMan(),saleChance.getLinkPhone());
        //state狀態是否分配 0 未分配 1已經分配
        if(StringUtils.isBlank(saleChance.getAssignMan())){
            saleChance.setDevResult(0);
            saleChance.setState(0);
        }
        if(StringUtils.isNotBlank(saleChance.getAssignMan())){
            saleChance.setDevResult(1);
            saleChance.setState(1);
            saleChance.setAssignTime(new Date());
        }

        //設置默認值
        saleChance.setCreateDate(new Date());
        saleChance.setUpdateDate(new Date());
        saleChance.setIsValid(1);
        //判斷插入是否成功
        AssertUtil.isTrue(insertSelective(saleChance)<1,"添加失敗!");

    }

   /* //修改商機*/
    @Transactional(propagation = Propagation.REQUIRED)
    public void updataSale(SaleChance saleChance){
        //通過id判斷是否存在
        SaleChance sc=selectByPrimaryKey(saleChance.getId());
        AssertUtil.isTrue(sc==null,"更新商機不存在!");
        //基礎判斷
        checkInfo(saleChance.getCustomerName(),saleChance.getChanceSource(),saleChance.getLinkMan(),saleChance.getLinkPhone());
        //是否分配]
        //原營銷機會未分配,改為已經分配
        if(StringUtils.isBlank(sc.getAssignMan()) && saleChance.getAssignMan()!=null){
            sc.setState(1);
            sc.setDevResult(1);
            sc.setAssignTime(new Date());
        }
        //原營銷機會已經分配,改為未分配
        if(StringUtils.isNotBlank(sc.getAssignMan()) && StringUtils.isBlank(sc.getAssignMan())){
            sc.setState(0);
            sc.setDevResult(0);
            sc.setAssignTime(null);
            sc.setAssignMan("");
        }
        //插入
        AssertUtil.isTrue(updateByPrimaryKeySelective(saleChance)<1,"添加失敗!");
    }

    /*批量刪除*/
    @Transactional(propagation = Propagation.REQUIRED)
    public void  deleteall(Integer[] ids){
        //判斷是否為空
        AssertUtil.isTrue((ids==null || ids.length==0),"刪除的ID不存在!");
        System.out.println(Arrays.toString(ids));
        //刪除是否成功
        AssertUtil.isTrue(saleChanceMapper.deleteBatch(ids) < 0,"刪除失敗~~~");
    }


    //校驗
    private void checkInfo(String customerName, String chanceSource, String linkMan, String linkPhone) {
        AssertUtil.isTrue(StringUtils.isBlank(customerName), "用戶名稱不能為空!");
        AssertUtil.isTrue(StringUtils.isBlank(chanceSource),"機會來源不能為空!");
        AssertUtil.isTrue(StringUtils.isBlank(linkMan),"聯系人不能為空!");
        AssertUtil.isTrue(StringUtils.isBlank(linkPhone),"聯系電話不能為空!");
        AssertUtil.isTrue(!PhoneUtil.isMobile(linkPhone),"電話號碼不合法!");
    }
}

感謝各位的閱讀,以上就是“分析Java中CRM之項目思路”的內容了,經過本文的學習后,相信大家對分析Java中CRM之項目思路這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

江津市| 秦安县| 宜阳县| 务川| 方正县| 和平区| 和田市| 龙江县| 尖扎县| 夏邑县| 娱乐| 遂溪县| 财经| 广水市| 哈密市| 盘锦市| 正安县| 牡丹江市| 甘德县| 化隆| 东安县| 扶风县| 顺昌县| 永年县| 西城区| 余姚市| 沙河市| 平塘县| 剑川县| 泗阳县| 山东| 建平县| 高阳县| 工布江达县| 铁岭市| 天峨县| 洞头县| 防城港市| 龙州县| 图木舒克市| 方城县|