热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

phpdiscuzchhome图片上传swfupload功能-PHP源码

ec(2);phpdiscuzchhome图片上传swfupload功能这上传与discuz来比,还相差太远.功能也欠缺. 除了部分内置的url引向,我们改不了之外,其它的数据都是可以修改的.<?php* [UCenterHome](C)2007-2008ComsenzInc. $Id:do_swfupload.

php discuz chhome 图片上传swfupload功能
这上传与discuz来比, 还相差太远. 功能也欠缺.
除了部分内置的url引向,我们改不了之外, 其它的数据都是可以修改的.
/*
[UCenter Home] (C) 2007-2008 Comsenz Inc.
$Id: do_swfupload.php 12830 2009-07-22 06:42:32Z zhengqingpeng $
*/

if(!defined('IN_UCHOME')) { //入门牌.
exit('Access Denied');
}

include_once(S_ROOT.'./source/function_cp.php');

$op = empty($_GET['op'])?'':$_GET['op']; // uchome比较喜欢用的方法变量.
$isupload = empty($_GET['cam']) && empty($_GET['doodle']) ? true : false; //是否上传.还有种可能是头像上传.
$iscamera = isset($_GET['cam']) ? true : false; //判断一下是头像上传.
$isdoodle = isset($_GET['doodle']) ? true : false; //判断一下是大头贴背景是否随机.
$fileurl = ''; // 默认赋值.
if(!empty($_POST['uid'])) { //如果有uid传过来, 表示在上传头像, 就取得uid值.
$_SGLOBAL['supe_uid'] = intval($_POST['uid']); //强制转化.
if(empty($_SGLOBAL['supe_uid']) || $_POST['hash'] != md5($_SGLOBAL['supe_uid'].UC_KEY)) { // 既然传递了uid值是过来, 假如用户没有登录,及hash码不对应,就中断.
exit();
}
} elseif (empty($_SGLOBAL['supe_uid'])) { //否则再判断, 如果没有登录, 禁止使用上传功能.
showmessage('to_login', 'do.php?ac='.$_SCONFIG['login_action']);
}

