过滤json中下划线字段名为驼峰式

作者:matrix 发布时间:2018年3月31日 分类:零零星星

项目中有需要将统一的json接口数据转换为驼峰式字段名,但是网上的确没找到能解决的代码。
还好难度不大,直接正则替换就好。代码都是去年写的了,一直放在有道云笔记里面,早就想拉出来分享下,趁着还是3月份 补一片文章来占位。
代码是php的,其他语言同理用正则替换解决。

 /**
     * json编码处理 传入数组
     * json字段名统一输出为驼峰式
     * @param $data
     * @return array
     */
    protected function json_encode($data)
    {
        $data =  json_encode($data);
        return preg_replace_callback('/[_]([a-zA-Z])(?=[^"]*?":)/',
            function ($matches) {
                return strtoupper($matches[1]) ;
            }, $data);
    }

说明:
代码不需要过多解释,传入数组数据 结果值会返回json字符,字段名推统一替换为驼峰式。
核心在于[_]([a-zA-Z])(?=[^"]*?":)的正则表达式
PEACE~

php的file_get_contents函数访问URL显示响应头

作者:matrix 发布时间:2014年10月1日 分类:零零星星

在用 file_get_contents 访问 http 时,stream wrapper 会把响应头放到当前作用域下的 $http_response_header 数组变量里。

所以说变量$http_response_header就保存了需要的响应头,输出这个变量也就能拿到响应头。

file_get_contents('http://www.hhtjim.com/');
print_r($http_response_header);//输出响应头内容

参考:
http://www.jbxue.com/article/16319.html

PS: 阅读剩余部分 »

get_headers函数模拟版

作者:matrix 发布时间:2014年9月27日 分类:零零星星

在sae上发现禁用了get_headers函数,只有另想办法,遂找到php 模拟get_headers函数代码,不过他的这个没有实现302跳转链接的跟踪。

这里自己的代码可以更高度模拟get_headers函数,利用php的curl功能

/*
模拟php的get_headers()函数;
在sae中需要关闭CURLOPT_FOLLOWLOCATION参数,否则不会有Location;缺点是没法跟踪跳转的链接
略有不同:Content-Length: 0 不会显示;一般的处理时没有问题的
*/
function getHeaders($url,$format=0,$FOLLOWLOCATION=1){
    $curl = curl_init($url);
    curl_setopt($curl, CURLOPT_HEADER, 1);
    curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);
    curl_setopt($curl, CURLOPT_TIMEOUT, 10);
    curl_setopt($curl, CURLOPT_NOBODY, 1);//不包含网页的内容
    if($FOLLOWLOCATION){
    curl_setopt($curl, CURLOPT_FOLLOWLOCATION, 1);//允许链接自动跳转,当系统开启safe_mode或open_basedir,会出错,该关闭
    }
    curl_setopt($curl, CURLOPT_AUTOREFERER, 1);//自动referer
    //curl_setopt($curl, CURLOPT_MAXREDIRS, 1);//限定CURLOPT_FOLLOWLOCATION递归返回的数量        
    $header = curl_exec($curl);
    curl_close($curl);
    $back =  array_filter(explode(PHP_EOL,$header));
    //return array_filter(explode(PHP_EOL,$header));
    if($format){
        foreach($back as $val)
        {
            if(preg_match('/^([^:]+): +(.*)$/',$val,$parts))
            {
                if (array_key_exists($parts[1],$v)){
                    $v[$parts[1]] = array_merge_recursive((array)$v[$parts[1]],(array)$parts[2]);
                }
                else
                {
                    $v[$parts[1]]=$parts[2];
                }
            }
            else{
                if(isset($v[0])){
                    $v[]=$val;
                }
                else{
                    $v[0]=$val;
                }
            }
        }
        return $v;
    }
    return $back;
}

