PHP-MYSQL图书管理系统(附源码免费)

环境配置

本系统采用phpstudy开发平台,采用PHP和MySQL数据库进行开发,开发工具为HBuilder。phpStudy是一个PHP调试环境的程序集成最新的

Apache+PHP+MySQL+phpMyAdmin,一次性安装,无须配置即可使用,是非常方便、好用的PHP调试环境。(其他平台均可)@@@文末有获取方式免费获取
————————————————
含sql文件

主要功能

————————————————
管理员登录
管理员注册
图书上架
图书修改
图书下架
图书查询

主要语言

PHP MySQL JavaScript CSS bootstrap框架

运行截图

  • 登录

在这里插入图片描述

<div class="p-3 container">
			<h1 class='text-light d-flex justify-content-center fs-1 mt-3'style="width: 300px;margin: auto;">管理员登录</h1>
			<div class="w-50 col-lg-6 offset-lg-3 mt-5">
				<form action="login.php" method="post" class="container">
					<div class="row mb-3">
						<label for="username" class="col-sm-2 col-form-label fw-bolder">用户名</label>
						<div class="col-sm-6">
							<input class="form-control" id="username" type="text" placeholder="请输入用户名" name="username" required/>
						</div>
						<div class="col-sm-4" id="box1"></div><!-- 展示提示信息 -->
					</div>
					<div class="row mb-3">
						<label for="password" class="col-sm-2 col-form-label fw-bolder">密&emsp;码</label>
						<div class="col-sm-6">
							<input class="form-control" id="password" type="password" placeholder="请输入密码" name="password" required/>
						</div>
						<div class="col-sm-4" id="box2"></div><!-- 展示提示信息 -->
					</div>
					
					<div class="row mb-3">
						<label for="checkCode" class="col-sm-2 col-form-label fw-bolder">验证码</label>
						<div class="col-sm-6">
							<input class="form-control" id="checkCode" type="number" placeholder="请输入下图加法计算结果" name="checkCode" min="0" max="100" required onblur="check_code()"/>
						</div>
						<div class="col-sm-4" id="box3"></div><!-- 展示提示信息 -->
					</div>
					<div class="row mb-3">
						<label for="checkCode" class="col-sm-2 col-form-label fw-bolder">图&emsp;片</label>
						<div class="col-sm-4">
							<img id="img" src="yanzhengma_add.php" onclick="refresh()"><br/><br/>
						</div>
					</div>
					
					<div class="d-flex justify-content-between">
						<div >
							<a href="zhuce.html">
								<button type="button" class="btn btn-danger">暂无账号,点击注册</button>
							</a>
						</div>
						<div >
							<button id="login" type="submit" class="btn btn-primary">点击登录</button>
  • 注册

在这里插入图片描述

