用PHP实现Ftp用户的在线管理


Posted in PHP onFebruary 16, 2012

实现在线报名和上传作品的思路是利用网页表单收集用户填写的资料存储到Mysql数据库内,同时以该用户的注册名创建一个FTP上传账号并创建该用户的相应目录。

Ftp服务器是系统默认带的,采用系统用户的用户名和密码,创建系统用户就等于创建FTP用户,FreeBSD是属于UNIX阵营的操作系统,它没有象Linux一样的useradd和groupadd等创建用户和组的命令,其取而代之的是pw命令加上相应参数来实现,在Freebsd上以管理员的身份创建一个用户的命令是

echo | pw useradd [-g][groupname] [-s][shelldir][-h 0]

参数g指定用户组,参数s指定用户的shell。

如果是普通用户登陆的话还必须用到su命令,调用的方法是

su root ?c ‘echo | pw useradd [-g][groupname] [-s][shelldir][-h 0] '

执行之后系统会要求输入管理员密码,输入密码就可以以管理员的身份执行这个命令了。

实现这步操作的主要难点在于如何通过PHP来调用上面这些系统命令去创建一个用户,本例是使用PHP中的popen()函数来实现的,该函数执行指令打开文件,语法是int popen(string command, string mode),其打开的文件只能是单向的,只能读或只能写,对应的“string mode”为'r'或'w',“string command” 就是命令字符串,在对文件的操作上可使用 fgets()、fgetss()与fputs()函数,本例用fputs()函数往文件里面输入管理员密码。若是开档发生错误将返回 false 值,最后函数要记得调用pclose()关闭。

下面我们来规划一下FTP用户的组,事先我们先用pw groupadd ftpuser创建ftpuse组,让在线申请的用户为这个组的成员。为了安全起见,我们不应该给FTP用户Telnet权限,所以我们还要专门给他们创建一个shell,使得他们不能通过Telnet正常登陆系统,方法如下:先创建一个文件/bin/ftponly

#!/bin/csh 
/bin/cat << XX 

You can ony use this username to login ftp server! 

And you can not use it to telnet to this system! XX 

sleep 10

该文件中XX之间就是显示给用telnet登陆的用户看的信息。信息显示10秒钟就自动退出了。最后不要忘记用chmod +x /bin/ftponly给这个文件可执行属性。

然后在/bin/shell文件中添加“/bin/ftponly”,在以后的命令里面我们就可以利用pw中-s参数把这个shell指定给FTP用户了。

最后还要注意一个问题,su命令仅仅是wheel管理组的用户成员才可以使用,当PHP调用su命令的时候也必须以wheel组成员的身份运行,否则系统拒绝运行,而PHP运行系统命令的身份就是Apache Web服务器运行的身份,初始的用户名和用户组都是nobody,所以先得建立一个wheel组的用户www供apache使用,接着更改Apache的配置文件httpd.conf中的user为www,group为wheel,重新启动Apache,就可以以新用户身份运行了。
下面可以创建PHP源文件checkin.php了,代码如下:

