分类 php技术 下的文章

laravel5.5 配置七牛上传文件

基于 https://github.com/qiniu/php-sdk 开发
符合Laravel 5 的Storage用法。

更新

  • v0.5 增加了QiniuUrl来更方便的设置文件 URL 参数。
  • v0.3 增加了对PIPE以及回调地址参数的配置。 感谢abcsun提供的灵感。
  • v0.2 提供了对多域名的支持。这是为了配合七牛的默认域名、HTTPS域名和自定义域名而添加的功能。

安装

  • composer require zgldh/qiniu-laravel-storage

  • config/app.php 里面的 providers 数组, 加上一行 zgldh\QiniuStorage\QiniuFilesystemServiceProvider

  • config/filesystem.php 里面的 disks数组加上:

     'disks' => [
         ... ,
         'qiniu' => [
             'driver'  => 'qiniu',
             'domains' => [
                 'default'   => 'xxxxx.com1.z0.glb.clouddn.com', //你的七牛域名
                 'https'     => 'dn-yourdomain.qbox.me',         //你的HTTPS域名
                 'custom'    => 'static.abc.com',                //你的自定义域名
             ],
             'access_key'=> '',  //AccessKey
             'secret_key'=> '',  //SecretKey
             'bucket'    => '',  //Bucket名字
             'notify_url'=> '',  //持久化处理回调地址
         ],
     ],
    
  • 完成

使用

第一种用法

$disk = \Storage::disk('qiniu');
$disk->exists('file.jpg');                      //文件是否存在
$disk->get('file.jpg');                         //获取文件内容
$disk->put('file.jpg',$contents);               //上传文件
$disk->put('file.jpg',fopen('path/to/big.jpg','r+')); //分段上传文件。建议大文件>10Mb使用。 
$disk->prepend('file.log', 'Prepended Text');   //附加内容到文件开头
$disk->append('file.log', 'Appended Text');     //附加内容到文件结尾
$disk->delete('file.jpg');                      //删除文件
$disk->delete(['file1.jpg', 'file2.jpg']);
$disk->copy('old/file1.jpg', 'new/file1.jpg');  //复制文件到新的路径
$disk->move('old/file1.jpg', 'new/file1.jpg');  //移动文件到新的路径
$size = $disk->size('file1.jpg');               //取得文件大小
$time = $disk->lastModified('file1.jpg');       //取得最近修改时间 (UNIX)
$files = $disk->files($directory);              //取得目录下所有文件
$files = $disk->allFiles($directory);               //这个没实现。。。
$directories = $disk->directories($directory);      //这个也没实现。。。
$directories = $disk->allDirectories($directory);   //这个也没实现。。。
$disk->makeDirectory($directory);               //这个其实没有任何作用
$disk->deleteDirectory($directory);             //删除目录,包括目录下所有子文件子目录

$disk->getDriver()->uploadToken('file.jpg');                //获取上传Token
$disk->getDriver()->downloadUrl('file.jpg');                //获取下载地址
$disk->getDriver()->downloadUrl('file.jpg')
                  ->setDownload('foo.jpg');                 //获取下载地址,文件名为 foo.jpg
$disk->getDriver()->downloadUrl('file.jpg', 'https');       //获取HTTPS下载地址
$disk->getDriver()->privateDownloadUrl('file.jpg');         //获取私有bucket下载地址
$disk->getDriver()->privateDownloadUrl('file.jpg', 'https');//获取私有bucket的HTTPS下载地址
$disk->getDriver()->privateDownloadUrl('file.jpg', 
                                    [
                                        'domain'=>'https',
                                        'expires'=>3600
                                    ]);                     //获取私有bucket的HTTPS下载地址。超时 3600 秒。
$disk->getDriver()->imageInfo('file.jpg');                  //获取图片信息
$disk->getDriver()->imageExif('file.jpg');                  //获取图片EXIF信息
$disk->getDriver()->imagePreviewUrl('file.jpg','imageView2/0/w/100/h/200');                         //获取图片预览URL
$disk->getDriver()->privateImagePreviewUrl('file.jpg','imageView2/0/w/100/h/200');                  //获取私有bucket图片预览URL
$disk->getDriver()->verifyCallback('application/x-www-form-urlencoded', $request->header('Authorization'), 'callback url', $request->getContent());//验证回调内容是否合法
$disk->getDriver()->persistentFop('file.flv','avthumb/m3u8/segtime/40/vcodec/libx264/s/320x240');   //执行持久化数据处理
$disk->getDriver()->persistentFop('file.flv','fop','队列名');   //使用私有队列执行持久化数据处理
$disk->getDriver()->persistentStatus($persistent_fop_id);       //查看持久化数据处理的状态。

第二种用法 (就是省略了一个getDriver)

use zgldh\QiniuStorage\QiniuStorage;