if($_POST){
		// 拿到用户输入的用户名,去数据库里面查询
		$sql01="select manager_username from manager_info where manager_username = ? ";	// 1.1.定义sql--查询
		$pre01 = $conn->prepare($sql01);	// 1.2.执行预处理,获取预处理结果对象
		$pre01->bind_param("s",$uname01);	// 1.3.将字段与预处理绑定。$uname指向sql语句里面的'?'。
		$uname01 = $_POST["username"];	// 1.4.为参数赋值:用户名来源于注册页面的用户输入信息
		$pre01->execute(); 	// 1.5 执行查询
		// 如果用户名已经存在,就提示用户重新注册
		if($pre01->fetch()){	// 1.6判断执行结果,fetch()获取查询到的数据,如果有值就提示重名
			die( "该用户名已被占用,请重新注册<br/><a href='zhuce.html'>点击重新注册</a>");
		}else{
			// 1.定义sql--添加
			$sql02="insert into manager_info (manager_id, manager_username, manager_password) values (null, ?, ?)";
			// 2.执行预处理,获取预处理结果对象
			$pre02 = $conn->prepare($sql02);
			// 3.将字段与预处理绑定
			$pre02->bind_param("ss",$manager_username, $manager_password); // s:string   i:int
			// 4.为参数赋值:用户,密码
			$manager_username = trim($_POST["username"]);
			$manager_password = sha1(md5(trim($_POST["password"])));  // 对密码进行加密
			// 5.判断执行结果
			if(!$pre02->execute()){
				die( "注册失败<br/><a href='zhuce.html'>点击重新注册</a>");
			}else{
				echo '
				<div class="modal fade" id="delModal" tabindex="-1" aria-labelledby="delModalLabel" aria-hidden="true">
					<div class="modal-dialog">
						<div class="modal-content">
							<div class="modal-header">
								<h5 class="modal-title" id="delModalLabel">注册成功!</h5>
								<button type="button" class="btn-close" data-bs-dismiss="modal" aria-label="Close" onclick="goToLogin()"></button>
							</div>
							<div class="modal-body">
								即将进入登录页面。
  • 系统首页

在这里插入图片描述

if($result->num_rows > 0){   // num_rows 查询的结果行数
				// 输出表格头部信息	
				echo "
				<h3 class='text-light d-flex justify-content-center fs-2 bg-dark mt-3'>图书信息表</h3>
				<table class='table table-bordered table-hover table-responsive text-nowrap'>
					<tr class='fs-5'>
						<th class='text-primary'>图书编号</th>
						<th class='text-primary'>书名</th>
						<th class='text-primary'>作者</th>
						<th class='text-primary'>出版社</th>
						<th class='text-primary'>页码</th>
						<th class='text-primary'>数量</th>
						<th class='de d-flex justify-content-center text-primary'>操作</th>
					</tr>";
				
				while($row = $result->fetch_assoc()){    // fetch_assoc()从结果集中取得一行作为关联数组
					echo 
					"<tr>
						<td class='text-secondary fs-5'>{$row['book_id']}</td>
						<td class='text-secondary fs-5'>{$row['book_name']}</td>
						<td class='text-secondary fs-5'>{$row['author']}</td>
						<td class='text-secondary fs-5'>{$row['publisher']}</td>
						<td class='text-secondary fs-5'>{$row['page']}</td>
						<td class='text-secondary fs-5'>{$row['number']}</td>
						<td class='d-flex justify-content-center'>
							<a href='operate.php?action=delete&id={$row['book_id']}'>
								<button class='btn btn-danger' onclick='javascript:return del()'>删除</button>
							</a>&emsp;  
							<a href='update.php?id={$row['book_id']}'>
								<button class='btn btn-primary'>修改</button>
							</a>
  • 添加图书

在这里插入图片描述

$sql01="select book_name from book_info where book_name = ? ";	// 1.1.定义sql--查询
		$pre01 = $conn->prepare($sql01);	// 1.2.执行预处理,获取预处理结果对象
		$pre01->bind_param("s",$book_name);	// 1.3.将字段与预处理绑定。$uname指向sql语句里面的'?'。
		$book_name = $_POST["bookname"];	// 1.4.为参数赋值:用户名来源于注册页面的用户输入信息
		$pre01->execute(); 	// 1.5 执行查询
		
		if($pre01->fetch()){	// 1.6判断执行结果,fetch()获取查询到的数据,如果有值就提示重名
			die( "该书名已被占用,请重新录入<br/><a href='add.html'>点击重新录入</a>");
		}else{
			// 1.定义sql--添加
			$sql02="insert into book_info (book_id, book_name, author, publisher, page, number) values (null, ?, ?, ?, ?, ?)";
			// 2.执行预处理,获取预处理结果对象
			$pre02 = $conn->prepare($sql02);
			// 3.将字段与预处理绑定
			$pre02->bind_param("sssii", $book_name, $author, $publisher, $page, $number); // s:string   i:int
			// 4.为参数赋值:用户,密码
			$book_name = $_POST["bookname"];
			$author = $_POST["author"];
			$publisher = $_POST["publisher"];
			$page = @$_POST["page"]; 
			$number = $_POST["number"];
			// 5.判断执行结果
			if(!$pre02->execute()){
				die( "<script>alert('添加成功!');window.location.href='add.html';</script>");
			}else{
				echo "<script>alert('添加成功!');window.location.href='index.php';</script>";
			}
  • 修改图书

在这里插入图片描述

	<?php
		    include "conn.php";
		    $sql="select * from book_info where book_id = ?";	
			$pre = $conn->prepare($sql);
			$pre->bind_param("i",$book_id);
			$book_id = $_GET['id'];
			$pre->bind_result($book_id, $book_name, $author, $publisher, $page, $number);
			$pre->execute(); 	
			$pre->fetch(); 
	    ?>
  • 文件目录

在这里插入图片描述
演示视频

图书管理系统总体上分为前台页面显示和后台管理。 前台页面(即本书图书管理系统的首页)实现了公告的显示,图书查询,留言建议三大主要功能,有读者规则查看功能,师生们可以看到图书管理人员发布的最新公告信息,并可以查询自己感兴趣的图书,查看留言提议,用户登录后还有个人资料修改、个人借阅信息查询、个人违章信息查询等功能,也可以给学校的图书管理人员留言提议。 后台的页面则集成了图书管理中所需的功能,分成图书管理人员和系统管理人员,平时管理人员的工作都是在后台中完成的。前台是为了师生显示的。相对应的后台是针对学校图书管理人员,后台的页面都加密,如果不正常登录是进入不了后台管理页面的,后台图书管理人员功能包括:借阅图书、归还图书、借书记录显示与查找、还书记录显示与查找、公告增删改查;后台系统管理员功能包括:对书籍的增删改查、对书籍分类的增删改、对借阅证的增删改查、对借阅信息的显示与查找、对借阅规则的增删改、对图书管理员的增删改、对近期借阅书籍数量的折线图显示,以及对这些表格数据进行Excel表格的输出 共包含三个大模块:用户、图书管理员、系统管理员 一、用户模块 查看公告:能看到图书管理员发布的公告信息。 图书查看:分页显示,能看到图书总览,能通过图书编号、图书名称、作者、存放位置、图书描述进行模糊查询 个人违章信息(登录后):个人历史违章信息与查询 图书馆读者留言(登录后):对图书馆的建议,或对书籍的评价 查看借阅规则:不同的规则有不同的借阅限定数量、限定时间、超期费用 个人信息(登录后):对个人信息的查看与登录密码的修改 个人借阅信息(登录后):对个人借阅记录的分页查看与查询 二、图书管理员模块 借还图书:帮助用户借阅图书,并判断符不符合借阅规则、返还图书时判断有没有超期,超期则输出超期费用再归还 借阅报表:分页显示所有借阅记录、能进行查询和输出结果到excel公告管理:能添加编辑和删除公告 还书报表:分页显示所有未还的书籍,能通过借阅证号、图书编号、借阅日期、截止日期等条件进行模糊查询 个人信息修改:修改个人信息、密码等 三、系统管理员模块 书籍管理:分页,新添图书,设置图书各种信息,编辑删除,通过编号、书名、作者、描述等进行搜索,输出结果到excel,并且能查看该书籍被谁借阅过。 分类管理:分页显示,增删改书籍分类,书籍分类方便查阅整理 借阅证管理:分页显示所有借阅证,增删改查用户借阅证,查看该借阅证所有的借阅记录 借阅规则管理:能显示、编辑、删除所有借阅规则,借阅规则将决定该图书证能借阅什么图书馆的图书,能借多少本,能借多久以及超期每天的费用。 借阅信息查询:分页显示,能条件查询超期没还的,根据编号、借阅证号、书籍编号、借阅日期等进行模糊查询,输出结果到excel等,系统管理员只能查询,不能增删改借阅信息,这个操作由图书管理员操作。 图书管理员管理:对图书管理员进行增删改操作,但是不能修改原来的账号 图书借阅统计:通过折线图将图书馆近30天的每天借阅书籍数量直观的显示出来。 sql表 共有十张数据库表,书籍表、借书记录表、留言表、系统管理员表、借阅证表、图书管理管理员表书籍分类表、图书馆表、借阅规则表、公告表 书籍表 编号、姓名、作者、存放的图书馆、分类编号、存放位置、是否借出、书籍描述 借书记录表 编号、借阅证编号、书籍编号、借书日期、限制日期、归还日期、违规描述、处理人编号 留言表 编号、借阅证编号、留言内容、留言日期 系统管理员表 账号、密码 借阅证表 编号、密码、借阅者姓名、规则编号、状态(丢失、可用) 图书管理员表 编号、姓名、账号、密码、邮箱 书籍分类表 编号、分类名、分类描述 图书馆表 编号、图书馆名、描述 规则表 编号、限制借阅数量、限制借阅天数、图书超期每天费用 公告表 编号、标题、公告内容、发布日期
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值