说明:
getHeaders()函数的前两个参数和get_headers函数一样;
第三个参数:我在本地测试是没有问题的,只是在sae上测试不同,原因是sae的cul不支持CURLOPT_FOLLOWLOCATION参数,还有很多限制。这就添加个是否开启CURLOPT_FOLLOWLOCATION功能(自动跟踪跳转的链接);
本地测试基本上与get_headers函数相同输出,不影响响应头的获取。

参考:

http://www.phpernote.com/php-function/748.html

http://bbs.php100.com/read-htm-tid-148513.html

Python版PHP内置的MD5()函数

作者:matrix 发布时间:2014年9月1日 分类:Python

初玩Python很不习惯那个md5函数。还好有人分享了相关代码,非常感谢。

import hashlib
def md5 (s, raw_output = False):
    res = hashlib.md5 (s)
    if raw_output:
        return res.digest ()
    return res.hexdigest ()

如果是Python2.5 :

# Python 2.5+
import hashlib
hashlib.md5("welcome").hexdigest()
# pre-2.5, removed in Python 3
import md5
md5.md5("welcome").hexdigest()

参考:Python 实现PHP内置MD5函数方法

PHP的基本规则

作者:matrix 发布时间:2014年4月23日 分类:兼容并蓄 零零星星

PHP的基本规则

下面内容来自 php开发实战宝典 附录A: php编码规则

A.1  PHP File文件格式

A.1.1  常规

对于只包含PHP代码的文件,结束标志("?>")是不允许存在的,否则会导致文件末尾被意外地注入空白并显示输出。

由__HALT_COMPILER()允许的任意的二进制代码的内容被Zend Framework PHP文件或由它们产生的文件禁止。这个功能只对特殊的安装脚本开放。

A.1.2  缩进

使用4个空格的缩进,而不使用制表符TAB。
阅读剩余部分 »

php函数笔记

作者:matrix 发布时间:2013年11月3日 分类:零零星星

图片4788-php函数笔记

TIME: 20190120 工作几年回过头来发现最近真理这篇post都是17年4月份了。看来工作之后真是进步或许没时间亦或变懒,不为简单函数做笔记。
大多都外链工具所用到的,整理整理,以便后用。

file_get_contents(函数把整个文件读入一个字符串中。

 htmlspecialchars() 函数将字符转换为 HTML 实体。

isset($ab)判断$ab是否存在

error_reporting(0);//禁用错误报告

使用@符号也可以

explode("/",$str)把字符串以/分割为数组

preg_match_all ()用正则匹配字符串并保存到数组中

preg_match_all ("/share_uk=(.*?)share/",$ukidConnect,$ukidList, PREG_PATTERN_ORDER);

//使用preg_match_all正则匹配数据并保存到$titleList数组中

$ukidList[0][1]表示第1数组【第一个括弧的值,如.*?】匹配到的字符串

如果preg_match_all换成preg_match,$ukidList[1]也表示第1数组【第一个括弧的值,如.*?】匹配到的字符串

废弃的eregi函数同理,传说使用preg函数更高效

strstr() 函数搜索一个字符串在另一个字符串中的第一次出现。

strpos() 返回字符串在另一个字符串中第一次出现的位置。

strpos 区别大小写strpos查找成功后则是返回的是位置。因为位置有可能是0,所以判断查找失败使用===false更合适。

substr_count()函数计算子串在字符串中出现的次数。

strlen() 函数返回字符串的长度。

 substr() 取固定长度的字符串

$zhuaqian=strpos($titleList[0][0],"title>");
$zhuahou=strpos($titleList[0][0],"_免费高速下载|百度云 网盘-分享无限制");
$xinzhi=substr($titleList[0][0],6,$zhuahou-6); //取适当的两个位置中间的值也就是文件名

$_SERVER["REQUEST_URI"];  php自带的函数

取得当前url的页面url。

http://127.0.0.1/xxx.php?st=http://hhtjim.com

返回:/xxx.php?st=http://hhtjim.com

$NOWstr =  'http://' .$_SERVER['HTTP_HOST'].$_SERVER["REQUEST_URI"];//由于$_GET['url']取url不完整
$NEWstr=explode('?url=',$NOWstr);
$quurl = $NEWstr[1];

curl()函数

作用大大的有。

示例代码:


function curl_get($url,$post=false,$carry_ua=true){ $ch=curl_init($url); if($carry_ua){ curl_setopt($ch, CURLOPT_HTTPHEADER, array('User-Agent:Mozilla/5.0 (iPhone; U; CPU iPhone OS 3_1_2 like Mac OS X; en-us) AppleWebKit/528.18 (KHTML, like Gecko) Version/4.0 Mobile/7D11 Safari/528.16')); } if ($post) { curl_setopt($ch, CURLOPT_POSTFIELDS, $post); } curl_setopt($ch, CURLOPT_RETURNTRANSFER, true); $get_url = curl_exec($ch); curl_close($ch); return $get_url; }

不懂,再保留另外的

$curlPost=’http://songtaste.com/time.php’; 
$ch = curl_init();//初始化curl    
curl_setopt($ch,CURLOPT_URL, $url);//提交到指定网页    
curl_setopt($ch, CURLOPT_HEADER, 0);//设置header    
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);//要求结果为字符串且输出到屏幕上    
curl_setopt($ch, CURLOPT_POST, 1);//post提交方式    
curl_setopt($ch, CURLOPT_POSTFIELDS, $curlPost);
$data = curl_exec($ch);//运行curl    
curl_close($ch);
print_r($data);//输出结果  

