php 生成随机函数
php 生成随机函数
function genRandomString($len)
{
$chars = array(
"a", "b", "c", "d", "e", "f", "g", "h", "i", "j", "k",
"l", "m", "n", "o", "p", "q", "r", "s", "t", "u", "v",
"w", "x", "y", "z", "A", "B", "C", "D", "E", "F", "G",
"H", "I", "J", "K", "L", "M", "N", "O", "P", "Q", "R",
"S", "T", "U", "V", "W", "X", "Y", "Z", "0", "1", "2",
"3", "4", "5", "6", "7", "8", "9"
);
$charsLen = count($chars) - 1;
shuffle($chars);
$output = "";
for ($i=0; $i<$len; $i++)
{
$output .= $chars[mt_rand(0, $charsLen)];
}
return $output;
}
还有一种是php 自带的mt_rand 与rand 哦,不过建意最好用mt_rand这个事速度上优与rand
php 常用的排序算法代码[冒泡,递归排序
冒泡排序算法
function bubblesort($arr)
{
$n=count($arr);
for($i=0;$i<$n;$i++)
{
for($j=$i;$j<=$n-1;$j++)
{
if($arr[$i]>$arr[$j])
{
$temp=$arr[$i];
$arr[$i]=$arr[$j];
$arr[$j]=$temp;
}
}
}
return $arr;
}
//直接插入排序
function insertsort($arr)
{
$n=count($arr);
for($i=1;$i<$n;++$i)
{
if($arr[$i]<$arr[$i-1])
{
$tmp=$arr[$i];
$j=0;
for($j=$i-1;$j>=0&&$tmp<$arr[$j];--$j)
{
$arr[$j+1]=$arr[$j];
}
$arr[$j+1]=$tmp;
}
}
return $arr;
}简单排序算法
function simplesort($arr)
{
$tmp=0;
$t=0;
$n=count($arr);
for($i=0;$i<$n;++$i)
{
$t=$i;
for($j=$i+1;$j<$n;++$j)
{
if($arr[$t]>$arr[$j])
{
$t=$j;
}
}
$tmp=$arr[$i];
$arr[$i]=$arr[$t];
$arr[$t]=$tmp;
}
return $arr;
}快速排序算法
function qsort($array)
{
$n=count($array);
if($n<=1){return $array;}
$key=$array[0];
$l=array();
$r=array();
//分别进行递归排序,然后合成一个数组
for($i=1;$i<$n;$i++)
{
if($array[$i]<=$key)
{
$l[]=$array[$i];
}
else
{
$r[]=$array[$i];
}
}
$l=qsort($l);
$r=qsort($r);
return array_merge($l,array($key),$r);
}
php discuz chhome 图片上传swfupload功能
这上传与discuz来比, 还相差太远. 功能也欠缺.
除了部分内置的url引向,我们改不了之外, 其它的数据都是可以修改的.
<?php
/*
[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) {//û��Ϳѻ��
$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 = "<?xml version="1.0" encoding="UTF-8"?>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
?>
<?php
// literally from the ABNF in rfc3986 (thanks to 'WCP')
function validateIPv6($IP)
{
return preg_match('/A
(?:
(?:
(?:[a-f0-9]{1,4}:){6}
|
::(?:[a-f0-9]{1,4}:){5}
|
(?:[a-f0-9]{1,4})?::(?:[a-f0-9]{1,4}:){4}
|
(?:(?:[a-f0-9]{1,4}:){0,1}[a-f0-9]{1,4})?::(?:[a-f0-9]{1,4}:){3}
|
(?:(?:[a-f0-9]{1,4}:){0,2}[a-f0-9]{1,4})?::(?:[a-f0-9]{1,4}:){2}
|
(?:(?:[a-f0-9]{1,4}:){0,3}[a-f0-9]{1,4})?::[a-f0-9]{1,4}:
|
(?:(?:[a-f0-9]{1,4}:){0,4}[a-f0-9]{1,4})?::
)
(?:
[a-f0-9]{1,4}:[a-f0-9]{1,4}
|
(?:(?:[0-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-5]).){3}
(?:[0-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-5])
)
|
(?:
(?:(?:[a-f0-9]{1,4}:){0,5}[a-f0-9]{1,4})?::[a-f0-9]{1,4}
|
(?:(?:[a-f0-9]{1,4}:){0,6}[a-f0-9]{1,4})?::
)
)Z/ix',
$IP
);
}
?>
本站推荐出百度、谷歌关键词排名在线查询哦,
查询地址:
http://zz.111cn.net/keyword/
相关文章
- eval函数在php中是一个函数并不是系统组件函数,我们在php.ini中的disable_functions是无法禁止它的,因这他不是一个php_function哦。 eval()针对php安全来说具有很...2016-11-25
- 在php中eval是一个函数并且不能直接禁用了,但eval函数又相当的危险了经常会出现一些问题了,今天我们就一起来看看eval函数对数组的操作 例子, <?php $data="array...2016-11-25
Python astype(np.float)函数使用方法解析
这篇文章主要介绍了Python astype(np.float)函数使用方法解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下...2020-06-08- 这篇文章主要介绍了Python中的imread()函数用法说明,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2021-03-16
- 本文主要介绍了C# 中取绝对值的函数。具有很好的参考价值。下面跟着小编一起来看下吧...2020-06-25
- 下面小编就为大家带来一篇C#学习笔记- 随机函数Random()的用法详解。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧...2020-06-25
- CREATE FUNCTION ChangeBigSmall (@ChangeMoney money) RETURNS VarChar(100) AS BEGIN Declare @String1 char(20) Declare @String2 char...2016-11-25
- 这篇文章主要介绍了C++中Sort函数详细解析,sort函数是algorithm库下的一个函数,sort函数是不稳定的,即大小相同的元素在排序后相对顺序可能发生改变...2022-08-18
Android开发中findViewById()函数用法与简化
findViewById方法在android开发中是获取页面控件的值了,有没有发现我们一个页面控件多了会反复研究写findViewById呢,下面我们一起来看它的简化方法。 Android中Fin...2016-09-20- strstr() 函数搜索一个字符串在另一个字符串中的第一次出现。该函数返回字符串的其余部分(从匹配点)。如果未找到所搜索的字符串,则返回 false。语法:strstr(string,search)参数string,必需。规定被搜索的字符串。 参数sea...2013-10-04
PHP函数分享之curl方式取得数据、模拟登陆、POST数据
废话不多说直接上代码复制代码 代码如下:/********************** curl 系列 ***********************///直接通过curl方式取得数据(包含POST、HEADER等)/* * $url: 如果非数组,则为http;如是数组,则为https * $header:...2014-06-07- Foreach 函数(PHP4/PHP5)foreach 语法结构提供了遍历数组的简单方式。foreach 仅能够应用于数组和对象,如果尝试应用于其他数据类型的变量,或者未初始化的变量将发出错误信息。...2013-09-28
- 这篇文章主要介绍了超简洁java实现双色球若干注随机号码生成(实例代码),本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下...2021-04-02
- 本文介绍两种使用 php 生成二维码的方法。 (1)利用google生成二维码的开放接口,代码如下: /** * google api 二维码生成【QRcode可以存储最多4296个字母数字类型的任意文本,具体可以查看二维码数据格式】 * @param strin...2015-10-21
- free函数是释放之前某一次malloc函数申请的空间,而且只是释放空间,并不改变指针的值。下面我们就来详细探讨下...2020-04-25
- 这篇文章主要介绍了Java生成随机姓名、性别和年龄的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2020-10-01
- PHP 函数 strip_tags 提供了从字符串中去除 HTML 和 PHP 标记的功能,该函数尝试返回给定的字符串 str 去除空字符、HTML 和 PHP 标记后的结果。由于 strip_tags() 无法实际验证 HTML,不完整或者破损标签将导致更多的数...2014-05-31
- 分享一个PHP加密解密的函数,此函数实现了对部分变量值的加密的功能。 加密代码如下: /* *功能:对字符串进行加密处理 *参数一:需要加密的内容 *参数二:密钥 */ function passport_encrypt($str,$key){ //加密函数 srand(...2015-10-30
- 这篇文章主要介绍了C#生成随机数功能,涉及C#数学运算与字符串操作相关技巧,具有一定参考借鉴价值,需要的朋友可以参考下...2020-06-25
SQL Server中row_number函数的常见用法示例详解
这篇文章主要给大家介绍了关于SQL Server中row_number函数的常见用法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2020-12-08