每天记录学习,每天会有好心情。*^_^*
在学习软件信息发布系统项目的时候,方便日后能及时查阅,在本平台中记录一下该项目的开发流程。在学习时候的选用了SSM(MYECLIPSE),这个框架不论是学习还是使用都非常方便,简单易上手。是我们学习编程可以重点学习的一个框架,我在开发软件信息发布系统项目的时候选用了MYECLIPSE来搭建SSM(MYECLIPSE)框架,最终将软件信息发布系统项目开发为了一个 后台项目。
该项目具有的用户角色包括了管理员、用户,每个角色都含有自己的登录账号和密码。
总结得出该系统所有数据为:管理员(admin)、用户(yonghu)、软件(ruanjian)
管理员表
字段名 | 类型 | 属性 | 描述 id | INT(11) | PRIMARY KEY | 管理员id username | VARCHAR(255) | | 账号 password | VARCHAR(255) | | 密码
用户表
字段名 | 类型 | 属性 | 描述 id | INT(11) | PRIMARY KEY | 用户id mingzi | VARCHAR(255) | | 名字 username | VARCHAR(255) | | 账号 password | VARCHAR(255) | | 密码
软件表
字段名 | 类型 | 属性 | 描述 id | INT(11) | PRIMARY KEY | 软件id mingcheng | VARCHAR(255) | | 名称 wenjian | VARCHAR(255) | | 文件 jieshao | VARCHAR(255) | | 介绍 shangchuanshijian | VARCHAR(255) | | 上传时间
SET FOREIGN_KEY_CHECKS=0; -- ---------------------------- -- ---------------------------- -- Table structure for ggruanjianfabu -- ---------------------------- DROP TABLE IF EXISTS `t_admin`; CREATE TABLE `t_admin` (`id` INT(11) NOT NULL AUTO_INCREMENT COMMENT '管理员id',`username` VARCHAR(255) DEFAULT NULL COMMENT '账号',`password` VARCHAR(255) DEFAULT NULL COMMENT '密码',PRIMARY KEY (`id`) ) ENGINE=MyISAM DEFAULT CHARSET=utf8 COMMENT='管理员'; -- ---------------------------- DROP TABLE IF EXISTS `t_yonghu`; CREATE TABLE `t_yonghu` (`id` INT(11) NOT NULL AUTO_INCREMENT COMMENT '用户id',`mingzi` VARCHAR(255) DEFAULT NULL COMMENT '名字',`username` VARCHAR(255) DEFAULT NULL COMMENT '账号',`password` VARCHAR(255) DEFAULT NULL COMMENT '密码',PRIMARY KEY (`id`) ) ENGINE=MyISAM DEFAULT CHARSET=utf8 COMMENT='用户'; -- ---------------------------- DROP TABLE IF EXISTS `t_ruanjian`; CREATE TABLE `t_ruanjian` (`id` INT(11) NOT NULL AUTO_INCREMENT COMMENT '软件id',`mingcheng` VARCHAR(255) DEFAULT NULL COMMENT '名称',`wenjian` VARCHAR(255) DEFAULT NULL COMMENT '文件',`jieshao` VARCHAR(255) DEFAULT NULL COMMENT '介绍',`shangchuanshijian` VARCHAR(255) DEFAULT NULL COMMENT '上传时间',PRIMARY KEY (`id`) ) ENGINE=MyISAM DEFAULT CHARSET=utf8 COMMENT='软件';
添加软件模块:
在ruanjianController中定义tianjiaruanjianact接收页面传入的软件参数,定义为ruanjian。其中ruanjian包含字段:名称,文件,介绍,上传时间,使用tianjiaruanjianact将该软件对象存入数据库中,在ruanjianMapper中定义了insert方法,匹配数据库中的insert into ruanjian语句实现将软件数据存入数据库的操作。该部分核心代码如下:
通过ruanjiandao的insert方法将页面传输的软件添加到数据库中 ruanjiandao.insert(ruanjian);
将添加软件成功信息,保存到request的message中,在页面中给出用户提示 request.setAttribute("message", "添加软件成功");
返回软件管理界面
return "forward:/tianjiaruanjian.action";
查询软件模块:
在后台ruanjianguanli方法中,通过selectByexample方法获取所有的数据信息。将其保存到request中,在页面中通过foreach方法
进行循环展示到table中。完成软件查询操作。具体代码如下:
生成软件样例类,通过example定义查询条件 RuanjianExample example = new RuanjianExample();
通过ruanjiandao的selectByExample方法查询出所有的软件信息 List ruanjianall = ruanjiandao.selectByExample(example);
将软件信息,保存到request中,在页面通过foreach方法进行展示 request.setAttribute("ruanjianall", ruanjianall);
返回软件管理界面
return "forward:/ruanjianguanli.action";
修改软件模块:
对已经上传的软件信息可以进行修改操作,该部分操作在软件管理界面中点击修改按钮可以跳转到软件修改页面。在修改页面中,将初始化所有的软件字段信息,字段信息包括名称,文件,介绍,上传时间。字段信息内容通过软件id获取。修改后的信息传入到ruanjianController中接收为ruanjian。在ruanjianController中包含有提前定义好的ruanjiandao,该参数为ruanjianMapper是实现。ruanjianMapper中定义了修改方法,此处使用修改方法为updateByPrimaryKeySelective,该方法可以将修改后信息同步到数据库中,最终将修改成功信息返回页面中。该部分代码如下:
通过ruanjiandao的修改方法根据id修改对应的软件 ruanjiandao.updateByPrimaryKeySelective(ruanjian);
将修改软件成功信息,保存到request的message中,在页面中给出用户提示 request.setAttribute("message", "修改软件信息成功");
返回软件管理界面
return "forward:/ruanjianguanli.action";
删除软件模块:
在管理页面中,点击删除。页面将通过a标签的href属性,使用get方法将该软件
的id上传到服务器中,在服务器中通过ruanjianController类中的shanchuruanjian进行接收,之后调用ruanjianMapper中的deleteByPrimaryKey方法根据ID进行删除。将删除信息保存到request的message中,在页面给出用户删除成功的提示信息,该部分核心代码如下:
通过ruanjiandao的删除方法根据id删除对应的软件 ruanjiandao.deleteByPrimaryKey(id);
将删除软件成功信息,保存到request的message中,在页面中给出用户提示 request.setAttribute("message", "删除软件成功");
返回软件管理界面
return "forward:/ruanjianguanli.action";