$disk = QiniuStorage::disk('qiniu');
$disk->exists('file.jpg');                      //文件是否存在
$disk->get('file.jpg');                         //获取文件内容
$disk->put('file.jpg',$contents);               //上传文件
$disk->put('file.jpg',fopen('path/to/big.jpg','r+')); //分段上传文件。建议大文件>10Mb使用。
$disk->prepend('file.log', 'Prepended Text');   //附加内容到文件开头
$disk->append('file.log', 'Appended Text');     //附加内容到文件结尾
$disk->delete('file.jpg');                      //删除文件
$disk->delete(['file1.jpg', 'file2.jpg']);
$disk->copy('old/file1.jpg', 'new/file1.jpg');  //复制文件到新的路径
$disk->move('old/file1.jpg', 'new/file1.jpg');  //移动文件到新的路径
$size = $disk->size('file1.jpg');               //取得文件大小
$time = $disk->lastModified('file1.jpg');       //取得最近修改时间 (UNIX)
$files = $disk->files($directory);              //取得目录下所有文件
$files = $disk->allFiles($directory);               //这个没实现。。。
$directories = $disk->directories($directory);      //这个也没实现。。。
$directories = $disk->allDirectories($directory);   //这个也没实现。。。
$disk->makeDirectory($directory);               //这个其实没有任何作用
$disk->deleteDirectory($directory);             //删除目录,包括目录下所有子文件子目录

$disk->uploadToken('file.jpg');                     //获取上传Token
$disk->downloadUrl('file.jpg');                     //获取下载地址
$disk->downloadUrl('file.jpg')
     ->setDownload('foo.jpg');                      //获取下载地址,文件名为 foo.jpg
$disk->downloadUrl('file.jpg', 'https');            //获取HTTPS下载地址
$disk->privateDownloadUrl('file.jpg');              //获取私有bucket下载地址
$disk->privateDownloadUrl('file.jpg', 'https');     //获取私有bucket的HTTPS下载地址
$disk->privateDownloadUrl('file.jpg', 
                        [
                            'domain'=>'https',
                            'expires'=>3600
                        ]);                         //获取私有bucket的HTTPS下载地址。超时 3600 秒。
$disk->imageInfo('file.jpg');                       //获取图片信息
$disk->imageExif('file.jpg');                       //获取图片EXIF信息
$disk->imagePreviewUrl('file.jpg','imageView2/0/w/100/h/200');                          //获取图片预览URL
$disk->privateImagePreviewUrl('file.jpg','imageView2/0/w/100/h/200');                   //获取私有bucket图片预览URL
$disk->verifyCallback('application/x-www-form-urlencoded', $request->header('Authorization'), 'callback url', $request->getContent());//验证回调内容是否合法
$disk->persistentFop('file.flv','avthumb/m3u8/segtime/40/vcodec/libx264/s/320x240');    //执行持久化数据处理
$disk->persistentFop('file.flv','fop','队列名');    //使用私有队列执行持久化数据处理
$disk->persistentStatus($persistent_fop_id);        //查看持久化数据处理的状态。

laravel上传文件代码实例

/**
 * 七牛上传文件 FileUploadInfo
 * @author jiazhizhong <jiazhizhongphp@163.com>
 * @param Request $request
 * @return json
 */
public function FileUploadInfo(Request $request){
    $this->disk = \Storage::disk('qiniu');
    $data = [];
    // 获取到文件信息
    $file = !empty($_FILES['fileUpload']) ? $_FILES['fileUpload'] : [];
    if (empty($file)) {
        return '';
    }
    // 获取文件名
    $fileName = $file['name'];
    $TmpName = $file['tmp_name'];
    // 获取文件内容
    $fp = fopen($TmpName,"r");
    $contents = fread($fp,filesize($TmpName));
    $this->disk->put($fileName,$contents);                        //上传文件
    $data['url'] = $this->disk->getDriver()->downloadUrl($fileName);      //获取下载地址
    return $this->response('true',1,$data);
}

官方SDK / 手册

  • https://github.com/qiniu/php-sdk
  • http://developer.qiniu.com/docs/v6/sdk/php-sdk.html

转自:https://blog.csdn.net/fishermanmax/article/details/53059104

php面试题

1、用PHP打印出前一天的时间格式是2006-5-10 22:21:21

$a = date("Y-m-d H:i:s", strtotime("-1 day"));   
print_r($a);

2、echo(),print(),print_r()的区别

echo 和print不是一个函数,是一个语言结构   
int print(string $arg), 只有一个参数   
echo arg1,arg1,arg2; 可以输出多个参数,返回void   
echo和print只能打印出string,不能打印出结构   
print_r能打印出结构   
比如    
$arr = array("key"=>"value");   
print_r($arr);

3、能够使HTML和PHP分离开使用的模板引擎

smarty,phplib

4、使用哪些工具进行版本控制?

svn,git,cvs

5、如何实现字符串翻转?

