随着时代的发展,共享单车越来越受到人们的欢迎,尤其是在一些大型城市中我们随处可见这些共享单车,用户通过扫码等方式可以非常方便的获取对单车的使用权只需要在使用期间支付对应的租金即可。
本系统是一个通过PHP来进行开发的共享单车管理系统,系统通过PHP:MySQL进行开发,在开发的时候分为用户和管理人员两部分,用户在注册登录之后可以进行车辆的查询和租借,管理人员可以对整个系统进行管理
本页面是系统管理人员的一个操作界面,在这里我们可以看到系统管理员所具备的所有功能。
用户部分功能
注册登录
查看并租赁单车
个人资料管理
租赁信息
归还记录
报修查询
系统信息
管理员部分功能
用户管理
自行车信息管理
租赁记录
归还记录
故障报修管理
论坛管理
系统信息
随着社会科技的发展进步,机动车已经成为大众消费品,发展初期较少的机动车方便了人们的交流,给人们带来了极大的便利,但随着数量的持续增长,依据辩证法之对立统一及质量互变两个哲学规律,我们可以清晰的得到私家车的激增已经从给人们带来方便转化为给人们造成困扰:环境污染,能源短缺,交通拥堵,交通噪音,停车困扰。这些问题或多或少都与机动车交通直接或间接相关。日益尖锐的问题已经不得不让人们引起注意了。为了应对这些困扰人们日常生活的问题,一个新的概念已经被提出:共享单车。早在建国初期,我国是自行车大国,自行车承担了主要的出行作用,尽管其优点众多:无需燃油,不产污染,没有拥堵;但是其缺点也十分突出:消耗体力,短距出行,时间较长。为了提高工效,加之工业革命的推动,自行车逐渐被机动车所取代。但是如今的现状,如何破解环境污染难题,践行可持续发展理念,共享单车管理系统具有重要的现实意义。
共享单车作为一种可持续型公共交通工具有着明显的优势:无噪音、零排放、灵活易存取、与其他公共交通工具无缝衔接。这一系列的优点令其在解决城市交通拥堵,缓解环境污染,降低能源消耗,解决出行最后一公里等方面的能力得到人们的广泛认可。如何解决科学发展所带来的各种环境问题,是新形势下的一个重要课题。本文系选题的目的正是研究利用共享单车管理系统,绿色解决居民最后一公里问题,还民众清山绿水,健康生态环境。
本系统分为管理员和用户两部分,其中管理员可以管理系统内的全部功能,用户可以查看车辆和进行租赁等操作,具体功能如下:
用户部分功能介绍
1:用户登录,用户通过自己的账号和密码登录到系统中来
2:查看车辆信息,用户可以查看车辆信息,并且可以进行在线对单车进行租赁
3:租赁记录,用户可以在自己的操作菜单中查看对应的操作记录,并对车辆进行归还
4:在线充值,用户如果余额不足的话可以进行在线充值操作
5:在线提现,当用户暂时不在使用单车,而余额内的钱又比较多的时候可以进行提现操作
6:修改密码,用户可以修改自己的个人密码
管理员部分功能介绍
1:会员信息管理,管理员可以管理对应的会员信息,包括对会员信息的增删改查
2:车辆信息管理,管理员可以管理对应的车辆信息,方便其他人进行租赁
3:还车点管理,管理员可以对换车点进行管理,包括对换车点的增删改查
4:租车信息管理,管理员可以管理用户的租车信息
5:财务管理,管理员可以对一定时间段的财务信息进行管理
6:管理员信息管理,为了减轻工作人员的工作量,系统可以设置多个管理员
7:修改密码,管理员可以修改自己的个人密码
<?php
error_reporting(E_ALL ^ E_NOTICE);
$conn=@mysql_connect("localhost","root","root") or die("数据库链接失败".mysql_error());
mysql_select_db("daizu",$conn) or die("数据库链接失败".mysql_error());
mysql_query('set names utf8');
//设置时区
date_default_timezone_set('asia/shanghai');
define('SYS_ROOT', str_replace("\\", '/', dirname(__FILE__)));
define('File_ROOT', SYS_ROOT."/upload/");
define('IMG_ROOT', SYS_ROOT . "/upload/");
@extract($_POST);
@extract($_GET);
function getfirst($sql)
{
$res=mysql_query($sql);
$rows=mysql_fetch_array($res);
return $rows;
}
//
function getcount($sql){
$res=mysql_query($sql);
return mysql_num_rows($res);
}
function get_name($id,$table)
{
$sql="select * from $table where id='$id'";
$rows=getfirst($sql);
return $rows[name];
}
//遍历创建目录
function Remkdir($path) {
if (!file_exists($path)) {
Remkdir(dirname($path));
@mkdir($path, 0777);
}
}
//上传图片
function upload_image($inputname, $image=null, $type='upimages', $width=440) {
$n = time().rand(1000,9999).'.jpg';
$z = $_FILES[$inputname];
if ($z && strpos($z['type'], 'image')===0 && $z['error']==0) {
if (!$image) {
Remkdir( IMG_ROOT . '/' . "{$type}/" );
$image = "{$type}/{$n}";
$path = IMG_ROOT . '/' . $image;
} else {
Remkdir( dirname(IMG_ROOT .'/' .$image) );
$image = "{$type}/{$n}";
$path = IMG_ROOT . '/' .$image;
}
//echo $path ;
move_uploaded_file($z['tmp_name'], $path);
//echo $image;exit;
return $image;
}
return $image;
}
//获取文件后缀名
function get_extend($file_name)
{
$extend = pathinfo($file_name);
$extend = strtolower($extend["extension"]);
return $extend;
}
//文件上传实现
function upload_file($inputname, $file=null)
{
$year = date('Y'); $day = date('md');
$z = $_FILES[$inputname];
$file_ext=get_extend($z['name']);
$n = time().rand(1000,9999).".".$file_ext;
if ($z && $z['error']==0) {
if (!$file) {
Remkdir( File_ROOT . '/' . "{$day}" );
$file = "{$day}/{$n}";
$path = File_ROOT . '/' . $file;
} else {
Remkdir( File_ROOT . '/' . "{$day}" );
$file = "{$day}/{$n}";
$path = File_ROOT . '/' .$file;
}
//echo $path ;
move_uploaded_file($z['tmp_name'], $path);
//echo $file;exit;
return $file;
}
return $file;
}
//分页函数.
function get_pager($url, $param, $count, $page = 1, $size = 10)
{
$size = intval($size);
if($size < 1)$size = 10;
$page = intval($page);
if($page < 1)$page = 1;
$count = intval($count);
$page_count = $count > 0 ? intval(ceil($count / $size)) : 1;
if ($page > $page_count)$page = $page_count;
$page_prev = ($page > 1) ? $page - 1 : 1;
$page_next = ($page < $page_count) ? $page + 1 : $page_count;
$param_url = '?';
foreach ($param as $key => $value)$param_url .= $key . '=' . $value . '&';
$pager['url'] = $url;
$pager['start'] = ($page-1) * $size;
$pager['page'] = $page;
$pager['size'] = $size;
$pager['count'] = $count;
$pager['page_count'] = $page_count;
if($page_count <= '1')
{
$pager['first'] = $pager['prev'] = $pager['next'] = $pager['last'] = '';
}
else
{
if($page == $page_count)
{
$pager['first'] = $url . $param_url . 'page=1';
$pager['prev'] = $url . $param_url . 'page=' . $page_prev;
$pager['next'] = '';
$pager['last'] = '';
}
elseif($page_prev == '1' && $page == '1')
{
$pager['first'] = '';
$pager['prev'] = '';
$pager['next'] = $url . $param_url . 'page=' . $page_next;
$pager['last'] = $url . $param_url . 'page=' . $page_count;
}
else
{
$pager['first'] = $url . $param_url . 'page=1';
$pager['prev'] = $url . $param_url . 'page=' . $page_prev;
$pager['next'] = $url . $param_url . 'page=' . $page_next;
$pager['last'] = $url . $param_url . 'page=' . $page_count;
}
}
return $pager;
}
?>
目录
1 绪论 1
1.1课题背景 1
1.2课题研究现状 1
1.3初步设计方法与实施方案 2
1.4本文研究内容 2
2 系统开发环境 4
2.1 使用工具简介 4
2.2 环境配置 4
2.3 B/S结构简介 4
2.4 MySQL数据库 5
2.5 框架介绍 5
3 系统分析 6
3.1系统可行性分析 6
3.1.1经济可行性 6
3.1.2技术可行性 6
3.1.3运行可行性 6
3.2系统现状分析 6
3.3功能需求分析 7
3.4系统设计规则与运行环境 8
3.5系统流程分析 8
3.5.1操作流程 8
3.5.2添加信息流程 9
3.5.3删除信息流程 10
4 系统设计 11
4.1系统设计主要功能 11
4.2数据库设计 11
4.2.1数据库设计规范 11
4.2.2 E/R图 11
4.2.3数据表 12
5 系统实现 25
5.1系统功能模块 25
5.2后台模块 27
5.2.1管理员功能模块 27
5.2.2用户功能模块 30
6 系统测试 33
6.1功能测试 33
6.2可用性测试 33
6.3性能测试 34
6.4测试结果分析 34
7结 论 35
参考文献 36
致 谢 37