亲宝软件园·资讯

展开

Java CRM项目思路 Java 初识CRM之项目思路解析

每日小新 人气:0
想了解Java 初识CRM之项目思路解析的相关内容吗,每日小新在本文为您仔细讲解Java CRM项目思路的相关知识和一些Code实例,欢迎阅读和指正,我们先划重点:Java,CRM项目思路,Java,CRM,下面大家一起来学习吧。

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映射层直接生成,其余静态页面和素材略....(详情代码看上传资源)

二、营销模块全程思路分析

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

营销模块:
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),"电话号码不合法!");
    }
}

总结

以上两个模块基本就是这个项目的全部思路,后面的模块思路与介绍的这两个模块思路一致,源码已上传~,1024程序员节日快乐!!🎈🎈🎈🎈

加载全部内容

相关教程
猜你喜欢
用户评论