SSM客户管理系统CRM开发mysql数据库web结构java编程计算机网页源码eclipse项目

一、源码特点
  SSM 客户管理系统CRM是一套完善的信息系统,结合springMVC框架完成本系统,对理解JSP java编程开发语言有帮助系统采用SSM框架(MVC模式开发),系统具有完整的源代码和数据库,系统主要采用B/S模式开发。
前段主要技术 html.css jquery
后端主要技术 SSM
数据库 mysql
开发工具 eclipse  JDK1.8 TOMCAT 8.5

视频链接 https://www.bilibili.com/video/BV1Ru4y1L7bm/

二、功能介绍
本系统模块实现功能如下:

(1)员工管理:对员工信息进行添加、删除、修改和查看
(2)菜单管理:对菜单信息进行添加、删除、修改和查看
(3)菜单权限管理:对菜单权限信息进行添加、删除、修改和查看 动态菜单实现
(4)职位管理:对职位信息进行添加、删除、修改和查看
(5)客户管理:对客户信息进行添加、删除、修改和查看
(6)联系人管理:对联系人信息进行添加、删除、修改和查看
(7)商机管理:对商机信息进行添加、删除、修改和查看
(8)邮件管理:对邮件信息进行添加、删除、修改和查看
(9)任务管理:对任务信息进行添加、删除、修改和查看
(10)产品管理:对产品信息进行添加、删除、修改和查看
(11)个人信息修改、登录

数据库设计

(1)员工信息表如表5.1所示:

表5.1 员工信息表

序号

字段名称

数据类型

长度

主键

描述

1

ygid

INTEGER

11

员工编号

2

yhm

VARCHAR

40

用户名

3

mm

VARCHAR

40

密码

4

xm

VARCHAR

40

姓名

5

qx

VARCHAR

40

权限

6

lxdh

VARCHAR

40

联系电话

7

lxdz

VARCHAR

40

联系地址

8

zw

VARCHAR

40

职位

(2)菜单信息表如表5.2所示:

表5.2 菜单信息表

序号

字段名称

数据类型

长度

主键

描述

1

cdid

INTEGER

11

菜单编号

2

cdmc

VARCHAR

40

菜单名称

(3)菜单权限信息表如表5.3所示:

表5.3 菜单权限信息表

序号

字段名称

数据类型

长度

主键

描述

1

cdqxid

INTEGER

11

菜单权限编号

2

cd

VARCHAR

40

菜单

3

qx

VARCHAR

40

权限

(4)职位信息表如表5.4所示:

表5.4 职位信息表

序号

字段名称

数据类型

长度

主键

描述

1

zwid

INTEGER

11

职位编号

2

zwmc

VARCHAR

40

职位名称

3

js

VARCHAR

40

介绍

(5)客户信息表如表5.5所示:

表5.5 客户信息表

序号

字段名称

数据类型

长度

主键

描述

1

khid

INTEGER

11

客户编号

2

khmc

VARCHAR

40

客户名称

3

jyfw

VARCHAR

40

经营范围

4

djsj

VARCHAR

40

登记时间

5

sm

VARCHAR

40

说明

6

lxdh

VARCHAR

40

联系电话

(6)联系人信息表如表5.6所示:

表5.6 联系人信息表

序号

字段名称

数据类型

长度

主键

描述

1

lxrid

INTEGER

11

联系人编号

2

kh

VARCHAR

40

客户

3

lxr

VARCHAR

40

联系人

4

lxdh

VARCHAR

40

联系电话

5

sm

VARCHAR

40

说明

控制层设计

