基于springboot的婚纱摄影网站

Posted 猫头鹰源码(同名B站)

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了基于springboot的婚纱摄影网站相关的知识,希望对你有一定的参考价值。

博主主页猫头鹰源码

博主简介:Java领域优质创作者、CSDN博客专家、公司架构师、全网粉丝5万+、专注Java技术领域和毕业设计项目实战

主要内容:毕业设计(Javaweb项目|小程序等)、简历模板、学习资料、面试题库、技术咨询

文末联系获取

项目介绍: 

该系统基于springboot技术,mysql数据库,页面采用html,具有完整的业务逻辑,适合选题:springboot、婚纱、摄影、婚纱摄影等。

项目功能:

1 网站管理
1.1 轮播图管理
概述:所管理的轮播图为首页展示的三张轮播图(规定只能三张显示)

新增:点击新增按钮

①、填写轮播图的标题(此标题为鼠标放上轮播图照片时显示的文字)

②、上传所要展示的照片,图片建议尺寸: 1922像素 * 544像素

③点击保存即可

修改

①、点击修改按钮、只能修改标题,如要修改照片请删除后重新添加

删除

①、点击删除按钮即可

1.2 资讯管理
概述:热门活动所展示的

新增:点击新增按钮

①、填写标题(此标题为文章标题)

②、填写活动内容

③、上传所要展示的照片,图片建议尺寸: 890像素 * 593像素

④、点击保存即可

修改

①、点击修改按钮、只能修改标题和内容,如要修改照片请删除后重新添加

删除

①、点击修改按钮,选择状态为禁用

2 摄影管理
2.1 整体流程

2.2 级别管理
概述:为摄影师的级别

新增:点击新增按钮

①、填写级别名称

②、点击保存即可

修改

①、点击修改按钮

删除

①、点击修改按钮,选择状态为禁用

2.3 标签管理
概述:为摄影师的标签

新增:点击新增按钮

①、填写标签名称

②、点击保存即可

修改

①、点击修改按钮

删除

①、点击修改按钮,选择状态为禁用

2.4 拍摄景点管理
概述:拍摄景点,常驻馆

新增:点击新增按钮

①、填写景点名称、景点描述、状态

②、上传所要景点的照片(只能一张),图片建议尺寸: 855像素 * 520像素

③、点击保存即可

修改

①、点击修改按钮、只能景点名称、景点描述,如要修改照片请删除后重新添加

删除

①、点击修改按钮,选择状态为禁用

2.5 摄影师管理
概述:摄影师

新增:点击新增按钮

①、填写摄影师名称、摄影师描述、选择标签、选择级别、选择常驻馆(就是景点)

②、上传所摄影师头像,图片建议尺寸: 270像素 * 270像素

③、点击保存即可

修改

①、点击修改按钮、只能景点名称、景点描述,如要修改照片请删除后重新添加

删除

①、点击修改按钮,选择状态为禁用或者点击状态栏中的按钮,YES为启用 NO为禁用

2.6 客片管理
概述:摄影师的客片

新增:点击新增按钮

①、填写作品标题、作品描述、选择摄影师、选择常驻馆(就是景点)

②、上传所拍摄的客片的照片(点击添加附件按钮,支持多张照片),图片建议尺寸: 无

③、点击保存即可

④、设置客片的封面(很重要),点击设置封面按钮,然后上传照片,图片建议尺寸: 290像素 * 380像素

修改

①、点击修改按钮、只能作品标题、作品描述,如要修改照片请删除后重新添加

删除

①、点击状态栏中的按钮,YES为启用 NO为禁用

3 用户订单管理
3.1 订单管理
概述:用户的预约和已预约和摄影师的无档期设置

无档期设置

①、选择摄影师

②、选择无档期的时间,点击确定

③、选择该摄影师该时间段是没有空无档期还是已经有预约了

④、点击保存即可

接收

①、点击接收按钮,即为接受该用户的预约

拒绝

①、点击拒绝按钮,即为拒绝该用户的预约

* 很重要的一点,无档期设置和接收、拒绝设置时必须时时间段无冲突的,必须再三确认。

系统包含技术:

后端:springboot
前端:js、css,html页面
开发工具:idea
数据库:mysql 5.7
JDK版本:jdk1.8

部分截图说明:

下面是首页

客片欣赏,后台可以维护 

 

拍摄景点维护

选择摄影师

预约摄影师

预约

用户登录后查看订单

 后台-登录

 后台-管理员首页

 后台-订单管理

后台-级别维护

 后台-摄影师管理

后台-资讯活动管理

 后台-景点维护

部分代码:

过滤器