<?if (($username!="") and ($userpasswd!=""))//判断是否有表单提交了信息 
{ $rootpasswd="adminpassword"; //定义管理员密码 
$creatuser ="su --login root -c 'echo ".$userpasswd." | pw useradd ".$username." -s /bin/ftponly -g ftpuser ?s /bin/ftponly -h 0' "; //这是利用su和pw命令创建用户的用到的字符串 
$fp=popen($creatuser,"w"); //调用popen()函数执行字符串中的命令,返回文句柄给$fp 
fputs($fp,$rootpasswd); //写入管理员密码到文件$fp,相当于输入密码给系统 
pclose($fp);//关闭文件 
$creatdir="su --login root -c 'mkdir /home/".$username."'";//创建用户目录的命令字符串 
$fp=popen($creatdir,"w");//执行命令创建用户目录 
fputs($fp,$rootpasswd); //输入管理员密码 
pclose($fp); 
$creatdir="su --login root -c 'mkdir /home/".$username."/public_html'"; 
$fp=popen($creatdir,"w"); //执行命令创建用户网站根目录 
fputs($fp,$rootpasswd); //输入管理员密码 
pclose($fp); 
$creatdir="su --login root -c 'chown ".$username." /home/".$username."'"; //改变用户目录的所有者为用户自己,初始为运行Apache的用户www。 
$fp=popen($creatdir,"w"); //执行命令 
fputs($fp,$rootpasswd); //输入管理员密码 
pclose($fp); 
$creatdir="su --login root -c 'chown ".$username." /home/".$username."/public_html'"; //改变网站根目录的归属 
$fp=popen($creatdir,"w"); 
fputs($fp,$rootpasswd); 
pclose($fp); 
echo "恭喜".$username.",您的的FTP账号已经申请成功!请到FTP上登陆,请注意,您没有Telnet权限";} 
else{?> 
<html> 
<head> 
<title>申请FTP账号</title> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312"> 
</head> 
<body bgcolor="#FFFFFF"> 
<div align="center"> 
<p>申请FTP账号</p> 
<form method=POST action="<? echo $PHP_SELF; ?>"> 
<table width="36%" border="0"> 
<tr> 
<td width="40%"> 
<div align="right">账号名称:</div> 
</td> 
<td width="60%"> 
<input type="text" name="username"> 
</td> 
</tr> 
<tr> 
<td width="40%"> 
<div align="right">密码:</div> 
</td> 
<td width="60%"> 
<input type="password" name="userpasswd"> 
</td> 
</tr> 
<tr> 
<td colspan="2"><input type="submit" name="Submit" value="申请"></td> 
</tr> 
</table> 
</form> 
</div><?}?> 
</body> 
</html>
PHP 相关文章推荐
php中json_encode中文编码问题分析
Sep 13 PHP
关于PHP的相似度计算函数:levenshtein的使用介绍
Apr 15 PHP
php实现的SESSION类
Dec 02 PHP
C# WinForm中实现快捷键自定义设置实例
Jan 23 PHP
php判断输入是否是纯数字,英文,汉字的方法
Mar 05 PHP
PHP多线程之内部多线程实例分析
Mar 09 PHP
CodeIgniter开发实现支付宝接口调用的方法示例
Nov 14 PHP
ThinkPHP3.2框架操作Redis的方法分析
May 05 PHP
Yii框架通过请求组件处理get,post请求的方法分析
Sep 03 PHP
laravel model 两表联查示例
Oct 24 PHP
TP框架实现上传一张图片和批量上传图片的方法分析
Apr 23 PHP
php优化查询foreach代码实例讲解
Mar 24 PHP
PHP排序算法的复习和总结
Feb 15 #PHP
php网上商城购物车设计代码分享
Feb 15 #PHP
php后台多用户权限组思路与实现程序代码分享
Feb 13 #PHP
php _autoload自动加载类与机制分析
Feb 10 #PHP
php 文本文件的读取效率
Feb 10 #PHP
php+iframe实现隐藏无刷新上传文件
Feb 10 #PHP
PHP中集成PayPal标准支付的实现方法分享
Feb 06 #PHP
You might like
多重?l件?合查?(一)
2006/10/09 PHP
php打开文件fopen函数的使用说明
2013/07/05 PHP
php在apache环境下实现gzip配置方法
2015/04/02 PHP
PHP插件PHPMailer发送邮件功能
2017/02/28 PHP
PHP排序算法之归并排序(Merging Sort)实例详解
2018/04/21 PHP
swoole锁的机制代码实例讲解
2021/03/04 PHP
javascript 面向对象编程 聊聊对象的事
2009/09/17 Javascript
JQuery Ajax 跨域访问的解决方案
2010/03/12 Javascript
js中的值类型和引用类型小结 文字说明与实例
2010/12/12 Javascript
一些javascript一些题目的解析
2010/12/25 Javascript
javascript 拖动表格行实现代码
2011/05/05 Javascript
JS实现根据出生年月计算年龄
2014/01/10 Javascript
对于Form表单reset方法的新认识
2014/03/05 Javascript
Jquery幻灯片特效代码分享--打开页面随机选择切换方式(3)
2015/08/15 Javascript
详解JavaScript设计模式开发中的桥接模式使用
2016/05/18 Javascript
很棒的一组js图片轮播特效
2017/01/12 Javascript
layui之select的option叠加问题的解决方法
2018/03/08 Javascript
详解JavaScript作用域和作用域链
2019/03/19 Javascript
JavaScript 反射和属性赋值实例解析
2019/10/28 Javascript
jQuery实现滑动开关效果
2020/08/02 jQuery
React冒泡和阻止冒泡的应用详解
2020/08/18 Javascript
js实现纯前端压缩图片
2020/11/16 Javascript
[59:35]DOTA2上海特级锦标赛主赛事日 - 3 败者组第三轮#1COL VS Alliance第二局
2016/03/04 DOTA
python继承和抽象类的实现方法
2015/01/14 Python
使用Python从有道词典网页获取单词翻译
2016/07/03 Python
基于python的socket实现单机五子棋到双人对战
2020/03/24 Python
python flask几分钟实现web服务的例子
2019/07/26 Python
tensorflow-gpu安装的常见问题及解决方案
2020/01/20 Python
Django限制API访问频率常用方法解析
2020/10/12 Python
利用Python pandas对Excel进行合并的方法示例
2020/11/04 Python
快速一键生成Python爬虫请求头
2021/03/04 Python
LivingSocial英国:英国本地优惠
2019/02/22 全球购物
C语言面试题
2015/10/30 面试题
高三生物教学反思
2014/01/25 职场文书
销售开票员岗位职责
2015/04/15 职场文书
tree shaking对打包体积优化及作用
2022/07/07 Java/Android