#中文:GB2312, 代码是使用GB2312编码   
<?php       
function reverse($str)   {   
    $ret = "";       
    len=mbstrwidth(len=mbstrwidth(str,"GB2312");   
    for(i=0;i=0;i< len;len;i++)   
    {   
        arr[]=mbsubstr(arr[]=mbsubstr(str, $i, 1, "GB2312");   
    }   
    return implode("", array_reverse($arr));   
}   
print_r(reverse("你好"));

6、优化MYSQL数据库的方法

语句方面:
1、使用索引,增加查询效率
2、优化查询语句,提高索引命中率

数据库涉及方面:
1、构造分库分表,提高数据库的存储和扩展能力
2、根据需要使用不同的存储引擎

7、PHP的意思

超级文本预处理语言
Hypertext PreProcessor

8、MYSQL取得当前时间的函数是?,格式化日期的函数是

CURRENT_TIMESTAMP()   
DATE_FORMAT()   
select DATE_FORMAT("2011-11-21 10:10:10", "%Y-%m-%d");

9、实现中文字串截取无乱码的方法。

mb_substr($str, 1, 1, "GB2312");

10、您是否用过版本控制软件? 如果有您用的版本控制软件的名字是

svn
git

11、您是否用过模板引擎? 如果有您用的模板引擎的名字是?

smarty

12、对于大流量的网站,您采用什么样的方法来解决访问量问题?

1、有效使用缓存,增加缓存命中率
2、使用负载均衡
3、对静态文件使用CDN进行存储和加速
4、想法减少数据库的使用
5、查看出现统计的瓶颈在哪里

13、用PHP写出显示客户端IP与服务器IP的代码

$_SERVER["REMOTE_ADDR"]
$_SERVER["SERVER_ADDR"]

14、语句include和require的区别是什么?为避免多次包含同一文件,可用(?)语句代替它们?

在失败的时候:
include产生一个warning,而require产生直接产生错误中断
require在运行前载入
include在运行时载入
require_once
include_once

15、如何修改SESSION的生存时间

session_set_cookie_params 

16、有一个网页地址, 比如PHP研究室主页: http://www.phpv.net/index.html,如何得到它的内容?

file_get_contents
curl

17、在HTTP 1.0中,状态码401的含义是(?);如果返回“找不到文件”的提示,则可用 header 函数,其语句为

未授权
header("HTTP/1.0 404 Not Found");
fast CGI中:
header("Status: 404 Not Found");

18、在PHP中,heredoc是一种特殊的字符串,它的结束标志必须?

成对出现
$a = <<EOD
good test
EOD;

19、谈谈asp,php,jsp的优缺点

asp是需要依赖IIS,是微软开发的语言
php和jsp可以依赖apache或者 nginx等其他服务器

20、谈谈对mvc的认识

model : 数据结构层
view :展现
control : 接收和判断处理输入

21、写出发贴数最多的十个人名字的SQL,利用下表:members(id,username,posts,pass,email)

select top 10 id,username from members order by posts desc

22、请说明php中传值与传引用的区别。什么时候传值什么时候传引用?

&表示传引用
函数中参数传引用会将参数进行改变
一般在输出参数有多个的时候可以考虑使用引用

23. 在PHP中error_reporting这个函数有什么作用?

设定error的展示级别

24. 请写一个函数验证电子邮件的格式是否正确

$str = "jiazhizhong@126.com";   
$regex="([a?z0?9\.?]+)@([\da?z\.?]+)\.([a?z\.]2,6)" ; //正则   
preg_match($regex,$str,$matches);
return $matches;

25. 简述如何得到当前执行脚本路径,包括所得到参数。

$argc --获取参数数量
$argv --获取参数列表

26.如何修改SESSION的生存时间.

session_set_cookie_params

27、JS表单弹出对话框函数是?获得输入焦点函数是?

alert()
confirm()
promopt()
focus()

28、JS的转向函数是?怎么引入一个外部JS文件?

window.location.href="#"
<script src="#"></script>

29、foo()和@foo()之间有什么区别?

@代表所有warning忽略

30、如何声明一个名为”myclass”的没有方法和属性的类?

class myclass
{
}

31、如何实例化一个名为”myclass”的对象?

$myclass = new myclass();

32、你如何访问和设置一个类的属性?

<?php   
class A   
{   
    public $name = "A";   
}   
$a = new A();   
$n=$a->name;   
print_r($n);

**33、mysql_fetch_row() 和mysql_fetch_array之间有什么区别? **

mysql_fetch_array() 是 mysql_fetch_row() 的扩展版本。除了将数据以数字索引方式储存在数组中之外,还可以将数据作为关联索引储存,用字段名作为键名。
<?php  
mysql_connect("localhost", "mysql_user", "mysql_password") or   
    die("Could not connect: " . mysql_error());   
mysql_select_db("mydb");   
$result = mysql_query("SELECT id, name FROM mytable");   
while ($row=mysqlfetcharray($result, MYSQL_ASSOC)) {   
    printf ("ID: %s  Name: %s", $row["id"],$row["id"],$row["name"]);   
}   
mysql_free_result($result);

34、GD库是做什么用的?

动态的开放的图片处理库

35、指出一些在PHP输入一段HTML代码的办法。

echo "{html}";
echo <<EOD
{html}
EOD;

36、下面哪个函数可以打开一个文件,以对文件进行读和写操作? 答案: C

(a) fget() (b) file_open() (c) fopen() (d) open_file()

37、下面哪个选项没有将 john 添加到users 数组中? 答案: B

(a) $users[] = ‘john’;   
(b) array_add($users,’john’);   
(c) array_push($users,‘john’);   
(d) $users ||= ‘john’;

38、下面的程序会输出什么? 答案: 10

$num = 10;   
function multiply(){   

   $num=$num * 10;
}
multiply();
echo $num;
?>

39、使用php写一段简单查询,查出所有姓名为“张三”的内容并打印出来。

表名 UserName Tel Content Date
张三 13333663366 大专毕业 2006-10-11
张三 13612312331 本科毕业 2006-10-15
张四 021-55665566 中专毕业 2006-10-15

请根据上面的题目完成代码:
$mysql_db=mysql_connect("local","root","pass");   

   @mysql_select_db("DB",$mysql_db);
$sql = sprintf("select * from %s where UserName = '%s'",
"表名",
"张三");
$values=mysqlquery($sql);
while($item=mysqlfetchqueryarray($values))
{
echo sprintf("用户名:%s, 电话 %s, 学历: %s, 毕业日期: %s",
item[′UserName′],item['Tel'], item[′Content′],item['Date']
);
}

40、如何使用下面的类,并解释下面什么意思?

class test{   
    function Get_test($num){   

   $num=md5(md5($num)."En");
   return $num;
}
}
$test = new test();
$ret = $test->Get_test(11);
print_r($ret);exit;
#将num进行MD5编码之后生成的32位字符串a1和"En"联系起来之后再进行一次MD5编码

41、写出 SQL语句的格式 : 插入 ,更新 ,删除

表名 UserName Tel Content Date
张三 13333663366 大专毕业 2006-10-11
张三 13612312331 本科毕业 2006-10-15
张四 021-55665566 中专毕业 2006-10-15

(a) 有一新记录(小王 13254748547 高中毕业 2007-05-06)请用SQL语句新增至表中

insert into 表名 values('小王', '13254748547', '高中毕业', '2007-05-06')

(b) 请用sql语句把张三的时间更新成为当前系统时间
update 表名 set Date = GETDATE() where UserName = "张三"

(c) 请写出删除名为张四的全部记录
delete from 表明 where UserName = "张四"

42、请写出数据类型(int char varchar datetime text)的意思; 请问varchar和char有什么区别

int 整型
char 存储定长
varchar 存储变长
datetime 时间
text 存储变长的
varchar是变长
char(20) 定长

43、MySQ自增类型(通常为表ID字段)必需将其设为(?)字段

auto_increment

44、写出以下程序的输出结果? 答案:4

$b=201;   
$c=40;   
$a=$b>$c ? 4 : 5;   
echo $a;   
?>  

45、检测一个变量是否有设置的函数是否?是否为空的函数是?

isset()
empty()

46、取得查询结果集总数的函数是?

mysql_num_rows()

47、$arr = array('james', 'tom', 'symfony'); 请打印出第一个元素的值

print_r($arr[0]);   
reset($arr);   
print_r(current($arr));   
print_r(array_shift($arr));

48、请将41题的数组的值用','号分隔并合并成字串输出

implode

49、$a=array('abcdef');请取出$a=array('abcdef');请取出$a的值并打印出第一个字母

$a[0];
substr($a, 0, 1);

50、PHP可以和sql server/oracle等数据库连接吗?

可以
有现成的库

51、请写出PHP5权限控制修饰符

public  (公共的)
private (私有的)
protected (受保护的)

52、请写出php5的构造函数和析构函数

public function __construct()   {   
}   
public function __destruct()   {   
}

[编程题]

1、写一个函数,尽可能高效的,从一个标准 url 里取出文件的扩展名

例如: http://www.sina.com.cn/abc/de/fg.php?id=1 需要取出 php 或 .php
<?php   
$url = "http://www.sina.com.cn/abc/de/fg.php?id=1";   
$arr = parseurl($url);   
$pathArr= pathinfo($arr['path']);   
print_r($pathArr['extension']);

2. 写一个函数,算出两个文件的相对路径

如 $a = '/a/b/c/d/e.php';   
$b = '/a/b/12/34/c.php';   
计算出 b相对于b相对于a 的相对路径应该是 http://www.cnblogs.com/12/34/c.php将添上   
<?php   
$a = '/a/b/c/d/e.php';   
$b = '/a/b/12/34/c.php';   
//获取path相对于conpath的相对路径   
function sGetRelativePath($path,$path,$conpath)   {   
    $pathArr=explode("/",$path);   
    $conpathArr=explode("/",$conpath);   
    $dismatchlen = 0;   
    for(i=0;i < count($pathArr);i++)   
    {   
        if($conpathArr[i] != $pathArr[i])   
        {   
            $dismatchlen=count($pathArr) - $i;   
            $arrLeft=arrayslice($pathArr, $i);   
            break;   
        }   
    }   
    $ret=strrepeat("../",$dismatchlen).implode("/", $arrLeft);   
    return $ret;   
}   
print_r(sGetRelativePath($b,$b,$a));

3、写一个函数,能够遍历一个文件夹下的所有文件和子文件夹。

<?php   
function aGetAllFile($folder)   {   
    $aFileArr = array();   
    if(is_dir($folder))   
    {   
        $handle=opendir(#folder);   
        while(($file=readdir($handle)) !== false)   
        {   
            //如果是.或者..则跳过   
            if($file=="."||$file == "..")   
            {   
                continue;   
            }   
            if(is_file($folder."/".$folder."/".file))   
            {   
                $aFileArr[]=$file;    
            }   
            else if(is_dir($folder."/".$folder."/".file))   
            {   
                $aFileArr[$file] = aGetAllFile($folder."/".$folder."/".file);   
            }   
        }   
        closedir($handle);   
    }   
    return $aFileArr;   
}   
$path = "/home/test/sql";   
print_r(aGetAllFile($path));

php 多线程扩展 pthreads 安装 及 使用

1、扩展的编译安装php(Linux),编辑参数 --enable-maintainer-zts 是必选项:
2、下载 php7:
http://tw2.php.net/get/php-7.1.2.tar.gz/from/a/mirrorduoxc

3、解压并编译php
tar -zxf php-7.1.2.tar.gz
cd php-7.1.2
./configure --prefix=/usr/local/php712 --with-config-file-path=/usr/local/php712/etc --with-config-file-scan-dir=/usr/local/php712/etc/php.d --with-mcrypt=/usr/include --enable-mysqlnd --with-mysqli --with-pdo-mysql --enable-fpm --with-gd --with-iconv --with-zlib --enable-xml --enable-shmop --enable-sysvsem --enable-inline-optimization --enable-mbregex --enable-mbstring --enable-ftp --enable-gd-native-ttf --enable-pcntl --enable-sockets --with-xmlrpc --enable-zip --enable-soap --without-pear --enable-session --with-curl --with-jpeg-dir --enable-sqlite-utf8 --enable-sysvmsg --enable-sysvshm --enable-wddx --with-xsl --enable-opcache --enable-maintainer-zts

sudo make -j8 && sudo make install

4、php编译完之后开始编译安装 pthreads扩展
5、下载pthreads扩展
https://github.com/krakjoe/pthreads
6、解压并安装
tar -zxf pthreads-3.1.6.tgz
cd pthreads-3.1.6
./configure --with-php-config=/usr/local/php712/bin/php-config
sudo make -j8 && sudo make install

7、配置php.ini
sudo vim /usr/local/php712/etc/php.ini
在 php.ini 最后添加:
[pthreads]
extension=pthreads.so

8、测试pthreads扩展
Thread.php :

<?php
Class Thread {

    public $hooks = array();
    public $args = array();

    public function thread() {

    }

    public function addthread($func) {
        $args = array_slice(func_get_args(), 1);
        $this->hooks[] = $func;
        $this->args[] = $args;
        return true;
    }

    public function runthread() {
        if(isset($_GET['flag'])) {
            $flag = intval($_GET['flag']);
        }

        if($flag || $flag === 0) {
            call_user_func_array($this->hooks[$flag], $this->args[$flag]);
        } else {
            for($i = 0, $size = count($this->hooks); $i < $size; $i++) {
                $fp=fsockopen($_SERVER['HTTP_HOST'],$_SERVER['SERVER_PORT']);

                if($fp) {
                    $out = "GET {$_SERVER['PHP_SELF']}?flag=$i HTTP/1.1rn";
                    $out .= "Host: {$_SERVER['HTTP_HOST']}rn";
                    $out .= "Connection: Closernrn";
                    fputs($fp,$out);
                    fclose($fp);
                }
            }
        }
    }
}

test.php :

include('Thread.php');
Class AsyncOperation extends Thread {

    public function __construct($arg){
        $this->arg = $arg;
    }

    public function run(){
        if($this->arg){
            printf("Hello %s\n", $this->arg);
        }
    }
}
$thread = new AsyncOperation("World");
if($thread->start()){
    $thread->join();
}

PHP 加密 和 解密 算法

<?php
/**
 * $string: 明文 或 密文
 * $operation:DECODE表示解密,其它表示加密
 * $key: 密匙
 * $expiry:密文有效期
 */
function authcode($string, $operation = 'DECODE', $key = '', $expiry = 0) {
    // 动态密匙长度,相同的明文会生成不同密文就是依靠动态密匙
    $ckey_length = 4;

    // 密匙
    $key = md5($key ? $key : $GLOBALS['discuz_auth_key']);

    // 密匙a会参与加解密
    $keya = md5(substr($key, 0, 16));
    // 密匙b会用来做数据完整性验证
    $keyb = md5(substr($key, 16, 16));
    // 密匙c用于变化生成的密文
    $keyc = $ckey_length ? ($operation == 'DECODE' ? substr($string, 0, $ckey_length): substr(md5(microtime()), -$ckey_length)) : '';
    // 参与运算的密匙
    $cryptkey = $keya.md5($keya.$keyc);
    $key_length = strlen($cryptkey);
    // 明文,前10位用来保存时间戳,解密时验证数据有效性,10到26位用来保存$keyb(密匙b),解密时会通过这个密匙验证数据完整性
    // 如果是解码的话,会从第$ckey_length位开始,因为密文前$ckey_length位保存 动态密匙,以保证解密正确
    $string = $operation == 'DECODE' ? base64_decode(substr($string, $ckey_length)) : sprintf('%010d', $expiry ? $expiry + time() : 0).substr(md5($string.$keyb), 0, 16).$string;
    $string_length = strlen($string);
    $result = '';
    $box = range(0, 255);
    $rndkey = array();
    // 产生密匙簿
    for($i = 0; $i <= 255; $i++) {
        $rndkey[$i] = ord($cryptkey[$i % $key_length]);
    }
    // 用固定的算法,打乱密匙簿,增加随机性,好像很复杂,实际上并不会增加密文的强度
    for($j = $i = 0; $i < 256; $i++) {
        $j = ($j + $box[$i] + $rndkey[$i]) % 256;
        $tmp = $box[$i];
        $box[$i] = $box[$j];
        $box[$j] = $tmp;
    }
    // 核心加解密部分
    for($a = $j = $i = 0; $i < $string_length; $i++) {
        $a = ($a + 1) % 256;
        $j = ($j + $box[$a]) % 256;
        $tmp = $box[$a];
        $box[$a] = $box[$j];
        $box[$j] = $tmp;
        // 从密匙簿得出密匙进行异或,再转成字符
        $result .= chr(ord($string[$i]) ^ ($box[($box[$a] + $box[$j]) % 256]));
    }
    if($operation == 'DECODE') {
        // substr($result, 0, 10) == 0 验证数据有效性
        // substr($result, 0, 10) - time() > 0 验证数据有效性
        // substr($result, 10, 16) == substr(md5(substr($result, 26).$keyb), 0, 16) 验证数据完整性
        // 验证数据有效性,请看未加密明文的格式
        if((substr($result, 0, 10) == 0 || substr($result, 0, 10) - time() > 0) && substr($result, 10, 16) == substr(md5(substr($result, 26).$keyb), 0, 16)) {
            return substr($result, 26);
        } else {
            return '';
        }
    } else {
        // 把动态密匙保存在密文里,这也是为什么同样的明文,生产不同密文后能解密的原因
        // 因为加密后的密文可能是一些特殊字符,复制过程可能会丢失,所以用base64编码
        return $keyc.str_replace('=', '', base64_encode($result));
    }
}
?>

调用实例:
<?php
$key = "e10adc3949ba59abbe56e057f20f883e";
$res = authcode("php是最好的语言","ENCODE",$key);
var_dump($res);
echo "
";
var_dump(authcode($res,"DECODE",$key));
string(67) "759880MngibY1yKLjCEtZDVd7ObzYJ39fTCcZkJGWoDovOaGlZeDaYRa5lx5jIXUt7k"
string(21) "php是最好的语言"

PHP通用检测函数集合

这些函数都要测试才能使用,不保证个个都能使用,很多好的代码函数都可以在phpcms,dedecms,帝国cms中查找。

// ※CheckMoney($C_Money) 检查数据是否是99999.99格式
// ※CheckEmailAddr($C_mailaddr) 判断是否为有效邮件地址
// ※CheckWebAddr($C_weburl) 判断是否为有效网址
// ※CheckEmpty($C_char) 判断字符串是否为空
// ※CheckLengthBetween($C_char, $I_len1, $I_len2=100) 判断是否为指定长度内字符串
// ※CheckUser($C_user) 判断是否为合法用户名
// ※CheckPassword($C_passwd) 判断是否为合法用户密码
// ※CheckTelephone($C_telephone) 判断是否为合法电话号码
// ※CheckValueBetween($N_var, $N_val1, $N_val2) 判断是否是某一范围内的合法值
// ※CheckPost($C_post) 判断是否为合法邮编(固定长度)
// ※CheckExtendName($C_filename,$A_extend) 判断上传文件的扩展名
// ※CheckImageSize($ImageFileName,$LimitSize) 检验上传图片的大小
// ※AlertExit($C_alert,$I_goback=0) 非法操作警告并退出
// ※Alert($C_alert,$I_goback=0) 非法操作警告
// ※ReplaceSpacialChar($C_char) 特殊字符替换函数
// ※ExchangeMoney($N_money) 资金转换函数
// ※WindowLocation($C_url,$C_get=”",$C_getOther=”") PHP中的window.location函数

<?php 
// 函数名:CheckMoney($C_Money) 
// 作 用:检查数据是否是99999.99格式 
// 参 数:$C_Money(待检测的数字) 
// 返回值:布尔值 
// 备 注:无 
//----------------------------------------------------------------------------------- 
function CheckMoney($C_Money) { 
    if (!ereg("^[0-9][.][0-9]$", $C_Money)) return false; 
    return true; 
} 

//----------------------------------------------------------------------------------- 
// 函数名:CheckEmailAddr($C_mailaddr) 
// 作 用:判断是否为有效邮件地址 
// 参 数:$C_mailaddr(待检测的邮件地址) 
// 返回值:布尔值 
// 备 注:无 
//----------------------------------------------------------------------------------- 
function CheckEmailAddr($C_mailaddr) { 
    if (!eregi("^[_a-z0-9-]+(.[_a-z0-9-]+)*@[a-z0-9-]+(.[a-z0-9-]+)*$",  $C_mailaddr)) $c_mailaddr))  { 
        return false; 
    } 
    return true; 
} 

//----------------------------------------------------------------------------------- 
// 函数名:CheckWebAddr($C_weburl) 
// 作 用:判断是否为有效网址 
// 参 数:$C_weburl(待检测的网址) 
// 返回值:布尔值 
// 备 注:无 
//----------------------------------------------------------------------------------- 
function CheckWebAddr($C_weburl) { 
    if (!ereg("^http://[_a-zA-Z0-9-]+(.[_a-zA-Z0-9-]+)*$", $C_weburl)) { 
        return false; 
    } 
    return true; 
} 
//----------------------------------------------------------------------------------- 
// 函数名:CheckEmpty($C_char) 
// 作 用:判断字符串是否为空 
// 参 数:$C_char(待检测的字符串) 
// 返回值:布尔值 
// 备 注:无 
//----------------------------------------------------------------------------------- 
function CheckEmptyString($C_char) { 
    if (!is_string($C_char)) return false; //是否是字符串类型 
    if (empty($C_char)) return false; //是否已设定 
    if ($C_char=='') return false; //是否为空 
    return true; 
} 

//----------------------------------------------------------------------------------- 
// 函数名:CheckLengthBetween($C_char, $I_len1, $I_len2=100) 
// 作 用:判断是否为指定长度内字符串 
// 参 数:$C_char(待检测的字符串) 
// $I_len1 (目标字符串长度的下限) 
// $I_len2 (目标字符串长度的上限) 
// 返回值:布尔值 
// 备 注:无 
//----------------------------------------------------------------------------------- 
function CheckLengthBetween($C_cahr, $I_len1, $I_len2=100) { 
    $C_cahr = trim($C_cahr); 
    if (strlen($C_cahr) < $I_len1) return false; 
    if (strlen($C_cahr) > $I_len2) return false; 
    return true; 
} 
//----------------------------------------------------------------------------------- 
// 函数名:CheckUser($C_user) 
// 作 用:判断是否为合法用户名 
// 参 数:$C_user(待检测的用户名) 
// 返回值:布尔值 
// 备 注:无 
//----------------------------------------------------------------------------------- 
function CheckUser($C_user)  { 
    if (!CheckLengthBetween($C_user, 4, 20)) return false; //宽度检验 
    if (!ereg("^[_a-zA-Z0-9]*$", $C_user)) return false; //特殊字符检验 
    return true; 
} 

// 函数名:CheckPassword($C_passwd) 
// 作 用:判断是否为合法用户密码 
// 参 数:$C_passwd(待检测的密码) 
// 返回值:布尔值 
// 备 注:无 
//----------------------------------------------------------------------------------- 
function CheckPassword($C_passwd) { 
    if (!CheckLengthBetween($C_passwd, 4, 20)) return false; //宽度检测 
    if (!ereg("^[_a-zA-Z0-9]*$", $C_passwd)) return false; //特殊字符检测 
    return true; 
} 
//----------------------------------------------------------------------------------- 
// 函数名:CheckTelephone($C_telephone) 
// 作 用:判断是否为合法电话号码 
// 参 数:$C_telephone(待检测的电话号码) 
// 返回值:布尔值 
// 备 注:无 
//----------------------------------------------------------------------------------- 
function CheckTelephone($C_telephone) { 
    if (!ereg("^[+]?[0-9]+([xX-][0-9]+)*$", $C_telephone)) return false; 
    return true; 
} 
//----------------------------------------------------------------------------------- 
// 函数名:CheckValueBetween($N_var, $N_val1, $N_val2) 
// 作 用:判断是否是某一范围内的合法值 
// 参 数:$N_var 待检测的值 
// $N_var1 待检测值的上限 
// $N_var2 待检测值的下限 
// 返回值:布尔值 
// 备 注:无 
//----------------------------------------------------------------------------------- 
function CheckValueBetween($N_var, $N_val1, $N_val2) { 
    if ($N_var < $N_var1 ││ $N_var > $N_var2) { 
        return false; 
    } 
    return true; 
} 

// 函数名:CheckPost($C_post) 
// 作 用:判断是否为合法邮编(固定长度) 
// 参 数:$C_post(待check的邮政编码) 
// 返回值:布尔值 
// 备 注:无 
//----------------------------------------------------------------------------------- 
function CheckPost($C_post) { 
    $C_post=trim($C_post); 
    if (strlen($C_post) == 6) { 
        if(!ereg("^[+]?[_0-9]*$",$C_post)) { 
            return true;; 
        }else { 
            return false; 
        } 
    }else { 
        return false;; 
    } 
}

//----------------------------------------------------------------------------------- 
// 函数名:CheckExtendName($C_filename,$A_extend) 
// 作 用:上传文件的扩展名判断 
// 参 数:$C_filename 上传的文件名 
// $A_extend 要求的扩展名 
// 返回值:布尔值 
// 备 注:无 
//----------------------------------------------------------------------------------- 
function CheckExtendName($C_filename,$A_extend) { 
    if(strlen(trim($C_filename)) < 5) { 
        return 0; //返回0表示没上传图片 
    } 
    $lastdot = strrpos($C_filename, "."); //取出.最后出现的位置 
    $extended = substr($C_filename, $lastdot+1); //取出扩展名 
    for($i=0;$i{ 
        //转换大小写并检测 
        if (trim(strtolower($extended)) == trim(strtolower($A_extend[$i]))) { 
            $flag=1; //加成功标志 
            $i=count($A_extend); //检测到了便停止检测 
        } 
    } 
    if($flag<>1) { 
        for($j=0;$j{ 
            $alarm .= $A_extend[$j]." "; 
        } 
        AlertExit('只能上传'.$alarm.'文件!而你上传的是'.$extended.'类型的文件'); 
        return -1; //返回-1表示上传图片的类型不符 
    } 
    return 1; //返回1表示图片的类型符合要求 
} 
//----------------------------------------------------------------------------------- 
// 函数名:CheckImageSize($ImageFileName,$LimitSize) 
// 作 用:检验上传图片的大小 
// 参 数:$ImageFileName 上传的图片名 
// $LimitSize 要求的尺寸 
// 返回值:布尔值 
// 备 注:无 
//----------------------------------------------------------------------------------- 
function CheckImageSize($ImageFileName,$LimitSize) { 
    $size=GetImageSize($ImageFileName); 
    if ($size[0]>$LimitSize[0] ││ $size[1]>$LimitSize[1]) { 
        AlertExit('图片尺寸过大'); 
        return false; 
    } 
    return true; 
} 
//----------------------------------------------------------------------------------- 
// 函数名:Alert($C_alert,$I_goback=0) 
// 作 用:非法操作警告 
// 参 数:$C_alert(提示的错误信息) 
// $I_goback(返回到那一页) 
// 返回值:字符串 
// 备 注:无 
//----------------------------------------------------------------------------------- 
function Alert($C_alert,$I_goback=0) { 
    if($I_goback<>0) { 
        echo " "; 
    } else { 
        echo " "; 
    } 
} 

// 函数名:AlertExit($C_alert,$I_goback=0) 
// 作 用:非法操作警告 
// 参 数:$C_alert(提示的错误信息) 
// $I_goback(返回到那一页) 
// 返回值:字符串 
// 备 注:无 
//----------------------------------------------------------------------------------- 
function AlertExit($C_alert,$I_goback=0) { 
    if($I_goback<>0) { 
        echo " "; 
        exit; 
    } else { 
        echo " "; 
        exit; 
    } 
} 
//----------------------------------------------------------------------------------- 
// 函数名:ReplaceSpacialChar($C_char) 
// 作 用:特殊字符替换函数 
// 参 数:$C_char(待替换的字符串) 
// 返回值:字符串 
// 备 注:这个函数有问题,需要测试才能使用 
//----------------------------------------------------------------------------------- 
function ReplaceSpecialChar($C_char) { 
    $C_char=HTMLSpecialChars($C_char); //将特殊字元转成 HTML 格式。 
    $C_char=nl2br($C_char); //将回车替换为 
    $C_char=str_replace(" "," ",$C_char); //替换空格为 
    return $C_char; 
} 
//----------------------------------------------------------------------------------- 
// 函数名:ExchangeMoney($N_money) 
// 作 用:资金转换函数 
// 参 数:$N_money(待转换的金额数字) 
// 返回值:字符串 
// 备 注:本函数示例:$char=ExchangeMoney(5645132.3155) ==> $char='¥5,645,132.31' 
//----------------------------------------------------------------------------------- 
function ExchangeMoney($N_money) { 
    $A_tmp=explode(".",$N_money ); //将数字按小数点分成两部分,并存入数组$A_tmp 
    $I_len=strlen($A_tmp[0]); //测出小数点前面位数的宽度 
    if($I_len%3==0) { 
        $I_step=$I_len/3; //如前面位数的宽度mod 3 = 0 ,可按,分成$I_step 部分 
    } else { 
        $step=($len-$len%3)/3+1; //如前面位数的宽度mod 3 != 0 ,可按,分成$I_step 部分+1 
    } 
    $C_cur=""; 
    //对小数点以前的金额数字进行转换 
    while($I_len<>0) { 
        $I_step--; 
        if($I_step==0) { 
            $C_cur .= substr($A_tmp[0],0,$I_len-($I_step)*3); 
        } else { 
            $C_cur .= substr($A_tmp[0],0,$I_len-($I_step)*3).","; 
        } 
        $A_tmp[0]=substr($A_tmp[0],$I_len-($I_step)*3); 
        $I_len=strlen($A_tmp[0]); 
    } 
    //对小数点后面的金额的进行转换 
    if($A_tmp[1]=="") { 
        $C_cur .= ".00"; 
    } else { 
        $I_len=strlen($A_tmp[1]); 
        if($I_len<2) { 
            $C_cur .= ".".$A_tmp[1]."0"; 
        } else { 
            $C_cur .= ".".substr($A_tmp[1],0,2); 
        } 
    } 
    //加上人民币符号并传出 
    $C_cur="¥".$C_cur; 
    return $C_cur; 
} 

//----------------------------------------------------------------------------------- 
// 函数名:WindowLocation($C_url,$C_get="",$C_getOther="") 
// 作 用:PHP中的window.location函数 
// 参 数:$C_url 转向窗口的URL 
// $C_get GET方法参数 
// $C_getOther GET方法的其他参数 
// 返回值: 字符串 
// 备 注:无 
//----------------------------------------------------------------------------------- 
function WindowLocation($C_url,$C_get="",$C_getOther="") { 
    if($C_get == "" && $C_getOther == "") 
    if($C_get == "" && $C_getOther <> "") {
        $C_target=""window.location='$C_url?$C_getOther='+this.value"";
    } 
    if($C_get <> "" && $C_getOther == "") {
        $C_target=""window.location='$C_url?$C_get'"";
    } 
    if($C_get <> "" && $C_getOther <> "") {
        $C_target=""window.location='$C_url?$C_get&$C_getOther='+this.value"";
    } 
    return $C_target; 
}