模拟POST提交数据

 $post_data = array('nid' => '13714766852756201', 'shorturl' => 'QeEWZNzPansuQ');
$url='http://ajy8hpcasy.l17.yunpan.cn/share/downloadfile/';
$_REFERER='http://ajy8hpcasy.l17.yunpan.cn/lk/QeEWZNzPansuQ';
$ch = curl_init();
curl_setopt($ch, CURLOPT_POST, 1);
curl_setopt($ch, CURLOPT_URL,$url);
curl_setopt($ch, CURLOPT_POSTFIELDS, $post_data);
curl_setopt($ch, CURLOPT_REFERER,$_REFERER);
ob_start();
curl_exec($ch);
$result = ob_get_contents() ;
ob_end_clean(); 
echo $result;

set_time_limit(0);//为0时:允许脚本运行的时间无上限。不设置此函数的话默认为30s

str_replace()使用一个字符串替换字符串中的另一些字符。

header()向客户端浏览器发送 HTTP 。

header("location: http://hhtjim.com");//跳转到http://hhtjim.com

list()  函数用数组中的元素为一组变量赋值。实际上是一种语言结构,不是函数。

array_slice() 函数在数组中根据条件取出一段值,并返回。

list($shareid, $uk) = array_slice($res, 1, 2);

//数组中有shareid, uk元素,让元素名最为变量名字。

//$res为总的数组,1为规定取出元素的开始位置。2为需要返回的数组数量。

define() 函数定义一个常量

define("GREETING","Hello world!");

//常量名为GREETING,值为"Hello world!

php中?(问号)和:(冒号)的作用:精简的if语句

条件表达式e1?e2:e3,若e1为真(非0),则此表达式的值为e2的值;若为假,则表达式的值为e3

例如:

preg_match('|Location: (.+)\r|', $src, $res);
$songurl = $res ? $res[1] : exit(" error!");

implode() 函数把数组元素组合为一个字符串。

json_decode()函数:接受一个 JSON 格式的字符串并且把它转换为 PHP 变量

示例:

