微信小程序毕业设计-报刊订阅系统项目开发实战(附源码+论文)

大家好!我是程序猿老A,感谢您阅读本文,欢迎一键三连哦。

💞当前专栏:微信小程序毕业设计

精彩专栏推荐👇🏻👇🏻👇🏻

🎀 Python毕业设计
🌎Java毕业设计

开发运行环境

①前端:微信小程序开发工具

② 后端:Java

  • 框架:ssm
  • JDK版本:JDK1.8
  • 服务器:tomcat7
  • 数据库:mysql 5.7
  • 数据库工具:Navicat12
  • 开发软件:eclipse/myeclipse/idea
  • Maven包:Maven3.3.9
  • 浏览器:谷歌浏览器

源码下载地址:

https://download.csdn.net/download/2301_76953549/89227577

论文目录

【如需全文请按文末获取联系】
在这里插入图片描述
在这里插入图片描述

一、项目简介

基于微信平台的报刊订阅小程序管理数据的工具是MySQL,编码的语言是Java,运用的框架是SSM框架。该系统可以实现对报刊信息,报刊订阅,订阅发送,报刊论坛,报刊类型等信息的管理。

二、系统设计

2.1软件功能模块设计

对管理员具体功能的设计结果将以图4.1所示的管理员功能结构图来进行体现。管理员对于基于微信平台的报刊订阅小程序操作的功能包括对报刊信息,报刊订阅信息,订阅发送信息,报刊论坛等进行管理。
在这里插入图片描述
对用户具体功能的设计结果将以图4.2所示的用户功能结构图来进行体现。用户对于基于微信平台的报刊订阅小程序操作的功能包括订阅报刊,查看订阅报刊的内容,发布关于报刊的帖子,在报刊论坛评论帖子,查看帖子等。

在这里插入图片描述

2.2数据库设计

(1)报刊订阅包括的属性有订阅编号,订阅价格,报刊类型等。其属性图如下。
在这里插入图片描述
(2)管理员包括的属性有密码,角色,用户名等。其属性图如下。
在这里插入图片描述
(3)报刊包括的属性有报刊名称,报刊封面,报刊类型等。其属性图如下。
在这里插入图片描述
(5)设计的各实体间关系E-R图如下。
在这里插入图片描述

三、系统项目部分截图

3.1管理员功能实现

报刊信息管理
该功能主要用于实现对报刊基本信息的管理,报刊信息管理界面的运行效果见图5.1。在此界面,管理员对包含有报刊名称,订阅价格等数据的报刊信息进行新增,查看报刊信息的评论,更改报刊信息等。
在这里插入图片描述
报刊订阅管理
该功能主要用于实现对报刊订阅基本信息的管理,报刊订阅管理界面的运行效果见图5.2。在此界面,管理员为订阅报刊的用户发送订阅信息,查看用户对订阅报刊的支付信息,需要删除的报刊订阅信息可以删除。
在这里插入图片描述
订阅发送管理
该功能主要用于实现对订阅发送基本信息的管理,订阅发送管理界面的运行效果见图5.3。在此界面,管理员查询已经发送给用户的订阅报刊的信息,查询条件是根据报刊名称查询,发现有错误数据的订阅发送信息可以修改。
在这里插入图片描述

3.2用户功能实现

报刊信息
报刊信息界面的运行效果见图5.6。在此界面,用户收藏喜欢的报刊,订阅需要的报刊,查看报刊的订阅价格,评论报刊等。
在这里插入图片描述
报刊订阅
报刊订阅界面的运行效果见图5.7。在此界面,用户查看已经提交的报刊订阅信息,并支付订阅报刊的价格。

在这里插入图片描述
订阅发送
订阅发送界面的运行效果见图5.8。在此界面,每当管理员发送用户订阅的报刊内容之后,用户可以及时查看报刊内容。
在这里插入图片描述

四、部分核心代码

package com.controller;

import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.Calendar;
import java.util.Map;
import java.util.HashMap;
import java.util.Iterator;
import java.util.Date;
import java.util.List;
import javax.servlet.http.HttpServletRequest;
import java.io.IOException;

