- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章PHP MYSQL简易交互式站点开发由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
目的:使用php和mysql模拟权限管理系统的实现 。
general用户只能查看其他用户信息,不能进行修改,添加,和删除操作,root用户可以完成以上三种操作.
实现思路 。
1.在mysql数据库中建立两张数据表。一张数据表保存用户名和密码,用于登陆验证,另一张保存用户权限等基本信息。 2.提交表单登陆时,先在数据库中查找该用户存不存在,若不存在,报错,存在,则验证密码,密码错误则报错,若密码正确,登陆显示所有存储在数据库中的用户信息和当前登陆用户名。 3.在用户进行添加,删除操作时,先判断权限是否足够,有权限则完成相应操作,修改数据库内容,否则提示没有权限 。
具体实现 。
1.登陆页面 。
1
2
3
4
5
6
7
|
<center>
<form method=
"post"
action=
"<?php echo $_server['script_name'] ?>"
>
用户名: <input type=
"text"
name=
"user_name"
>
密码: <input type=
"text"
name=
"password"
>
<input type=
"submit"
name=
"submit"
value=
"登陆"
>
</form>
</center>
|
效果如下:
2.连接数据库对登陆名和密码进行验证 。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
|
//登陆处理
if
(isset(
$_post
[
'submit'
]))
{
// 用户名输入为空
if
(
$_post
[
'user_name'
] ==
''
)
// 调用javascript函数动态提醒
echo
"<script type='text/javascript'>dis_alert(\"用户名\",1);</script>"
;
// 密码输入为空
if
(
$_post
[
'password'
] ==
''
)
// 调用javascript函数动态提醒
echo
"<script type='text/javascript'>dis_alert(\"密码\",1);</script>"
;
// 用户名与密码均不为空
$user_name
=
$_post
[
'user_name'
];
//链接数据库,从中读出用户名和密码
$db
= mysql_connect(
"localhost"
,
"root"
,
"123456"
);
mysql_select_db(
"linyimin"
,
$db
);
$result
= mysql_query(
"select * from login where user_name = '$user_name'"
);
$num
= mysql_num_rows(
$result
);
//判断用户输入的用户名存在,验证密码
if
(
$num
!= 0)
{
$user_name
= mysql_result(
$result
,0,
'user_name'
);
$password
= mysql_result(
$result
,0,
'password'
);
if
(
strcmp
(
$password
,
$_post
[
'password'
]) != 0)
{
echo
"密码错误"
;
//密码错误,报错
$password
=
$_post
[
'password'
];
echo
"<script type='text/javascript'>dis_alert('密码错误',3);</script>"
;
}
// 密码正确
else
{
session_unset();
session_start();
$_session
[
'user_name'
] =
$_post
[user_name];
header(
"location:http://localhost/display.php"
);
exit
;
}
}
// 用户输入的用户名不存在,报错
else
if
(
$num
== 0)
{
// 用户名不存在,报错
$user_name
=
$_post
[
'user_name'
];
echo
"<script type='text/javascript'>dis_alert(\"$user_name\",2);</script>"
;
}
mysql_close(
$db
);
}
//登陆处理结束
|
输入错误提醒函数 。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
|
<script type=
"text/javascript"
>
// 登陆错误提醒
function
dis_alert(var1, var2)
{
// 用户名和密码不能为空提醒
if
(var2 == 1)
{
alert(var1 +
" 不能为空,请重新输入"
);
history.back(-1);
}
// 用户名不存在错误提醒
if
(var2 == 2)
{
alert(
"该用户名 "
+ var1 +
" 不存在,请重新输入"
);
history.back(-1);
}
// 密码错误提醒
if
(var2 == 3)
{
alert(
"密码错误,请重新输入"
);
history.back(-1);
}
}
</script>
|
错误提醒效果图:
3.成功登陆之后显示数据库中所有用户信息和当前登陆用户名 。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
|
// 获取登陆名
session_start();
$name
=
$_session
[
'user_name'
];
// 连接数据库,获取数据并显示
function
display()
{
global
$name
;
$db
= mysql_connect(
"localhost"
,
"root"
,
"123456"
);
mysql_select_db(
"linyimin"
,
$db
);
$sql
=
"select * from admin_info"
;
$result
= mysql_query(
$sql
);
// 显示信息表
echo
"<h3 align=right color=#ffffff> 当前用户:$name</h6>"
;
echo
"<table border = 0 align = center width = 1000></br>"
;
// 添加超链接
echo
"<tr align = center><th> <a href =\"display.php?add=yes\">add</a></th><br>"
;
// 修改添加超连接
echo
"<th> <a href =\"display.php?update=yes\">update</a></th><br>"
;
// 删除超链接
echo
"<th> <a href =\"display.php?delete=yes\">delete</a></th></tr><br>"
;
echo
"</table>"
;
echo
"<table border = 2 align = center width = 1000></br>"
;
// 表头
echo
"<tr><th colspan=\"3\">管理员权限表</th></tr><br>"
;
echo
"<tr align = center><td>姓名</td><td>权限</td><td>职务</td></tr><br>"
;
while
(
$row
= mysql_fetch_row(
$result
))
{
// 显示管理员信息并通过超链接调用处理函数
echo
"<tr align = center><td>$row[0]</td>"
;
echo
"<td>$row[1]</td>"
;
echo
"<td>$row[2]</td></tr>"
;
}
echo
"</table>"
;
mysql_close(
$db
);
}
|
显示效果如下:
4.修改,删除,添加操作的实现 。
修改,添加页面 。
1
2
3
4
5
6
7
8
|
<center>
<form method=
"post"
action=
"<?php echo $_server['url'] ?>"
>
姓名: <input type=
"text"
name=
"user_name"
>
权限: <input type=
"text"
name=
"pemission"
>
职务: <input type=
"text"
name=
"position"
>
<input type=
"submit"
name=
"update"
value=
"提交"
>
</form>
</center>
|
效果如下:
删除页面 。
1
2
3
4
5
|
<center>
<form method=
"post"
action=
"<?php echo $_server['url'] ?>"
onsubmit=
"return confirm('请确认删除');"
>
姓名: <input type=
"text"
name=
"user_name"
>
<input type=
"submit"
name=
"update"
value=
"删除"
>
</center>
|
效果图如下:
实现 。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
// 调用修改函数
if
(
$_get
[update])
{
modify(
"update"
);
}
// 调用添加函数
elseif
(
$_get
[add])
{
modify(
"add"
);
}
elseif
(
$_get
[
delete
])
{
modify(
"delete"
);
}
|
modify()函数的实现 。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
|
// 修改数据函数
/*
点击修改超链接,跳转到修改页面
表单中,名字项指定要修改记录
权限和职务项为可修改内容
*/
function
modify(
$operation
)
{
if
(isset(
$_post
[
'update'
]))
{
// 有root权限修改,修改
if
(
$operation
==
"update"
&& judge(
"update"
))
{
$user_name
=
$_post
[user_name];
$sql
=
"update admin_info set pemission = '$_post[pemission]', position ='$_post[position]' where user_name = '$user_name'"
;
mysql_query(
$sql
);
mysql_close(
$db
);
display();
}
// 添加
elseif
(judge(
"add"
) &&
$operation
==
"add"
)
{
$user_name
=
$_post
[user_name];
$sql
=
"insert into admin_info (user_name, pemission, position) values ('$_post[user_name]','$_post[pemission]','$_post[position]')"
;
mysql_query(
$sql
);
mysql_close(
$db
);
display();
}
// 删除
elseif
(judge(
"delete"
) &&
$operation
==
"delete"
)
{
$user_name
=
$_post
[user_name];
// 获取确认情况
$sql
=
"delete from admin_info where user_name = \"$user_name\""
;
mysql_query(
$sql
);
}
}
}
|
judge()函数的实现 。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
|
// 判断修改用户名是否存在和该用户是否具有权限
function
judge(
$operation
)
{
global
$name
;
// 修改用户名
$user_name
=
$_post
[
'user_name'
];
// 连接数据库,获取数据
$db
= mysql_connect(
"localhost"
,
"root"
,
"123456"
);
mysql_select_db(
"linyimin"
,
$db
);
// 该用户是否存在
$sql
=
"select * from admin_info where user_name = \"$user_name\""
;
$result
= mysql_query(
$sql
);
$num
= mysql_num_rows(
$result
);
// 输入名称不存在
if
(
$num
== 0 &&
$operation
!=
"add"
)
{
$user_name
=
$_post
[
'user_name'
];
echo
"<script type='text/javascript'>dis_alert(\"$user_name\",2);</script>"
;
return
0;
}
else
{
// 判断有没有权限(只有root权限可以修改)
$sql
=
"select * from admin_info where user_name = \"$name\""
;
$result
= mysql_query(
$sql
);
$pemission
= mysql_result(
$result
,0,
'pemission'
);
// 没有root权限,报错
if
(
strcmp
(
$pemission
,
"root"
) != 0)
{
$user_name
=
$_post
[
'user_name'
];
echo
"<script type='text/javascript'>dis_alert(\"$user_name\",1);</script>"
;
return
0;
}
else
return
1;
}
}
|
常用技巧记录 。
1.利用session实现多个php文件使用同一个变量的方法 。
在定义该变量的文本中打开session,并把值存入session 。
1
2
3
|
usersession_unset();
session_start();
$_session
[
'变量名'
] =
"值"
;
|
在使用该变量的文本中打开session并取出该变量 。
1
2
|
session_start();
$name
=
$_session
[
'变量名'
];
|
2.php连接mysql数据库,并对数据库进行查找,添加,删除操作 。
连接数据库 。
1
2
3
4
|
// 连接数据库
$db
= mysql_connect(
"url"
,
"用户名"
,
"密码"
);
// 选择数据库
mysql_select_db(
"数据库名称"
,
$db
);
|
查找 。
1
2
3
4
5
6
7
8
9
10
11
12
|
$sql
=
"select * from admin_info where 字段名 = \"查找值\""
;
$result
= mysql_query(
$sql
);
// 对查找返回结果进行操作
// 获取查找返回记录数条数
$num
= mysql_num_rows(
$result
);
// 获取查找结果第一条记录的user_name字段值
$user_name
= mysql_result(
$result
,0,
'user_name'
);
// 逐条取出查询记录
while
(
$row
= mysql_fetch_row(
$result
))
{
相关操作;
}
|
插入 。
1
2
|
$sql
=
"insert into 数据表 (字段1, 字段2, 字段3) values ('值1','值2','值3')"
;
mysql_query(
$sql
);
|
删除 。
1
2
3
4
|
$sql
=
"delete from 数据表 where 字段名 = \"查找值\""
;
mysql_query(
$sql
);
// 关闭数据库
mysql_close(
$db
);
|
3.表格提交前提醒 。
<form method="post" action="url" onsubmit="return confirm('请确认删除');"> 。
4.在php中调用javascript函数 。
1
2
3
|
<?php
echo
"<script type='text/javascript'>javascript函数;</script>"
;
?>
|
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我.
最后此篇关于PHP MYSQL简易交互式站点开发的文章就讲到这里了,如果你想了解更多关于PHP MYSQL简易交互式站点开发的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
最近我用 php 建立了一个网站,但他们的旧网站都是 HTML 格式的。所以现在我不知道使用 .htaccess 将所有这些旧链接重定向到新站点(可能将所有带有 HTML 的链接重定向到主域)的最佳方
我创建了一个新的 WordPress 网站,它是我旧网站的更名版本。它有一个新的域和一个新的设计。除此之外,其他一切都是相同的,包括内容和链接结构。现在我想完全重定向旧链接。与旧帖子一样,标签和类别
我想使用 WatiN测试我正在开发的网站的功能。理想情况下,我会在测试开始运行之前以编程方式部署网站 (asp.net MVC3),然后在每次测试之前刷新数据。这可能吗? 最佳答案 在此处阅读有关使用
我们的网站使用我们自己定制的 session 状态管理,与 ASP.NET session 状态分开。但是由于少数特殊页面使用 SQL Server Reporting Services,我们还需要启
不久前我看到一个网站,其中有 JavaScript/HTML/CSS 栏目,下面有实际代码的样子。有点像 jsFiddle,但它有用户示例和演示。有谁知道这个网站的名字吗?我到处都找不到它!谢谢! 最
我们的核心数据库出现问题,该数据库已由前一天的备份数据库恢复。 此后,网站工作正常,但我们在发布任何更改时遇到问题。一旦点击发布按钮,“发布正在初始化..”消息就会持续很长时间。截至“发布开始/结束”
我们的核心数据库出现问题,该数据库已由前一天的备份数据库恢复。 此后,网站工作正常,但我们在发布任何更改时遇到问题。一旦点击发布按钮,“发布正在初始化..”消息就会持续很长时间。截至“发布开始/结束”
Maven 不仅仅是一款项目构建和依赖管理工具,它还能够聚合项目信息,促进项目团队间地交流。POM 中可以包含各种项目信息,例如:项目描述、SCM 地址、许可证信息,开发者信息等。用户可以使用 Mav
关闭。这个问题需要更多focused .它目前不接受答案。 想改进这个问题吗? 更新问题,使其只关注一个问题 editing this post . 关闭上个月。 Improve this ques
您知道哪些网站正在使用 Silverlight?此信息将帮助我们决定何时采用 Silverlight 平台。 这些网站应该是面向公众的并且被认为是高流量的。 (每月至少 300,000 次点击)。 我
我尝试通过 VS2017 中的发布上下文菜单将我的 .net 核心站点部署到 Azure,偶尔(大约三分之一的部署),我收到以下错误。 Web deployment task failed. (Web
我为 20 个不同的国家/地区创建了一个包含 20 个站点(每个站点一个不同的域)的 Django 项目。这些站点共享所有内容:代码库、数据库、网址、模板等。 他们唯一不共享的是我在每个站点设置文件中
如何将商店页面添加到我使用 jekyll 和基础构建的网站? 任何自动化平台/方法都可以做到这一点。 谢谢。 最佳答案 您可以使用 snipcart .有一个blog post和一个 demo sit
我部署了一个服务结构集群,域为 foo.northcentralus.cloudapp.azure.com 它具有单一节点类型和单一公共(public) IP 地址/负载均衡器。 假设我部署了以下
我不是一个大的typ3 专家,也无法访问我正在使用的typ3 实例中的typoscript 选项(这是一个非常大的站点,我没有这样做的授权)。所以我希望这个问题适合 stackoverflow(如果没
我们正在对我们的 Drupal 站点进行性能调整。 我们正在使用 Siege 来衡量性能(作为 drupal 访问者)。 环境: Nginx + FastCGI + Memcache Siege 运行
我搜索了 SO、SU 和 SP.SE寻求解决方案,但找不到我需要的东西。我正在寻找一个解决方案,它可能是一个脚本或一些其他非编码方法/工具。 我正在尝试编写一个脚本(供其他人使用)或某种其他形式的自动
我有一个 Django 站点,它使用本地化中间件与 gettext 和 trans/blocktrans 模板标签相结合,根据用户代理字符串中的首选语言向访问者显示不同的页面(这似乎是在 Django
我是 Drupal 新手。是否可以设置所有内容并在服务器上部署 Drupal?我的意思是像放入内容、设置模块等...,然后将它们全部放到生产服务器上? 最佳答案 当然。 复制所有文件 编辑数据库凭证(
我想将以下行添加到我的 head.html仅在运行时 jekyll serve本地: 如果可能的话,我正在考虑使用一些简单的液体检查。 最佳答案 当你做 jekyll serve本地默认 {{
我是一名优秀的程序员,十分优秀!