if($op == "finish") { //上传结束时.
/* 它会传入如下GET
array (
'ac' => 'swfupload',
'op' => 'finish',
'albumid' => '2',
)*/
$albumid = intval($_GET['albumid']); //取得分类id.
$space = getspace($_SGLOBAL['supe_uid']); //更新用户部分记录, 比较图片总数, 容量计算.
if(ckprivacy('upload', 1)) { //判断一下是否已经写了推送.
include_once(S_ROOT.'./source/function_feed.php');
feed_publish($albumid, 'albumid'); //否则就再写一次.
}
//强行中断.
exit();
} elseif($op == 'config') { //swf上传的配置.
/* 根据抓取所得 GET传过来:
array (
'ac' => 'swfupload',
'op' => 'config',
)
*/
$hash = md5($_SGLOBAL['supe_uid'].UC_KEY); //生成一个hash码.

if($isupload && !checkperm('allowupload')) { //是上传图片,并且权限足够.对于配置来说, $isupload永远为假.
$hash = '';
} else {
$filearr = $dirstr = array(); //初始化数组. 文件数组/及目录数据.

if($iscamera) { //进入头像上传工作.
/*
根据抓取, GET数据如下:
array (
'ac' => 'swfupload',
'op' => 'config',
'cam' => '1',
)
*/
$directory = sreaddir(S_ROOT.'./image/foreground'); //大头贴背景的目录. sreaddir读取里面的目录数据.
foreach($directory as $key => $value) { //每一个背景都是独立的一个目录, 所以循环一下.
$dirstr = S_ROOT.'./image/foreground/'.$value; //合成新的路径.
if(is_dir($dirstr)) { //判断一下是否是目录.
$filearr = sreaddir($dirstr, array('jpg','jpeg','gif','png')); //读取目录里面的图片文件.
if(!empty($filearr)) { // 如果图片数组不为空.
if(is_file($dirstr.'/categories.txt')) { // 如果categories.txt文件存在.
$catfile = @file($dirstr.'/categories.txt'); //打开此文件.
$dirarr[$key][0] = trim($catfile[0]); //就将里面的文件读取来. 当然, 很无谓的方法, 里面的内容与目录名是一样的.
} else { //如果txt文件不存在, 就取得目录名.
$dirarr[$key][0] = trim($value); //准确取得值, trim多用.
}
$dirarr[$key][1] = trim('image/foreground/'.$value.'/'); //将指针1设置为当前大头贴背景目录.
$dirarr[$key][2] = $filearr; // //将指针2设置为当前大头贴背景目录里面的图片.
}
}
}
} elseif($isdoodle) { //如果是头像随机背景, 就读取./image/doodle/big里面的图片文件.
$filearr = sreaddir(S_ROOT.'./image/doodle/big', array('jpg','jpeg','gif','png'));
}
}
//接着就到了图片上传配置工作.
$max = @ini_get(upload_max_filesize); //取得php.ini最大上传值.
$unit = strtolower(substr($max, -1, 1)); //$max结尾有kb字样吧, 要截取一下,并且转成小写.

//下面是针对不同的计算单元作换算.
if($unit == 'k') {
$max = intval($max)*1024; //看样子是全部转成byt字节单位. KB X 1024 = 多少字节.
} elseif($unit == 'm') {
$max = intval($max)*1024*1024; // MB X 1024 X 1024 = 多少字节.
} elseif($unit == 'g') {
$max = intval($max)*1024*1024*1024; // GB X 1024 X 1024 X 1024 = 多少字节.
}
//取得用户所建立的分类数组.
$albums = getalbums($_SGLOBAL['supe_uid']);

} elseif($op == "screen" || $op == "doodle") { // screen 不理解什么时候出来 || 随机大头贴背景,由于没有摄像头, 这里面略过.

if(empty($GLOBALS['HTTP_RAW_POST_DATA'])) {
$GLOBALS['HTTP_RAW_POST_DATA'] = file_get_contents("php://input");
}
$status = "failure";
$dosave = true;

if($op == "doodle") {
$query = $_SGLOBAL['db']->query('SELECT * FROM '.tname('usermagic')." WHERE uid = '$_SGLOBAL[supe_uid]' AND mid = 'doodle'");
$value = $_SGLOBAL['db']->fetch_array($query);
if(empty($value) || $value['count'] <1) {//û&#65533;&#65533;&#895;&#1147;&#65533;&#65533;
$uploadfiles = -8;
$dosave = false;
}
}

if($dosave && !empty($GLOBALS['HTTP_RAW_POST_DATA'])) {
$_SERVER['HTTP_ALBUMID'] = addslashes(siconv(urldecode($_SERVER['HTTP_ALBUMID']), $_SC['charset'], "UTF-8"));
$from = false;
if($op == 'screen') {
$from = 'camera';
} elseif($_GET['from'] == 'album') {
$from = 'uploadimage';
}
$_SCONFIG['allowwatermark'] = 0;
$uploadfiles = stream_save($GLOBALS['HTTP_RAW_POST_DATA'], $_SERVER['HTTP_ALBUMID'], 'jpg', '', '', 0, $from);
}

$uploadRespOnse= true;
$picid = $proid = $albumid = 0;
if($uploadfiles && is_array($uploadfiles)) {
$status = "success";
$albumid = $uploadfiles['albumid'];
$picid = $uploadfiles['picid'];
if($op == "doodle") {
$fileurl = pic_get($uploadfiles['filepath'], $uploadfiles['thumb'], $uploadfiles['remote'], 0);
include_once(S_ROOT.'./source/function_magic.php');
magic_use('doodle', array(), 1);
}
} else {
switch ($uploadfiles) {
case -1:
$uploadfiles = cplang('inadequate_capacity_space');
break;
case -2:
$uploadfiles = cplang('only_allows_upload_file_types');
break;
case -4:
$uploadfiles = cplang('ftp_upload_file_size');
break;
case -8:
$uploadfiles = cplang('has_not_more_doodle');
break;
default:
$uploadfiles = cplang('mobile_picture_temporary_failure');
break;
}
}

} elseif($_FILES && $_POST) { // 图片上传时,
/* 根据抓取, POST GET数据值为:
POST = array (
'Filename' => 'MJP45+R3001.jpg',
'proid' => '1',
'albumid' => '2',
'uid' => '1',
'title' => 'MJP45+R3001',
'hash' => '11ed07fe235ca5b9e509043e85419785',
'Upload' => 'Submit Query',
)

GET = array (
'ac' => 'swfupload',
)

*/
if($_FILES["Filedata"]['error']) { //如果有上传错误
$uploadfiles = cplang('file_is_too_big'); // 就提示文件过大.
} else {
//考虑到编码及大小写问题, 还有转义. 取得上传文件名.
$_FILES["Filedata"]['name'] = addslashes(siconv(urldecode($_FILES["Filedata"]['name']), $_SC['charset'], "UTF-8"));
//考虑到编码及大小写问题, 还有转义. 取得上传分类id.
$_POST['albumid'] = addslashes(siconv(urldecode($_POST['albumid']), $_SC['charset'], "UTF-8"));
//考虑到编码及大小写问题, 还有转义. 取得上传文件后的一个详解路径.
$uploadfiles = pic_save($_FILES["Filedata"], $_POST['albumid'], addslashes(siconv(urldecode($_POST['title']), $_SC['charset'], "UTF-8")));
}

//根据我的分析, 以下内容在图片上传时没用, 不知头像上传会否用到.
$proid = $_POST['proid'];
$uploadRespOnse= true;
$albumid = 0;
//判断一下上传文件, 及上传文件数组.
if($uploadfiles && is_array($uploadfiles)) {
$status = "success"; //上传完成
$albumid = $uploadfiles['albumid']; // 上传的分类id
} else {
$status = "failure"; //这就是上传失败了.
}

//这是我自己加上去的, 估计uchome也会感激我.
exit();
}
// 时间
$newalbumname = sgmdate('Ymd');