@RequestMapping(value="/add")public String add(kehu kehu,HttpServletRequest request){//添加方法Map<String,Object> map= new HashMap<String,Object>();//初始化对象//String name=(String)request.getParameter("name");map.put("khid", kehu.getKhid());//客户编号map.put("khmc", kehu.getKhmc());//客户名称map.put("jyfw", kehu.getJyfw());//经营范围map.put("djsj", kehu.getDjsj());//登记时间map.put("sm", kehu.getSm());//说明map.put("lxdh", kehu.getLxdh());//联系电话String khid=(String)kehu.getKhid();//客户编号String khmc=(String)kehu.getKhmc();//客户名称String jyfw=(String)kehu.getJyfw();//经营范围String djsj=(String)kehu.getDjsj();//登记时间String sm=(String)kehu.getSm();//说明String lxdh=(String)kehu.getLxdh();//联系电话kehudao.save(map);//调用 add方法 保存kehu 数据request.setAttribute("msg", "<script>alert('添加成功');</script>");System.out.println("addok");return "kehu/kehuadd";}/**删除 kehu* */@RequestMapping(value="/del")public String  del(Integer id,HttpServletRequest request,Map<String,Object> map){//	Map<String,Object> map= new HashMap<String,Object>();//初始化对象String a=(String)request.getParameter("keyid");//request 方式获得主键idid=Integer.parseInt(a);request.setAttribute("msg", "<script>alert('删除成功');</script>");kehudao.del(id);//调用 删除方法return selectall(null,map,request);}/*** 修改kehu信息*/@RequestMapping(value="/update")public String update(kehu kehu,HttpServletRequest request,Map<String,Object> map1){Map<String,Object> map= new HashMap<String,Object>();//初始化对象map.put("khid", kehu.getKhid());//客户编号map.put("khmc", kehu.getKhmc());//客户名称map.put("jyfw", kehu.getJyfw());//经营范围map.put("djsj", kehu.getDjsj());//登记时间map.put("sm", kehu.getSm());//说明map.put("lxdh", kehu.getLxdh());//联系电话String khid=(String)kehu.getKhid();//客户编号String khmc=(String)kehu.getKhmc();//客户名称String jyfw=(String)kehu.getJyfw();//经营范围String djsj=(String)kehu.getDjsj();//登记时间String sm=(String)kehu.getSm();//说明String lxdh=(String)kehu.getLxdh();//联系电话request.setAttribute("msg", "<script>alert('修改成功');</script>");kehudao.update(map);//执行update 方法return selectall(null,map1,request);}/*** 查询kehu信息*/@RequestMapping(value="/modify")public String modify(Integer id,Map<String,Object> map,HttpServletRequest request){String keyid=(String)request.getParameter("keyid");//request 方式获得主键idList<Map<String,Object>> list= new  ArrayList<Map<String,Object>>();//初始化对象list=kehudao.select(Integer.parseInt(keyid));//根据id返回 kehu对象数据request.setAttribute("khid", list.get(0).get("khid"));//客户编号request.setAttribute("khmc", list.get(0).get("khmc"));//客户名称request.setAttribute("jyfw", list.get(0).get("jyfw"));//经营范围request.setAttribute("djsj", list.get(0).get("djsj"));//登记时间request.setAttribute("sm", list.get(0).get("sm"));//说明request.setAttribute("lxdh", list.get(0).get("lxdh"));//联系电话return "kehu/kehumodify";}@RequestMapping(value="/detail")public String detail(Integer id,Map<String,Object> map,HttpServletRequest request){String keyid=(String)request.getParameter("keyid");//request 方式获得主键idList<Map<String,Object>> list= new  ArrayList<Map<String,Object>>();//初始化对象list=kehudao.select(Integer.parseInt(keyid));//根据id返回 kehu对象数据request.setAttribute("khid", String.valueOf(list.get(0).get("khid")));//客户编号request.setAttribute("khmc", list.get(0).get("khmc"));//客户名称request.setAttribute("jyfw", list.get(0).get("jyfw"));//经营范围request.setAttribute("djsj", list.get(0).get("djsj"));//登记时间request.setAttribute("sm", list.get(0).get("sm"));//说明request.setAttribute("lxdh", list.get(0).get("lxdh"));//联系电话return "kehu/kehudetail";}

持久层设计

public void save(Map<String, Object> map) {sqlSession.insert("com.chanpin.insertchanpin", map);//执行insert 插入方法}/*** 删除aa* @param id*/public void del(Integer id) {sqlSession.delete("com.chanpin.delchanpin", id);//执行delete 删除方法}/*** 修改chanpin信息* @param map*/public void update(Map<String, Object> map) {sqlSession.update("com.chanpin.updatechanpin", map);//执行update 修改方法}/*** 查询chanpin信息* @param id* @return */public List<Map<String, Object>> select(Integer id) {return sqlSession.selectList("com.chanpin.selectchanpin", id) ; //执行select 查询}

三、注意事项
1、管理员账号:admin密码:admin 数据库配置文件DBO.java
2、开发环境为eclipse开发,数据库为mysql,使用java语言开发。
3、数据库文件名是jspssmcrm.sql 系统名称ssmcrm
4、地址:http://127.0.0.1:8080/ssmcrm/login.jsp

四 系统实现

源码获取 下方联系卡片↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/159103.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

day62

Cookie与Session的发展史详解 1.Cookie的发展史 1994年&#xff0c;网景通信公司推出了第一个浏览器Cookie技术。Cookie是存储在用户计算机上的小型文本文件&#xff0c;用于跟踪用户在网站上的活动。初始版本的Cookie只能存储很少的数据&#xff0c;并且没有强制加密机制&am…

CVE-2021-42287CVE-2021-42278 域内提权

倘见玉皇先跪奏&#xff1a;他生永不落红尘 本文首发于先知社区&#xff0c;原创作者即是本人 前言 网络安全技术学习&#xff0c;承认⾃⼰的弱点不是丑事。只有对原理了然于⼼&#xff0c;才能突破更多的限制。拥有快速学习能力的白帽子&#xff0c;是不能有短板的&#xf…

Spring Framework IoC依赖注入-按Bean类型注入

Spring Framework 作为一个领先的企业级开发框架&#xff0c;以其强大的依赖注入&#xff08;Dependency Injection&#xff0c;DI&#xff09;机制而闻名。DI使得开发者可以更加灵活地管理对象之间的关系&#xff0c;而不必过多关注对象的创建和组装。在Spring Framework中&am…

Go语言读取文件内容

简介 读取文件内容在每个语言里面都有&#xff0c;go语言中主要注意文件读完后会返回一个异常 io.EOF&#xff0c;根据这个异常去判断就可以了 代码实现 package mainimport ("bufio""fmt""io""os" )func main() {lines : Read(&qu…

【20年扬大真题】编写程序,功能是从键盘输入若干4位数字学号,然后输出学号中百位数字是3的学号 (输入0时结束循环)

【20年扬大真题】 编写程序&#xff0c;功能是从键盘输入若干4位数字学号&#xff0c;然后输出学号中百位数字是3的学号 &#xff08;输入0时结束循环&#xff09; #include<stdio.h> #define MaxSize 20 int BaiWei3(int x) {x x / 100;if (x % 10 3) {return 1;}els…

Windows安装Hadoop运行环境

1、下载Hadoop 2、解压Hadoop tar zxvf hadoop-3.1.1.tar.gz3、设置Hadoop环境变量 3.1.1、系统环境变量 # HADOOP_HOME D:\software\hadoop-3.1.13.1.2、Path 环境变量 %HADOOP_HOME%\bin %HADOOP_HOME%\sbin3.1.3、修改Hadoop文件JAVA_HOME 注 : 路径中不要出现空格 ,…

TMUX设置鼠标滚轮滑动来浏览之前的前面内容

在Ubuntu上使用Tmux有时使用鼠标滚轮时&#xff0c;和平时使用终端的习惯不怎么一致&#xff0c;因此可以设置启用鼠标滚轮。 通过鼠标滚轮滑动来浏览之前的前面内容 具体方式&#xff1a; 1 按完前缀ctrlB后 2 再按冒号&#xff1a;(记得shift) 3 进入命令行模式(下方绿色栏变…

关于web端调用iOS系统的图库异常的问题

前端调用iOS系统图库时异常 好久没更新了&#xff0c;忙于生计。 近日开发中需要iOS客户端需要加载一个webview用于承载一些IM的聊天功能&#xff0c;对于iOS来说很简单&#xff0c;加载一个url即可&#xff0c;但是本人习惯于写成view添加到window上[UIApplication sharedApp…

蓝桥等考C++组别七级008

第一部分:选择题 1、C++ L7 (15分) 在判断是否满足循环条件之前,至少执行循环体语句一次的是哪种循环结构?( ) for循环while循环do-while循环以上都不是正确答案:C 2、C++ L7 (15分) 执行以下程序,会输出几个“*”?( ) for(int i = 0; i <= 10; i++){…

webpack之resolve模块解析

resolve官网配置地址 resolve官网概念地址 解析文件路径 绝对路径&#xff1a;由于已经获得文件的绝对路径&#xff0c;因此不需要再做进一步解析。 相对路径&#xff1a;在 import/require 中给定的相对路径&#xff0c;会拼接此上下文路径&#xff0c;来生成模块的绝对路径&…

前端面试算法之“时间复杂度

✨求关注~ &#x1f600;博客&#xff1a;www.protaos.com 欢迎添加我的微信 介绍 时间复杂度是算法效率的一个关键概念&#xff0c;用于衡量算法运行时间随输入规模增长的速度。在计算机科学中&#xff0c;我们经常面临着不同的算法选择&#xff0c;而了解它们的时间复杂度有助…

首选C++,彻底麻了!

“作为初学者&#xff0c;我应该选择什么语言?” 网上冲浪时&#xff0c;我经常看到上面这样的疑问。作为一个同样在这个选择上挣扎许久的人&#xff0c;我最终选择了C。我想&#xff0c;我可以就这个特定的选择以及它如何影响我之后的学习谈一下个人看法。 本文将围绕以下四…

Spring条件注解@Conditoinal+ Profile环境切换应用@Profile

Spring条件注解 一、创建一个maven项目 <dependencies><dependency><groupId>org.springframework</groupId><artifactId>spring-context</artifactId><version>5.1.5.RELEASE</version></dependency> </dependenc…

局域网内Ubuntu上搭建Git服务器

1.在局域网内选定一台Ubuntu电脑作为Git服务端&#xff1a; (1).新建用户如为fbc&#xff0c;执行如下命令&#xff1a;需设置密码&#xff0c;此为fbc sudo adduser fbc (2).切换到fbc用户&#xff1a;需密码&#xff0c;此前设置为fbc su fbc (3).建一个空目录作为仓…

Linux 内核提权漏洞

提权方式 存在漏洞版本 exp/poc 参考 CVE-2021-33200 Linux kernel through 5.12.7 暂无 NVD - CVE-2021-33200 CVE-2021-31440 Linux kernel 5.11 through 5.12.2 【kernel exploit】CVE-2021-31440 eBPF边界计算错误漏洞&#xff08;Pwn2Own 2021&#xff09; — b…

UI自动化之Playwright简介

&#x1f4e2;专注于分享软件测试干货内容&#xff0c;欢迎点赞 &#x1f44d; 收藏 ⭐留言 &#x1f4dd; 如有错误敬请指正&#xff01;&#x1f4e2;交流讨论&#xff1a;欢迎加入我们一起学习&#xff01;&#x1f4e2;资源分享&#xff1a;耗时200小时精选的「软件测试」资…

C++初阶--类型模板

文章目录 泛型编程函数模板使用通用加法函数多模板参数必须用实例化 函数模板的原理类模板使用 注意事项 泛型编程 先看一个例子&#xff1a; 这是一些对于Swap重载的函数&#xff0c;区别是类型不同&#xff1b; 虽然能够重载使用&#xff0c;但代码复用率比较低&#xff0c…

CSS元素的显示模式

一.什么是元素显示模式 元素显示模式就是元素&#xff08;标签&#xff09;以什么方式进行显示&#xff1b;比如&#xff1a;<div>独占一行&#xff0c;一行可以显示多个<span> HTML元素一般分为块元素和行内元素两种类型。 二.元素分类 1.块元素 常见的块元素有…

Java正则表达式之账号检验与判断基础

考虑到此时读者不知道何为正则表达式&#xff1a; 我需要验证一个字符串是否符合qq号码的规则&#xff0c;我们采取已有知识进行验证 import java.util.Scanner;public class Main{public static void main(String[] args){//正则表达式理解为一种规则//这种规则就是用来校验…

Python实现四个组成不相同且无重复的三位数

前言 大家早好、午好、晚好吖 ❤ ~欢迎光临本文章 如果有什么疑惑/资料需要的可以点击文章末尾名片领取源码 1.题目&#xff1a;有四个数字&#xff1a;1、2、3、4&#xff0c;能组成多少个互不相同且无重复数字的三位数&#xff1f;各是多少&#xff1f; for i in range(1,…