基于微信小程序的线上教育商城小程序

文末联系获取源码

开发语言:Java

框架:ssm

JDK版本:JDK1.8

服务器:tomcat7

数据库:mysql 5.7/8.0

数据库工具:Navicat11

开发软件:eclipse/myeclipse/idea

Maven包:Maven3.3.9

浏览器:谷歌浏览器

小程序框架:uniapp

小程序开发软件:HBuilder X

小程序运行软件:微信开发者

一、前言介绍 

现代经济快节奏发展以及不断完善升级的信息化技术,让传统数据信息的管理升级为软件存储,归纳,集中处理数据信息的管理方式。本微信小程序线上教育商城就是在这样的大环境下诞生,其可以帮助管理者在短时间内处理完毕庞大的数据信息,使用这种软件工具可以帮助管理人员提高事务处理效率,达到事半功倍的效果。此微信小程序线上教育商城利用当下成熟完善的SSM框架,使用跨平台的可开发大型商业网站的Java语言,以及最受欢迎的RDBMS应用软件之一的 MySQL数据库进行程序开发。微信小程序线上教育商城有管理员,教师,学生三个角色。管理员功能有个人中心,学生管理,教师管理,类型管理,课程信息管理,订单信息管理,付费课程管理,系统管理。教师和学生都可以注册登录,教师登录后可以发布付费课程,管理员审核付费课程,学生查看和购买付费课程,收藏课程等。微信小程序线上教育商城的开发根据操作人员需要设计的界面简洁美观,在功能模块布局上跟同类型网站保持一致,程序在实现基本要求功能时,也为数据信息.面临的安全间题提供了一些实用的解决方案。可以说该程序在帮助管理者高效率地处理工作事务的同时,也实现了数据信息的整体化,规范化与自动化。

二、系统功能结构设计

在分析并得出使用者对程序的功能要求时,就可以进行程序设计了。如图展示的就是管理员功能结构图。 

基于微信小程序的线上教育商城小程序_第1张图片

三、微信小程序功能实现

3.1首页

如图显示的就是小程序首页页面,学生用户可以看到公告信息以及下面的导航栏。

基于微信小程序的线上教育商城小程序_第2张图片

3.2付费课程 

如图显示的就是付费课程页面,这里主要显示当前学生用户已经付费过的课程。 

基于微信小程序的线上教育商城小程序_第3张图片

3.3学生用户购买课程 

如图显示的就是学生用户购买课程页面,学生用户登录后可以查看课程信息,可以对课程信息收藏和购买操作。 

基于微信小程序的线上教育商城小程序_第4张图片

3.4我的

如图显示的就是我的页面,我的里面可以查看订单和收藏,点击小齿轮还可以退出当前用户。 

基于微信小程序的线上教育商城小程序_第5张图片

四、管理员后台功能实现 

4.1用户管理

如图显示的就是学生用户管理页面,此页面提供给管理员的功能有:对用户信息进行查询,添加,删除以及批量删除操作。

基于微信小程序的线上教育商城小程序_第6张图片

4.2教师管理 

如图显示的就是教师管理页面,管理员可以对教师信息进行添加,修改,删除,查询操作。 

基于微信小程序的线上教育商城小程序_第7张图片

4.3类型管理

如图显示的就是类型管理页面,管理员可以对类型信息进行添加,修改,删除,查询操作。 

基于微信小程序的线上教育商城小程序_第8张图片

4.4公告信息管理 

如图显示的就是公告信息管理页面,管理员可以对公告信息进行添加修改删除查询操作。

基于微信小程序的线上教育商城小程序_第9张图片

4.5课程信息管理 

如图显示的就是课程信息管理页面,教师可以对课程信息进行添加修改删除查询操作。 

基于微信小程序的线上教育商城小程序_第10张图片

五、部分核心代码

5.1登录系统主要代码

/**
	 * 登录
	 */
	@IgnoreAuth
	@RequestMapping(value = "/login")
	public R login(String username, String password, String captcha, HttpServletRequest request) {
		YonghuEntity user = yonghuService.selectOne(new EntityWrapper().eq("yonghuzhanghao", username));
		if(user==null || !user.getMima().equals(password)) {
			return R.error("账号或密码不正确");
		}
		
		String token = tokenService.generateToken(user.getId(), username,"yonghu",  "用户" );
		return R.ok().put("token", token);
	}

5.2上传文件关键代码

@RequestMapping("/upload")
	public R upload(@RequestParam("file") MultipartFile file,String type) throws Exception {
		if (file.isEmpty()) {
			throw new EIException("上传文件不能为空");
		}
		String fileExt = file.getOriginalFilename().substring(file.getOriginalFilename().lastIndexOf(".")+1);
		File path = new File(ResourceUtils.getURL("classpath:static").getPath());
		if(!path.exists()) {
		    path = new File("");
		}
		File upload = new File(path.getAbsolutePath(),"/upload/");
		if(!upload.exists()) {
		    upload.mkdirs();
		}
		String fileName = new Date().getTime()+"."+fileExt;
		File dest = new File(upload.getAbsolutePath()+"/"+fileName);
		file.transferTo(dest);
		/**
  		 * 如果使用idea或者eclipse重启项目,发现之前上传的图片或者文件丢失,将下面一行代码注释打开
   		 * 请将以下的"D:\\springbootq33sd\\src\\main\\resources\\static\\upload"替换成你本地项目的upload路径,
 		 * 并且项目路径不能存在中文、空格等特殊字符
 		 */
//		FileUtils.copyFile(dest, new File("D:\\springbootq33sd\\src\\main\\resources\\static\\upload"+"/"+fileName)); /**修改了路径以后请将该行最前面的//注释去掉**/
		if(StringUtils.isNotBlank(type) && type.equals("1")) {
			ConfigEntity configEntity = configService.selectOne(new EntityWrapper().eq("name", "faceFile"));
			if(configEntity==null) {
				configEntity = new ConfigEntity();
				configEntity.setName("faceFile");
				configEntity.setValue(fileName);
			} else {
				configEntity.setValue(fileName);
			}
			configService.insertOrUpdate(configEntity);
		}
		return R.ok().put("file", fileName);
	}

你可能感兴趣的:(微信小程序,微信小程序,小程序,java,毕业设计,mysql)