import com.utils.ValidatorUtils;
import org.apache.commons.lang3.StringUtils;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.transaction.annotation.Transactional;
import org.springframework.format.annotation.DateTimeFormat;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;
import com.baomidou.mybatisplus.mapper.EntityWrapper;
import com.baomidou.mybatisplus.mapper.Wrapper;
import com.annotation.IgnoreAuth;

import com.entity.BaokanxinxiEntity;
import com.entity.view.BaokanxinxiView;

import com.service.BaokanxinxiService;
import com.service.TokenService;
import com.utils.PageUtils;
import com.utils.R;
import com.utils.MD5Util;
import com.utils.MPUtil;
import com.utils.CommonUtil;
import com.service.StoreupService;
import com.entity.StoreupEntity;

/**
 * 报刊信息
 * 后端接口
 * @author 
 * @email 
 * @date 2022-05-18 11:41:33
 */
@RestController
@RequestMapping("/baokanxinxi")
public class BaokanxinxiController {
    @Autowired
    private BaokanxinxiService baokanxinxiService;


    @Autowired
    private StoreupService storeupService;

    


    /**
     * 后端列表
     */
    @RequestMapping("/page")
    public R page(@RequestParam Map<String, Object> params,BaokanxinxiEntity baokanxinxi, 
		HttpServletRequest request){

        EntityWrapper<BaokanxinxiEntity> ew = new EntityWrapper<BaokanxinxiEntity>();
		PageUtils page = baokanxinxiService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, baokanxinxi), params), params));
        return R.ok().put("data", page);
    }
    
    /**
     * 前端列表
     */
	@IgnoreAuth
    @RequestMapping("/list")
    public R list(@RequestParam Map<String, Object> params,BaokanxinxiEntity baokanxinxi, 
		HttpServletRequest request){
        EntityWrapper<BaokanxinxiEntity> ew = new EntityWrapper<BaokanxinxiEntity>();
		PageUtils page = baokanxinxiService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, baokanxinxi), params), params));
        return R.ok().put("data", page);
    }

	/**
     * 列表
     */
    @RequestMapping("/lists")
    public R list( BaokanxinxiEntity baokanxinxi){
       	EntityWrapper<BaokanxinxiEntity> ew = new EntityWrapper<BaokanxinxiEntity>();
      	ew.allEq(MPUtil.allEQMapPre( baokanxinxi, "baokanxinxi")); 
        return R.ok().put("data", baokanxinxiService.selectListView(ew));
    }

	 /**
     * 查询
     */
    @RequestMapping("/query")
    public R query(BaokanxinxiEntity baokanxinxi){
        EntityWrapper< BaokanxinxiEntity> ew = new EntityWrapper< BaokanxinxiEntity>();
 		ew.allEq(MPUtil.allEQMapPre( baokanxinxi, "baokanxinxi")); 
		BaokanxinxiView baokanxinxiView =  baokanxinxiService.selectView(ew);
		return R.ok("查询报刊信息成功").put("data", baokanxinxiView);
    }
	
    /**
     * 后端详情
     */
    @RequestMapping("/info/{id}")
    public R info(@PathVariable("id") Long id){
        BaokanxinxiEntity baokanxinxi = baokanxinxiService.selectById(id);
		baokanxinxi.setClicknum(baokanxinxi.getClicknum()+1);
		baokanxinxi.setClicktime(new Date());
		baokanxinxiService.updateById(baokanxinxi);
        return R.ok().put("data", baokanxinxi);
    }

    /**
     * 前端详情
     */
	@IgnoreAuth
    @RequestMapping("/detail/{id}")
    public R detail(@PathVariable("id") Long id){
        BaokanxinxiEntity baokanxinxi = baokanxinxiService.selectById(id);
		baokanxinxi.setClicknum(baokanxinxi.getClicknum()+1);
		baokanxinxi.setClicktime(new Date());
		baokanxinxiService.updateById(baokanxinxi);
        return R.ok().put("data", baokanxinxi);
    }
    



    /**
     * 后端保存
     */
    @RequestMapping("/save")
    public R save(@RequestBody BaokanxinxiEntity baokanxinxi, HttpServletRequest request){
    	baokanxinxi.setId(new Date().getTime()+new Double(Math.floor(Math.random()*1000)).longValue());
    	//ValidatorUtils.validateEntity(baokanxinxi);

        baokanxinxiService.insert(baokanxinxi);
        return R.ok();
    }
    
    /**
     * 前端保存
     */
    @RequestMapping("/add")
    public R add(@RequestBody BaokanxinxiEntity baokanxinxi, HttpServletRequest request){
    	baokanxinxi.setId(new Date().getTime()+new Double(Math.floor(Math.random()*1000)).longValue());
    	//ValidatorUtils.validateEntity(baokanxinxi);

        baokanxinxiService.insert(baokanxinxi);
        return R.ok();
    }

    /**
     * 修改
     */
    @RequestMapping("/update")
    @Transactional
    public R update(@RequestBody BaokanxinxiEntity baokanxinxi, HttpServletRequest request){
        //ValidatorUtils.validateEntity(baokanxinxi);
        baokanxinxiService.updateById(baokanxinxi);//全部更新
        return R.ok();
    }
    

    /**
     * 删除
     */
    @RequestMapping("/delete")
    public R delete(@RequestBody Long[] ids){
        baokanxinxiService.deleteBatchIds(Arrays.asList(ids));
        return R.ok();
    }
    
    /**
     * 提醒接口
     */
	@RequestMapping("/remind/{columnName}/{type}")
	public R remindCount(@PathVariable("columnName") String columnName, HttpServletRequest request, 
						 @PathVariable("type") String type,@RequestParam Map<String, Object> map) {
		map.put("column", columnName);
		map.put("type", type);
		
		if(type.equals("2")) {
			SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
			Calendar c = Calendar.getInstance();
			Date remindStartDate = null;
			Date remindEndDate = null;
			if(map.get("remindstart")!=null) {
				Integer remindStart = Integer.parseInt(map.get("remindstart").toString());
				c.setTime(new Date()); 
				c.add(Calendar.DAY_OF_MONTH,remindStart);
				remindStartDate = c.getTime();
				map.put("remindstart", sdf.format(remindStartDate));
			}
			if(map.get("remindend")!=null) {
				Integer remindEnd = Integer.parseInt(map.get("remindend").toString());
				c.setTime(new Date());
				c.add(Calendar.DAY_OF_MONTH,remindEnd);
				remindEndDate = c.getTime();
				map.put("remindend", sdf.format(remindEndDate));
			}
		}
		
		Wrapper<BaokanxinxiEntity> wrapper = new EntityWrapper<BaokanxinxiEntity>();
		if(map.get("remindstart")!=null) {
			wrapper.ge(columnName, map.get("remindstart"));
		}
		if(map.get("remindend")!=null) {
			wrapper.le(columnName, map.get("remindend"));
		}


		int count = baokanxinxiService.selectCount(wrapper);
		return R.ok().put("count", count);
	}
	
	/**
     * 前端智能排序
     */
	@IgnoreAuth
    @RequestMapping("/autoSort")
    public R autoSort(@RequestParam Map<String, Object> params,BaokanxinxiEntity baokanxinxi, HttpServletRequest request,String pre){
        EntityWrapper<BaokanxinxiEntity> ew = new EntityWrapper<BaokanxinxiEntity>();
        Map<String, Object> newMap = new HashMap<String, Object>();
        Map<String, Object> param = new HashMap<String, Object>();
		Iterator<Map.Entry<String, Object>> it = param.entrySet().iterator();
		while (it.hasNext()) {
			Map.Entry<String, Object> entry = it.next();
			String key = entry.getKey();
			String newKey = entry.getKey();
			if (pre.endsWith(".")) {
				newMap.put(pre + newKey, entry.getValue());
			} else if (StringUtils.isEmpty(pre)) {
				newMap.put(newKey, entry.getValue());
			} else {
				newMap.put(pre + "." + newKey, entry.getValue());
			}
		}
		params.put("sort", "clicknum");
        
        params.put("order", "desc");
		PageUtils page = baokanxinxiService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, baokanxinxi), params), params));
        return R.ok().put("data", page);
    }







}

五、获取源码或论文

如需对应的论文或源码,以及其他定制需求,也可以下方微❤联系。

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值