//引入模板
include template("do_swfupload");

//输出xml, swf配置需要.
$outxml = "n";
$outxml .= siconv(ob_get_contents(), 'UTF-8');
obclean();
@header("Expires: -1");
@header("Cache-Control: no-store, private, post-check=0, pre-check=0, max-age=0", FALSE);
@header("Pragma: no-cache");
@header("Content-type: application/xml; charset=utf-8");
echo $outxml;

// 配置文件具体导出什么内容呢? 请访问这个网址.
//http://u.discuz.net/home/do.php?ac=swfupload&op=config
?>

推荐阅读
  • Java序列化对象传给PHP的方法及原理解析
    本文介绍了Java序列化对象传给PHP的方法及原理,包括Java对象传递的方式、序列化的方式、PHP中的序列化用法介绍、Java是否能反序列化PHP的数据、Java序列化的原理以及解决Java序列化中的问题。同时还解释了序列化的概念和作用,以及代码执行序列化所需要的权限。最后指出,序列化会将对象实例的所有字段都进行序列化,使得数据能够被表示为实例的序列化数据,但只有能够解释该格式的代码才能够确定数据的内容。 ... [详细]
  • 本文讨论了Alink回归预测的不完善问题,指出目前主要针对Python做案例,对其他语言支持不足。同时介绍了pom.xml文件的基本结构和使用方法,以及Maven的相关知识。最后,对Alink回归预测的未来发展提出了期待。 ... [详细]
  • 在说Hibernate映射前,我们先来了解下对象关系映射ORM。ORM的实现思想就是将关系数据库中表的数据映射成对象,以对象的形式展现。这样开发人员就可以把对数据库的操作转化为对 ... [详细]
  • 本文介绍了在SpringBoot中集成thymeleaf前端模版的配置步骤,包括在application.properties配置文件中添加thymeleaf的配置信息,引入thymeleaf的jar包,以及创建PageController并添加index方法。 ... [详细]
  • 知识图谱——机器大脑中的知识库
    本文介绍了知识图谱在机器大脑中的应用,以及搜索引擎在知识图谱方面的发展。以谷歌知识图谱为例,说明了知识图谱的智能化特点。通过搜索引擎用户可以获取更加智能化的答案,如搜索关键词"Marie Curie",会得到居里夫人的详细信息以及与之相关的历史人物。知识图谱的出现引起了搜索引擎行业的变革,不仅美国的微软必应,中国的百度、搜狗等搜索引擎公司也纷纷推出了自己的知识图谱。 ... [详细]
  • MACElasticsearch安装步骤及验证方法
    本文介绍了MACElasticsearch的安装步骤,包括下载ZIP文件、解压到安装目录、启动服务,并提供了验证启动是否成功的方法。同时,还介绍了安装elasticsearch-head插件的方法,以便于进行查询操作。 ... [详细]
  • ZSI.generate.Wsdl2PythonError: unsupported local simpleType restriction ... [详细]
  • Oracle分析函数first_value()和last_value()的用法及原理
    本文介绍了Oracle分析函数first_value()和last_value()的用法和原理,以及在查询销售记录日期和部门中的应用。通过示例和解释,详细说明了first_value()和last_value()的功能和不同之处。同时,对于last_value()的结果出现不一样的情况进行了解释,并提供了理解last_value()默认统计范围的方法。该文对于使用Oracle分析函数的开发人员和数据库管理员具有参考价值。 ... [详细]
  • 本文介绍了使用AJAX的POST请求实现数据修改功能的方法。通过ajax-post技术,可以实现在输入某个id后,通过ajax技术调用post.jsp修改具有该id记录的姓名的值。文章还提到了AJAX的概念和作用,以及使用async参数和open()方法的注意事项。同时强调了不推荐使用async=false的情况,并解释了JavaScript等待服务器响应的机制。 ... [详细]
  • 本文介绍了Java工具类库Hutool,该工具包封装了对文件、流、加密解密、转码、正则、线程、XML等JDK方法的封装,并提供了各种Util工具类。同时,还介绍了Hutool的组件,包括动态代理、布隆过滤、缓存、定时任务等功能。该工具包可以简化Java代码,提高开发效率。 ... [详细]
  • android listview OnItemClickListener失效原因
    最近在做listview时发现OnItemClickListener失效的问题,经过查找发现是因为button的原因。不仅listitem中存在button会影响OnItemClickListener事件的失效,还会导致单击后listview每个item的背景改变,使得item中的所有有关焦点的事件都失效。本文给出了一个范例来说明这种情况,并提供了解决方法。 ... [详细]
  • 本文讲述了如何通过代码在Android中更改Recycler视图项的背景颜色。通过在onBindViewHolder方法中设置条件判断,可以实现根据条件改变背景颜色的效果。同时,还介绍了如何修改底部边框颜色以及提供了RecyclerView Fragment layout.xml和项目布局文件的示例代码。 ... [详细]
  • Android Studio Bumblebee | 2021.1.1(大黄蜂版本使用介绍)
    本文介绍了Android Studio Bumblebee | 2021.1.1(大黄蜂版本)的使用方法和相关知识,包括Gradle的介绍、设备管理器的配置、无线调试、新版本问题等内容。同时还提供了更新版本的下载地址和启动页面截图。 ... [详细]
  • 本文介绍了Python版Protobuf的安装和使用方法,包括版本选择、编译配置、示例代码等内容。通过学习本教程,您将了解如何在Python中使用Protobuf进行数据序列化和反序列化操作,以及相关的注意事项和技巧。 ... [详细]
  • 本文介绍了Perl的测试框架Test::Base,它是一个数据驱动的测试框架,可以自动进行单元测试,省去手工编写测试程序的麻烦。与Test::More完全兼容,使用方法简单。以plural函数为例,展示了Test::Base的使用方法。 ... [详细]
author-avatar
学习小菜鸟
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有