首页 > php上传下载 > php登录操作的文件上传管理系统

php登录操作的文件上传管理系统

<?php
$admin_pw = "admin"; //管理密码
$uploaddir = "upload"; //上传目录
session_start();
if ($_GET['action'] == "getcode") {
    setcode();
    exit();
}
if ($_POST['password'] == $admin_pw && $_POST['yz'] == $_SESSION['yzcode']) {
    $_SESSION['logined'] = $admin_pw;
}
if ($_GET['action'] == "logout") {
    $_SESSION['logined'] = "";
    header("location: " . $_SERVER['PHP_SELF']);
    exit();
}
if ($_SESSION['logined'] != $admin_pw) {
?> 
<!DOCTYPE html> 
<html xmlns="http://www.w3.org/1999/xhtml"> 
<head> 
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> 
<title>请登录</title> 
</head> 
<body> 
<form action="" method="post"> 
输入密码:<input type="password" name="password" style="width:100px;" /><br />验证字符:<input type="text" style="width:40px;" name="yz" /><a href="#" onclick="document.tzm.src='?action=getcode';"><img src="?action=getcode" alt="验证码" id="tzm" name="tzm" /></a><br /><input type="submit" value="进入管理" /> 
</form> 
</body> 
</html> 
<?php
} else {
?> 
<!DOCTYPE html> 
<html xmlns="http://www.w3.org/1999/xhtml"> 
<head> 
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> 
<title>文件上传</title> 
</head> 
<body> 
<?php
    if ($_POST['ac'] == "upload") {
        $fileall = explode('.', $_FILES['file']['name']);
        $filetype = $fileall[count($fileall) - 1];
        $filename = $uploaddir . "/" . $_FILES['file']['name'] . "_" . rand(1, 999999999) . "." . $filetype;
        $fileexists = file_exists($filename);
        while ($fileexists == true) {
            $filename = $uploaddir . "/" . $_FILES['file']['name'] . "_" . rand(1, 999999999) . "." . $filetype;
            $fileexists = file_exists($filename);
        }
        if (move_uploaded_file($_FILES["file"]["tmp_name"], $filename)) {
            $url = "http://" . $_SERVER['SERVER_NAME'] . $_SERVER['REQUEST_URI'];
            echo "文件:" . $filename . " 上传成功!<br>文件地址:<input type=text style='width:350px;' value=" . dirname($url) . "/" . $filename . " /><a href=" . dirname($url) . "/" . $filename . " target="_blank">测试</a>";
        } else {
            echo "文件" . $filename . "上传失败!";
        }
    }
?> 
<form action="" method="post" enctype="multipart/form-data"> 
选择文件:<input type="file" name="file" id="file" width="100px" /><input type="hidden" name="ac" value="upload" /><input type="submit" value="上传" /> 
</form> 
<p><a href="?action=logout">退出登录</a></p> 
</body> 
</html> 
<?php
}
function setcode() {
    Header("Content-type: image/gif");
    $border = 0; //是否要边框 1要:0不要
    $how = 4; //验证码位数
    $w = $how * 15; //图片宽度
    $h = 20; //图片高度
    $fontsize = 5; //字体大小
    $alpha = "abcdefghijkmnopqrstuvwxyz"; //验证码内容1:字母
    $number = "0123456789"; //验证码内容2:数字
    $randcode = ""; //验证码字符串初始化
    srand((double)microtime() * 1000000); //初始化随机数种子
    $im = ImageCreate($w, $h); //创建验证图片
    $bgcolor = ImageColorAllocate($im, 255, 255, 255); //设置背景颜色
    ImageFill($im, 0, 0, $bgcolor); //填充背景色
    if ($border) {
        $black = ImageColorAllocate($im, 0, 0, 0); //设置边框颜色
        ImageRectangle($im, 0, 0, $w - 1, $h - 1, $black); //绘制边框
        
    }
    for ($i = 0; $i < $how; $i++) {
        $alpha_or_number = mt_rand(0, 1); //字母还是数字
        $str = $alpha_or_number ? $alpha : $number;
        $which = mt_rand(0, strlen($str) - 1); //取哪个字符
        $code = substr($str, $which, 1); //取字符
        $j = !$i ? 4 : $j + 15; //绘字符位置
        $color3 = ImageColorAllocate($im, mt_rand(0, 100) , mt_rand(0, 100) , mt_rand(0, 100)); //字符随即颜色
        ImageChar($im, $fontsize, $j, 3, $code, $color3); //绘字符
        $randcode.= $code; //逐位加入验证码字符串
        
    }
    $_SESSION['yzcode'] = $randcode;
    Imagegif($im);
    ImageDestroy($im);
}
?>


本文地址:http://www.phprm.com/scxz/fs4882.html

转载随意,但请附上文章地址:-)

标签:php文件上传 php登录操作

相关文章

发表留言