$rt='{"errno":0,"errmsg":"\u64cd\u4f5c\u6210\u529f","data":{"downloadurl":"http:\/\/wsdl25.yunpan.cn\/share.php?method=Share.download&fhash=119f736a936d62396d7dd71ff8fb7d187d69d3d9&xqid=23620387&fname=%E8%AF%B4%E6%98%8E.doc&fsize=211968&nid=13754589643979953&cqid=157ddad976b9aa811591ed43134891f7&st=48ea3770079bce5360f952cff1dc9d29&e=1382784599&dt=25.1291649b2f9ed61380291c5c0d711ca9","params":[]}}';
$obj = json_decode($rt);
$dll=$obj->data->downloadurl;
echo $dll;

结果显示:http://wsdl25.yunpan.cn/share.php?method=Share.download&fhash=119f736a936d62396d7dd71ff8fb7d187d69d3d9&xqid=23620387&fname=%E8%AF%B4%E6%98%8E.doc&fsize=211968&nid=13754589643979953&cqid=157ddad976b9aa811591ed43134891f7&st=48ea3770079bce5360f952cff1dc9d29&e=1382784599&dt=25.1291649b2f9ed61380291c5c0d711ca9

示例二:

json数据:

{
"songs": [{
"score": 100,
"copyrightId": 0,
"mvid": 0,
"mp3Url": "http://m1.music.126.net/fG44YGce-id8VZ9LjQIPpQ==/1069824813834035.mp3"
}],
"code": 200
}

php处理:

$eo='上面的json数据';
$obj=json_decode($eo,true);
echo $obj['songs'][0]['mp3Url'];

结果返回:
h t t p : / /m1.music.126.net/fG44YGce-id8VZ9LjQIPpQ==/1069824813834035.mp3

get_headers()函数获取服务器响应 HTTP 请求所发送的所有标头

parse_str() 函数把URL参数解析到到变量中。

 array_unique() 函数移除数组中的重复的值

$b = &$a; //变量前&  表示$b 和 $a 引用了同一个变量

parse_url()解析 URL并返回组成部分为数组内容

strip_tags() 去除 HTML、XML 以及 PHP 的标签。

extract() 函数 把数组中的键名设置为变量,其键值为变量的值。

对于数组中的每个元素,键名用于变量名,键值用于变量值。

substr_replace() 函数把字符串的一部分替换为另一个字符串。

substr_replace($P,$v,9,1);//(替换第10位的数字为$p)

<<<  运算符,将由自定义分界符间的内容视为字符串,可对其间的变量做处理

echo <<<tem
<script>alert("输入的留言内容太长!");history.go(-1);</script>
tem;

tem是任意字符,<<<后的tem标记着开始。必须以 tem; 结尾,另起一行顶格(前面无空格)书写,否则会报错。

echo <<<'tem'
$a str
tem;

添加单引号 就不会解析里面的变量

base_convert() 函数在任意进制之间转换数字。

is_numeric()函数检测变量是否为数字或数字字符串

urlencode()返回字符串,此字符串中除了 -_. 之外的所有非字母数字字符都将被替换成百分号(%)后跟两位十六进制数.

rawurlencode()功能和urlencode基本一样,采用的是RFC1738编码,因此空格会编码为%20

sprintf() 函数把格式化的字符串写入一个变量中。

in_array()函数在数组中搜索给定的值。

array_search()函数在数组中查找一个键值。如果找到了该值,匹配元素的键名会被返回。

array_key_exists() 函数判断某个数组中是否存在指定的键名

md5(arg[,arg])

函数计算字符串的 MD5 散列,第二的参数规定十六进制或二进制输出格式。

PHP_EOL表示换行符

str_split() 函数把字符串逐字分割到数组中。

split()用正则表达式将字符串分割到数组中

preg_split()通过一个正则表达式分隔字符串

http_build_query()生成 URL-encode 之后的请求字符串

quotemeta() 函数在字符串中某些预定义的字符前添加反斜杠。

mt_rand(A,B) 函数返回A到B的随机整数

compact

创建一个包含变量名和它们的值的数组:

$firstname = "Bill";
$lastname = "Gates";
$age = "60";

$result = compact("firstname", "lastname", "age");

print_r($result);

extract() 正好相反
陆续添加整理。。。