php多维数组排序与操作函数
php教程多维数组排序与操作函数
function arraycd($arr){
static $res_arr=array();
if(is_array($arr))
{
foreach($arr as $key=>$val)
{
if(is_array($val))
{
arraycd($val);
}else{
$res_arr[]=$val;
}
}
}elseif(is_string($arr))
{
$res_arr[]=$arr;
}
return implode(",",$res_arr);
}
$fruits = array (
"fruits" => array("a" => "orange", "b" => "banana", "c" => "apple"),
"numbers" => array(1, 2, 3, 4, 5, 6),
"holes" => array("first", 5 => "second", "third")
);
$strayy=arraycd($fruits);
var_dump($strayy);
看一个多维数组排序
<?php
function sortdata($data, $col, $order){
if (count($data)) $temp_array[key($data)] = array_shift($data);
foreach($data as $key => $val){
$offset = 0;
$found = false;
foreach($temp_array as $tmp_key => $tmp_val){
if(!$found and strtolower($val[$col]) >
strtolower($tmp_val[$col])){
$temp_array = array_merge((array)
array_slice($temp_array,0,$offset),
array($key => $val),
array_slice($temp_array,$offset)
);
$found = true;
}
$offset++;
}
if(!$found) {
$temp_array = array_merge($temp_array, array
($key => $val));
}
}
if (strtolower($order)=="asc"){
$array = array_reverse($temp_array);
} else {
$array = $temp_array;
}
return $array;
}
主函数
$data=array(
array(
'name'=>'alice',
'key'=>'2fc4ab3d639e5400efdfc73bc27e83f1',
'age'=>20
),
array(
'name'=>'claudia',
'key'=>'831c2b79c1f19af39c7e3321e11e5f5e',
'age'=>18
),
array(
'name'=>'beatrice',
'key'=>'6f8512a2066b8f35a27a495ce1228c76',
'age'=>100
),
array(
'name'=>'denise',
'age'=>25,
'key'=>'ef6de3b178bf9f69a9fef72e4ee7bbe9'
)
);
$arr1 = sortdata($data, "name","asc");
echo "<pre>";
var_dump($arr1);
echo "</pre>";
$arr2 = sortdata($data, "age","desc");
echo "<pre>";
var_dump($arr2);
echo "</pre>";
php教程 curl_setopt与模拟用户登录
bool curl_setopt (int ch, string option, mixed value)
curl_setopt()函数将为一个curl会话设置选项。option参数是你想要的设置,
value是这个选项给定的值。
//该例子为模拟登录
$cookie_file = tempnam('./temp','cookie');//保存临时cookie
$login_url = 'http://xxx/login.php';//登录页提交地址
$post_fields = 'username=&password=';//传值参数
$ch = curl_init($login_url);
curl_setopt($ch, curlopt_header, 0);
curl_setopt($ch, curlopt_returntransfer, 1);
curl_setopt($ch, curlopt_post, 1);
curl_setopt($ch, curlopt_postfields, $post_fields);
curl_setopt($ch, curlopt_cookiejar, $cookie_file);
curl_exec($ch);
curl_close($ch);
下列选项的值将被作为长整形使用(在option参数中指定):
curlopt_infilesize: 当你上传一个文件到远程站点,这个选项告诉php你上传文
件的大小。
curlopt_verbose: 如果你想curl报告每一件意外的事情,设置这个选项为一个非
零值。
curlopt_header: 如果你想把一个头包含在输出中,设置这个选项为一个非零值。
curlopt_noprogress: 如果你不会php为curl传输显示一个进程条,设置这个选项
为一个非零值。
注意:php自动设置这个选项为非零值,你应该仅仅为了调试的目的来改变这个选
项。
curlopt_nobody: 如果你不想在输出中包含body部分,设置这个选项为一个非零值
。
curlopt_failonerror: 如果你想让php在发生错误(http代码返回大于等于300)时
,不显示,设置这个选项为一人非零值。默认行为是返回一个正常页,忽略代码。
curlopt_upload: 如果你想让php为上传做准备,设置这个选项为一个非零值。
curlopt_post: 如果你想php去做一个正规的http post,设置这个选项为一个非零
值。这个post是普通的 application/x-www-from-urlencoded 类型,多数被html
表单使用。
curlopt_ftplistonly: 设置这个选项为非零值,php将列出ftp的目录名列表。
curlopt_ftpappend: 设置这个选项为一个非零值,php将应用远程文件代替覆盖它
。
curlopt_netrc: 设置这个选项为一个非零值,php将在你的 ~./netrc 文件中查找
你要建立连接的远程站点的用户名及密码。
curlopt_followlocation: 设置这个选项为一个非零值(象 'location: ')的头,
服务器会把它当做http头的一部分发送(注意这是递归的,php将发送形如
'location: '的头)。
curlopt_put: 设置这个选项为一个非零值去用http上传一个文件。要上传这个文
件必须设置curlopt_infile和curlopt_infilesize选项.
curlopt_mute: 设置这个选项为一个非零值,php对于curl函数将完全沉默。
curlopt_timeout: 设置一个长整形数,作为最大延续多少秒。
curlopt_low_speed_limit: 设置一个长整形数,控制传送多少字节。
curlopt_low_speed_time: 设置一个长整形数,控制多少秒传送
curlopt_low_speed_limit规定的字节数。
curlopt_resume_from: 传递一个包含字节偏移地址的长整形参数,(你想转移到的
开始表单)。
curlopt_sslversion: 传递一个包含ssl版本的长参数。默认php将被它自己努力的
确定,在更多的安全中你必须手工设置。
curlopt_timecondition: 传递一个长参数,指定怎么处理curlopt_timevalue参数
。你可以设置这个参数为timecond_ifmodsince 或 timecond_isunmodsince。这仅
用于http。
curlopt_timevalue: 传递一个从1970-1-1开始到现在的秒数。这个时间将被
curlopt_timevalue选项作为指定值使用,或被默认timecond_ifmodsince使用。
下列选项的值将被作为字符串:
curlopt_url: 这是你想用php取回的url地址。你也可以在用curl_init()函数初始
化时设置这个选项。
curlopt_userpwd: 传递一个形如[username]:[password]风格的字符串,作用php去
连接。
curlopt_proxyuserpwd: 传递一个形如[username]:[password] 格式的字符串去连
接http代理。
curlopt_range: 传递一个你想指定的范围。它应该是'x-y'格式,x或y是被除外的
。http传送同样支持几个间隔,用逗句来分隔(x-y,n-m)。
curlopt_postfields: 传递一个作为http “post”操作的所有数据的字符串。
curlopt_referer: 在http请求中包含一个'referer'头的字符串。
curlopt_useragent: 在http请求中包含一个'user-agent'头的字符串。
curlopt_ftpport: 传递一个包含被ftp 'post'指令使用的ip地址。这个post指令
告诉远程服务器去连接我们指定的ip地址。 这个字符串可以是一个ip地址,一个
主机名,一个网络界面名(在unix下),或是‘-’(使用系统默认ip地址)。
curlopt_cookie: 传递一个包含http cookie的头连接。
curlopt_sslcert: 传递一个包含pem格式证书的字符串。
curlopt_sslcertpasswd: 传递一个包含使用curlopt_sslcert证书必需的密码。
curlopt_cookiefile: 传递一个包含cookie数据的文件的名字的字符串。这个
cookie文件可以是netscape格式,或是堆存在文件中的http风格的头。
curlopt_customrequest: 当进行http请求时,传递一个字符被get或head使用。为
进行delete或其它操作是有益的,更pass a string to be used instead of get
or head when doing an http request. this is useful for doing or another,
more obscure, http request.
注意: 在确认你的服务器支持命令先不要去这样做。
下列的选项要求一个文件描述(通过使用fopen()函数获得):
curlopt_file: 这个文件将是你放置传送的输出文件,默认是stdout.
curlopt_infile: 这个文件是你传送过来的输入文件。
curlopt_writeheader: 这个文件写有你输出的头部分。
curlopt_stderr: 这个文件写有错误而不是stderr。
<?php
function curl_redir_exec($ch,$debug="")
{
static $curl_loops教程 = 0;
static $curl_max_loops = 20;
if ($curl_loops++ >= $curl_max_loops)
{
$curl_loops = 0;
return false;
}
curl_setopt($ch, curlopt_header, true);
curl_setopt($ch, curlopt_returntransfer, true);
$data = curl_exec($ch);
$debbbb = $data;
list($header, $data) = explode("nn", $data, 2);
$http_code = curl_getinfo($ch, curlinfo_http_code);
if ($http_code == 301 || $http_code == 302) {
$matches = array();
preg_match('/location:(.*?)n/', $header, $matches);
$url = @parse_url(trim(array_pop($matches)));
//print_r($url);
if (!$url)
{
//couldn't process the url to redirect to
$curl_loops = 0;
return $data;
}
$last_url = parse_url(curl_getinfo($ch,
curlinfo_effective_url));
/* if (!$url['scheme'])
$url['scheme'] = $last_url['scheme'];
if (!$url['host'])
$url['host'] = $last_url['host'];
if (!$url['path'])
$url['path'] = $last_url['path'];*/
$new_url = $url['scheme'] . '://' . $url['host'] . $url['path']
. ($url['query']?'?'.$url['query']:'');
curl_setopt($ch, curlopt_url, $new_url);
// debug('redirecting to', $new_url);
return curl_redir_exec($ch);
} else {
$curl_loops=0;
return $debbbb;
}
}
?>
php教程实现记住密码自动登录方法不止一个,下面出现有二个emptyempty,其实是一个,那是因为代码高亮有bug。希望对大家有帮助。
一,用户登录的check
代码如下:
//检查用户是否登录
function checklogin(){
if(emptyempty($_session['user_info'])){ //检查一下session是不是为空
if(emptyempty($_cookie['username']) || emptyempty($_cookie['password'])){ //如果session为空,并且用户没有选择记录登录状
header(”location:login.php?req_url=”.$_server['request_uri']); //转到登录页面,记录请求的url,登录后跳转过去,用户体验好。
}else{ //用户选择了记住登录状态
$user = getuserinfo($_cookie['username'],$_cookie['password']); //去取用户的个人资料
if(emptyempty($user)){ //用户名密码不对没到取到信息,转到登录页面
header(”location:login.php?req_url=”.$_server['request_uri']);
}else{
$_session['user_info'] = $user; //用户名和密码对了,把用户的个人资料放到session里面
}
}
}
}
//检查用户是否登录
function checklogin(){
if(empty($_session['user_info'])){ //检查一下session是不是为空
if(empty($_cookie['username']) || empty($_cookie['password'])){ //如果session为空,并且用户没有选择记录登录状
header(”location:login.php?req_url=”.$_server['request_uri']); //转到登录页面,记录请求的url,登录后跳转过去,用户体验好。
}else{ //用户选择了记住登录状态
$user = getuserinfo($_cookie['username'],$_cookie['password']); //去取用户的个人资料
if(empty($user)){ //用户名密码不对没到取到信息,转到登录页面
header(”location:login.php?req_url=”.$_server['request_uri']);
}else{
$_session['user_info'] = $user; //用户名和密码对了,把用户的个人资料放到session里面
}
}
}
}
在访问后台的每个页面时,都要先进行上面的检查
二,用户提交登录信息
当用户填写用户名和密码后就提交到这儿来,
代码如下:
$username = trim($_post['username']);
$password = md5(trim($_post['password']));
$validatecode = $_post['validatecode'];
$ref_url = $_get['req_url'];
$remember = $_post['remember'];$err_msg = ”;
if($validatecode!=$_session['checksum']){
$err_msg = “验证码不正确”;
}elseif($username==” || $password==”){
$err_msg = “用户名和密码都不能为空”;
}else{
$row = getuserinfo($username,$password);if(emptyempty($row)){
$err_msg = “用户名和密码都不正确”;
}else{
$_session['user_info'] = $row;
if(!emptyempty($remember)){ //如果用户选择了,记录登录状态就把用户名和加了密的密码放到cookie里面
setcookie(”username”, $username, time()+3600*24*365);
setcookie(”password”, $password, time()+3600*24*365);
}
if(strpos($ref_url,”login.php”) === false){
header(”location:”.$ref_url);
}else{
header(”location:main_user.php”);
}
}
}
$username = trim($_post['username']);
$password = md5(trim($_post['password']));
$validatecode = $_post['validatecode'];
$ref_url = $_get['req_url'];
$remember = $_post['remember'];$err_msg = ”;
if($validatecode!=$_session['checksum']){
$err_msg = “验证码不正确”;
}elseif($username==” || $password==”){
$err_msg = “用户名和密码都不能为空”;
}else{
$row = getuserinfo($username,$password);if(empty($row)){
$err_msg = “用户名和密码都不正确”;
}else{
$_session['user_info'] = $row;
if(!empty($remember)){ //如果用户选择了,记录登录状态就把用户名和加了密的密码放到cookie里面
setcookie(”username”, $username, time()+3600*24*365);
setcookie(”password”, $password, time()+3600*24*365);
}
if(strpos($ref_url,”login.php”) === false){
header(”location:”.$ref_url);
}else{
header(”location:main_user.php”);
}
}
}
关于$ref_url简单解释一下,假如:用户a访问b.php,但是a用户没有登录,跳转到登录页面login.php,在登录页面填完用户和密码后,确定后又跳转到b.php这个页面,而不是跳转一个默认的页面main_user.php。因为b.php是用户a想去的那个页面,所以用户体验会好一点。
三,当用户点退出时,清出记录登录状态
为什么要这样做呢,因为如果有别人用你的电脑的话,他们有可能会浏览到你的个人隐私,所以当用户特意点了退出时,最好是把记录登录状态取消掉。
复制代码 代码如下:
//退出登录
function logout(){
unset($_session['user_info']);
if(!emptyempty($_cookie['username']) || emptyempty($_cookie['password'])){
setcookie(”username”, null, time()-3600*24*365);
setcookie(”password”, null, time()-3600*24*365);
}
}
第一行代码是强制下载;
第二行代码是给下载的内容指定一个名字;
第三行代码是把下载的内容读进文件中。
提示用户保存一个生成的 pdf 文件(content-disposition 报头用于提供一个推荐的文件名,并强制浏览器显示保存对话框):
<?php教程2 header("content-type: application/force-download");
3 header("content-disposition: attachment; filename=ins.jpg");
4 readfile("imgs/test_zoom.jpg");
5 ?>
header() 函数向客户端发送原始的 http 报头。
认识到一点很重要,即必须在任何实际的输出被发送之前调用 header() 函数(在 php 4 以及更高的版本中,您可以使用输出缓存来解决此问题):
header(string,replace,http_response_code)
其它用法
<?php
// date in the past
header("expires: mon, 26 jul 1997 05:00:00 gmt");
header("cache-control: no-cache");
header("pragma: no-cache");
?>
asp教程/asp.net教程/php教程实现301重定向代码,一般我们做301是全用iis,apache来实现,在没有操作服务器的时我们再用脚本来实现,代码如下。
1、asp下的301重定向代码
<%@ language=vbscript %>
<%
response.status=”301 moved permanently”
response.addheader “location”, “106/”
%>
2、asp.net下的301重定向代码
<script runat=”server”>
private void page_load(object sender, system.eventargs e)
{
response.status = “301 moved permanently”;
response.addheader(”location”,” 106/“);
}
</script>
3、php下的301重定向代码
header(”http/1.1 301 moved permanently”);
header(”location: 106/”);
exit();
相关文章
- 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
- 下面一段代码给大家介绍php curl模拟post请求的示例代码,具体代码如下: <?php$uri = "http://www.cnblogs.com/test.php";//这里换成自己的服务器的地址// 参数数组$data = array ( 'name' => 'tanteng'// 'passwor...2015-11-24
- 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
- free函数是释放之前某一次malloc函数申请的空间,而且只是释放空间,并不改变指针的值。下面我们就来详细探讨下...2020-04-25
- PHP 函数 strip_tags 提供了从字符串中去除 HTML 和 PHP 标记的功能,该函数尝试返回给定的字符串 str 去除空字符、HTML 和 PHP 标记后的结果。由于 strip_tags() 无法实际验证 HTML,不完整或者破损标签将导致更多的数...2014-05-31
- 分享一个PHP加密解密的函数,此函数实现了对部分变量值的加密的功能。 加密代码如下: /* *功能:对字符串进行加密处理 *参数一:需要加密的内容 *参数二:密钥 */ function passport_encrypt($str,$key){ //加密函数 srand(...2015-10-30
SQL Server中row_number函数的常见用法示例详解
这篇文章主要给大家介绍了关于SQL Server中row_number函数的常见用法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2020-12-08php的mail函数发送UTF-8编码中文邮件时标题乱码的解决办法
最近遇到一个问题,就是在使用php的mail函数发送utf-8编码的中文邮件时标题出现乱码现象,而邮件正文却是正确的。最初以为是页面编码的问题,发现页面编码utf-8没有问题啊,找了半天原因,最后找到了问题所在。 1.使用 PEAR 的...2015-10-21- 下面小编就为大家带来一篇C#中加载dll并调用其函数的实现方法。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧...2020-06-25
- 这篇文章主要介绍了C#虚函数用法,实例分析了C#中虚函数的功能与基本使用技巧,需要的朋友可以参考下...2020-06-25