作者主页:源码空间站2022
简介:Java领域优质创作者、Java项目、学习资料、技术互助
文末获取源码
本项目分为前后台,前台主要用于官网展示,后台主要为管理员管理,
管理员角色包含以下功能:
管理员登录,文章分类管理,文章列表管理,友情链接管理,招聘管理,留言管理,滚动图片管理,联系我们,关于我们,网站管理员管理,日志管理等功能。
用户角色包含以下功能:
用户首页,关于我们,服务领域发布,新闻动态,诚聘英才,在线留言,联系我们等功能。
1.运行环境:最好是java jdk 1.8,我们在这个平台上运行的。其他版本理论上也可以。
2.IDE环境:IDEA,Eclipse,Myeclipse都可以。推荐IDEA;
3.tomcat环境:Tomcat 7.x,8.x,9.x版本均可
4.硬件环境:windows 7/8/10 1G内存以上;或者 Mac OS;
5.数据库:MySql 5.7版本;
6.是否Maven项目:是;
1. 后端:Spring+SpringMVC+Mybatis
2. 前端:JSP+CSS+JavaScript+bootstrap+jquery
1. 使用Navicat或者其它工具,在mysql中创建对应名称的数据库,并导入项目的sql文件;
2. 使用IDEA/Eclipse/MyEclipse导入项目,Eclipse/MyEclipse导入时,若为maven项目请选择maven;
若为maven项目,导入成功后请执行maven clean;maven install命令,然后运行;
3. 将项目中conf.properties配置文件中的数据库配置改为自己的配置;
4. 运行项目,输入localhost:8080/ 登录
前台界面
- @Controller("frontArticleController")
- @RequestMapping("/")
- public class ArticleAction extends BaseController
{ - private static final String page_toList = "/front/article/articleList";
- private static final String page_toEdit = "/front/article/articleInfo";
-
- @Autowired
- private ArticleService articleService;
- @Override
- public Services
getService() { - return articleService;
- }
- public ArticleAction(){
- super.page_toList = page_toList;
- super.page_toEdit = page_toEdit;
- }
-
- /**
- * 跳转到文章列表
- * @param request
- * @param article
- * @return
- * @throws Exception
- */
- @RequestMapping("article")
- public String article(HttpServletRequest request, @ModelAttribute("e") Article article) throws Exception {
-
- this.initPageSelect();
- setParamWhenInitQuery(article);
- int offset = 0;
- if(request.getParameter("pager.offset")!=null){
- offset = Integer.parseInt(request.getParameter("pager.offset"));
- }
- if(offset < 0){
- offset=0;
- }
- article.setOffset(offset);
-
- PageModel page = getService().selectPageList(article);
- if(page == null){
- page = new PageModel();
- }
- page.setPageSize(10); //设置单页数据为10
- page.setPagerSize((page.getTotal() + page.getPageSize() - 1)
- / page.getPageSize());
- selectListAfter(page);
- page.setPagerUrl("article");
- request.setAttribute("pager", page);
- return page_toList;
- }
-
-
- /**
- * 文章详情
- * @param code
- * @param model
- * @return
- * @throws Exception
- */
- @RequestMapping("article/{code}")
- public String selectOne(HttpServletRequest request,@ModelAttribute("code")@PathVariable("code") String code,@ModelAttribute("e") Article article, ModelMap model) throws Exception {
- if(isInteger(code)) { //如果是数字 则为id 按id进行文章查询
- Article e = articleService.selectById(Integer.parseInt(code));
- e.setHit(String.valueOf(Integer.parseInt(e.getHit())+1));
- articleService.update(e); //更新浏览量 --优化建议:可使用缓存或者redis暂存 然后再刷入数据库
- Article next = articleService.selectNext(Integer.parseInt(code));
- if(next==null){
- next = new Article();
- }
- Article previous = articleService.selectPrevious(Integer.parseInt(code));
- if(previous==null){
- previous = new Article();
- }
- model.addAttribute("e", e);
- model.addAttribute("next", next);
- model.addAttribute("previous", previous);
- return page_toEdit;
- }else{//不是数字,则为分类编码
- for(ArticleCategory item: SystemManage.getInstance().getArticleCategory()){ //遍历分类缓存
- if(code.equals(item.getCode())){ //当编码相等时
- article.setCategoryId(String.valueOf(item.getId())); //把相等编码里的分类id值赋予文章中catagroyId中
- break; //跳出循环
- }
- }
- setParamWhenInitQuery(article);
- int offset = 0;
- if(request.getParameter("pager.offset")!=null){
- offset = Integer.parseInt(request.getParameter("pager.offset"));
- }
- if(offset < 0){
- offset=0;
- }
- article.setOffset(offset);
- PageModel page = getService().selectPageList(article);
- if(page == null){
- page = new PageModel();
- }
- page.setPageSize(10); //设置单页数据为10
- page.setPagerSize((page.getTotal() + page.getPageSize() - 1)
- / page.getPageSize());
- selectListAfter(page);
- page.setPagerUrl(code);
- request.setAttribute("pager", page);
- request.setAttribute("code", code);
- return page_toList;
- }
-
- }
-
- /**
- *判断是不是数字
- * @param code
- * @return
- */
- public static boolean isInteger(String code){
- try {
- Integer.parseInt(code);
- return true;
- }catch (NumberFormatException e){
- return false;
- }
- }
- }
如果也想学习本系统,下面领取。关注并回复:069ssm