@Configuration
public class FilterConfiguration 
    @Bean
    public FilterRegistrationBean filterAdminRegistration() 
        FilterRegistrationBean registration = new FilterRegistrationBean();
        //注入过滤器
        registration.setFilter(new AdminFilter());
        //拦截规则
        registration.addUrlPatterns("/manage/page/*","/manage/home.html","/manage/index.html");
        //过滤器名称
        registration.setName("AdminFilter");
        //是否自动注册 false 取消Filter的自动注册
        registration.setEnabled(true);
        //过滤器顺序
        registration.setOrder(2);
        return registration;
    
    @Bean
    public FilterRegistrationBean filterLoginRegistration() 
        FilterRegistrationBean registration = new FilterRegistrationBean();
        //注入过滤器
        registration.setFilter(new LoginFilter());
        //拦截规则
        registration.addUrlPatterns("/member.html");
        //过滤器名称
        registration.setName("LoginFilter");
        //是否自动注册 false 取消Filter的自动注册
        registration.setEnabled(true);
        //过滤器顺序
        registration.setOrder(1);
        return registration;
    

public void doFilter(ServletRequest arg0, ServletResponse arg1,
			FilterChain arg2) throws IOException, ServletException 
		HttpServletRequest request=(HttpServletRequest)arg0;
		HttpServletResponse response=(HttpServletResponse)arg1;
		HttpSession session = request.getSession();
		
		
		if(session.getAttribute("admin")!=null)
			arg2.doFilter(arg0, arg1);
		else
			response.sendRedirect("/manage/login.html");
		
	

	public void init(FilterConfig arg0) throws ServletException 
	

摄影师操作

/**
	 * 分页获取photographer
	 * 
	 * @return
	 */
	@RequestMapping(value = "getPhotographerListByPage", method = RequestMethod.POST)
	@ResponseBody
	public ReturnResult getPhotographerListByPage(PageVO page, String labelId, String levelId, String spotsId,
			String beforeTime, String afterTime, String status, String name) 
		returnResult.setStatus(ReturnCodeType.FAILURE);
		try 
			Map<String, Object> resultMap = new HashMap<String, Object>();
			StringBuffer sql = new StringBuffer(
					"SELECT a.*,f.`name` AS label,g.`name` AS level,h.`name` AS spots FROM t_photographer a," +
							"t_photographer_label b,t_photographer_level c ,t_photographer_spots d,t_label f," +
							"t_level g,t_spots h WHERE a.id=b.photographerId AND a.id = c.photographer " +
							"AND a.id = d.photographerId AND f.id=b.labelId AND g.id=c.levelId AND h.id= d.spotsId");
			if (StringUtils.isNotBlank(labelId)) 
				sql.append(" AND b.labelId=" + labelId);
				sql.append(" AND f.id=" + labelId);
			
			if (StringUtils.isNotBlank(levelId)) 
				sql.append(" AND c.levelId=" + levelId);
				sql.append(" AND g.id=" + levelId);
			
			if (StringUtils.isNotBlank(spotsId)) 
				sql.append(" AND d.spotsId=" + spotsId);
				sql.append(" AND h.id=" + spotsId);
			
			if (StringUtils.isNotBlank(status)) 
				sql.append(" AND a.status=" + status);
			
			if (StringUtils.isNotBlank(name)) 
				sql.append(" AND a.name=" + name);
			
			List<Map<String, Object>> results = photographerService.selectPageBySQL(sql.toString(), page.getPage() - 1,
					page.getRows());
			if (!results.isEmpty() && results != null) 
				int total = photographerService.selectCount(new TPhotographer());
				int rows = page.getRows();
				rows = rows == 0 ? 10 : rows;
				resultMap.put("total", (total % rows != 0 ? (total / rows + 1) : (total / rows)));
				resultMap.put("page", page.getPage());
				resultMap.put("records", total);
				resultMap.put("rows", results);
				returnResult.setStatus(ReturnCodeType.SUCCESS).setData(resultMap);
			
		 catch (Exception e) 
			logger.error("分页获取photographer失败" + e);
		
		return returnResult;
	

	/**
	 * 分页获取启用的photographer
	 * 
	 * @return
	 */
	@RequestMapping(value = "getPhotographerListByPageStatus", method = RequestMethod.POST)
	@ResponseBody
	public ReturnResult getPhotographerListByPageStatus(PageVO page, String labelId, String levelId, String spotsId,
			String start, String end) 
		returnResult.setStatus(ReturnCodeType.FAILURE);
		try 
			Map<String, Object> resultMap = new HashMap<String, Object>();
			StringBuffer sql = new StringBuffer(
					"SELECT a.*,f.`name` AS label,g.`name` AS level,h.`name` AS spots FROM t_photographer a,t_photographer_label b,t_photographer_level c ,t_photographer_spots d,t_label f,t_level g,t_spots h WHERE a.id=b.photographerId AND a.id = c.photographer AND a.id = d.photographerId AND f.id=b.labelId AND g.id=c.levelId AND h.id= d.spotsId AND a.status=0");

			StringBuffer countSql = new StringBuffer("SELECT COUNT(*) AS total FROM t_photographer a,t_photographer_label b,t_photographer_level c ,t_photographer_spots d,t_label f,t_level g,t_spots h WHERE a.id=b.photographerId AND a.id = c.photographer AND a.id = d.photographerId AND f.id=b.labelId AND g.id=c.levelId AND h.id= d.spotsId AND a.status=0");
			if (StringUtils.isNotBlank(start) && StringUtils.isNotBlank(end)) 
				List<String> list = photographerService.selectByStartEnd(start,end);
				for(String id : list)
					sql.append(" AND a.id!="+id);
					countSql.append(" AND a.id!="+id);
				
			
			if (StringUtils.isNotBlank(labelId)) 
				sql.append(" AND b.labelId=" + labelId);
				sql.append(" AND f.id=" + labelId);
				countSql.append(" AND b.labelId=" + labelId);
				countSql.append(" AND f.id=" + labelId);
			
			if (StringUtils.isNotBlank(levelId)) 
				sql.append(" AND c.levelId=" + levelId);
				sql.append(" AND g.id=" + levelId);
				countSql.append(" AND c.levelId=" + levelId);
				countSql.append(" AND g.id=" + levelId);
			
			if (StringUtils.isNotBlank(spotsId)) 
				sql.append(" AND d.spotsId=" + spotsId);
				sql.append(" AND h.id=" + spotsId);
				countSql.append(" AND d.spotsId=" + spotsId);
				countSql.append(" AND h.id=" + spotsId);
			

			List<Map<String, Object>> results = photographerService.selectPageBySQL(sql.toString(), page.getPage() - 1,
					page.getRows());
			if (!results.isEmpty() && results != null) 
				int total = Integer.valueOf( photographerService.selectBySQL(countSql.toString()).get(0).get("total").toString());
				int rows = page.getRows();
				rows = rows == 0 ? 10 : rows;
				resultMap.put("total", (total % rows != 0 ? (total / rows + 1) : (total / rows)));
				resultMap.put("page", page.getPage());
				resultMap.put("records", total);
				resultMap.put("rows", results);
				returnResult.setStatus(ReturnCodeType.SUCCESS).setData(resultMap);
			
		 catch (Exception e) 
			logger.error("分页获取启用的photographer失败" + e);
		
		return returnResult;
	

	/**
	 * 获取所有启用的Photographer
	 * 
	 * @param Photographer
	 * @return
	 */
	@RequestMapping(value = "getAllPhotographer", method = RequestMethod.POST)
	@ResponseBody
	public ReturnResult getAllPhotographer() 
		returnResult.setStatus(ReturnCodeType.FAILURE);
		try 
			returnResult.setStatus(ReturnCodeType.SUCCESS).setData(photographerService.selectBySQL(
					"SELECT a.id,a.name FROM t_photographer a,t_photographer_label b,t_photographer_level c ,t_photographer_spots d,t_label f,t_level g,t_spots h WHERE a.id=b.photographerId AND a.id = c.photographer AND a.id = d.photographerId AND f.id=b.labelId AND g.id=c.levelId AND h.id= d.spotsId AND a.status=0"));
		 catch (Exception e) 
			logger.error("获取所有启用的Photographer失败" + e);
		
		return returnResult;
	

以上就是部分功能展示,从整体上来看,本系统功能是十分完整的,界面设计简洁大方,交互友好,数据库设计也很合理,规模适中,代码工整,清晰,适合学习使用。

好了,今天就到这儿吧,小伙伴们点赞、收藏、评论,一键三连走起呀,下期见~~

基于JavaWEB SSM SpringBoot婚纱影楼摄影预约网站设计和实现

本项目演示链接地址 》

主要功能设计:

运行环境: java jdk 1.8
环境:IDEA
tomcat环境: Tomcat 7.x,8
主要功能说明: 管理员角色包含以下功能:管理员登录,订单管理,摄影师管理,级别管理,标签管理,摄影地点管理,客片管理,轮播图管理,资讯管理等功能。
客户角色包含以下功能:客户首页,客片欣赏,预约摄影师,会员登录,填写预约摄影师信息,查看活动,订单查看等功能。
技术框架: HTML+CSS+JavaScript+jsp+mysql+Spring+SpringMVC+mybatis+Spring boot
数据库: Mysql数据库

主要功能截图如下:

以上是关于基于springboot的婚纱摄影网站的主要内容,如果未能解决你的问题,请参考以下文章

java基于springboot+vue的婚庆信息网站-摄影影楼信息网站-计算机毕业设计

JavaWeb SpringBoot SSM 婚纱影楼摄影预约网站(源码+sql可直接运行完整版《精品毕设》)主要功能实现:登录,订单,摄影师,级别,标签,摄影地点,客片,轮播图等管理

Java项目:婚纱影楼摄影预约网站设计和实现(javaweb+SSM+springboot)

基于Java+SpringBoot+vue+element实现婚纱摄影网系统

基于Java+SpringBoot+vue+element实现婚纱摄影网系统

基于java婚纱摄影租赁网站