PHP采集静态页面并把页面下载css,img,js保存

 更新时间:2016年11月25日 17:24  点击:1653
这是一个可以获取网页的html代码以及css,js,font和img资源的小工具,主要用来快速获取模板。如果你来不及设计UI或者看到不错的模板,则可以使用这个工具来抓取网页和提取资源文件。提取的内容会按相对路径来保存资源,因此你不必担心资源文件的错误url导入

首页 index.php:

 代码如下 复制代码

<!DOCTYPE html>
<html>
<head>
<meta name="author" content="flute" />
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>网页抓取器</title>
<link rel="stylesheet" href="main.css" media="all" />
<script type="text/javascript" src="jquery.js"></script>
<script type="text/javascript" src="main.js"></script>
</head>
<body>
<h1>Web Grabber</h1>
<hr />
<div class="box">
  <h2>Url</h2>
  <div class="form">
    <input type="text" id="project" value="projectname" />
    <input type="text" id="url" value="http://" size="60" />
    <button class="submit" type="button">Get</button><span id="tip"></span>
  </div> www.111cn.net
</div>
<div class="box">
  <span class="all" id="saveall">Save All</span>
  <h2>List</h2>
  <ul id="list">
  </ul>
</div>
</body>
</html>

抓取页面代码 grab.php:

 代码如下 复制代码

<?PHP
 /*
 * flute
 * 2014/03/31
 */

 if(isset($_POST['url'])) {
  if(isset($_POST['project']) && !is_dir($_POST['project'])) mkdir($_POST['project'], 0777);
  echo json_encode(grab($_POST['url']));
 }

 function grab($url) {
  //$url = 'http://ldixing-wordpress.stor.sinaapp.com/uploads/leaves/test.html';
  $data = array();
  $file = preg_replace('/^.*//', '', $url);

  if(($content = file_get_contents($url)) !== false) {

   if(isset($_POST['project'])) file_put_contents($_POST['project'].'/'.$file, $content);

   $pattern = '/<link.*?href=('|")(.*?.css)1.*?>/i';
   if(preg_match_all($pattern, $content, $matches)) {
    $data['css'] = $matches[2];
   }

   $pattern = '/<script.*?src=('|")(.*?.js)1.*?>/i';
   if(preg_match_all($pattern, $content, $matches)) {
    $data['js'] = $matches[2];
   }

   $pattern = '/<img.*?src=('|")(.*?)1.*?>/i';
   if(preg_match_all($pattern, $content, $matches)) {
    $data['img'] = $matches[2];
   }

   $pattern = '/url(('|"|s)(.*?)1)/i';
   if(preg_match_all($pattern, $content, $matches)) {
    $data['src'] = $matches[2];
   }
  }

  return $data;
 }

www.111cn.net

 function vardump($obj) {
  echo '<pre>';
  print_r($obj);
  echo '</pre>';
 }
?>

保存css,js,img等资源的页面 save.php:

 代码如下 复制代码

<?PHP
 /*
 *  flute
 *  2014/03/31
 */

 if(isset($_POST['url']) && isset($_POST['project']) && isset($_POST['domain'])) {
  extract($_POST);
  $url = preg_replace('/?.*$/', '', $url);
  $file = $url;
  $arr = explode('/', $file);
  $length = sizeof($arr);
  $filename = $arr[$length - 1];
  $root = $project;
  $dir = $root;

  if($domain == 'http') {
   $dir = $root.'/http';
   if(!is_dir($dir)) mkdir($dir, 0777);
  } else {
   $file = $domain.'/'.$url;
   for($i = 0; $i < $length -1; $i++) {
    if(!empty($arr[$i])) {
     $dir .= '/'.$arr[$i];
     if(!is_dir($dir)) mkdir($dir, 0777);
    }
   }
  }
  if(!file_exists($dir.'/'.$filename) || filesize($dir.'/'.$filename) == 0) {
   $content = file_get_contents($file);
   file_put_contents($dir.'/'.$filename, $content);
  }
 }
?>

使用方法:
1. 打开index页,输入项目名和要抓取的网址,网址必须是文件名结尾,如index.html;
2. 点Get按钮,得到当前页面所有的css,js,img等资源列表;
3. 点击css链接会获取css文件中的背景资源图片,附加在列表后头;
4. 点击Save All即可保存列表中所有的文件,并按相对路径生成;
5. 如果网页上有http远程文件,将会直接保存在http文件夹下;
6. Get和Save有时会失败,没关系重试几次即可。

最近,一个项目要求做交通银行在线支付,ecshop本身没有这方面的接口,于是通过一些时间的专研,做了一个插件出来。有好的东西,当然要分享,在此特地分享出来,希望能够帮助到跟我一样有需要的人,为大家减轻一下开发的负担,也多请大家指出一些好的方法和建议,相互的学习、进步!

在使用插件之前,请配置好交通银行在线支付的环境(具体安装方法,交行提供的demo会有,也不是很难,注意好细节就行)。安装好之后,请将includes文件夹和languages文件夹拷贝到ecshop站点的根目录覆盖(最下面有源码下载),最后进入后台的支付模块安装即可。


以下是调用的范例:

 代码如下 复制代码


include_once(ROOT_PATH . 'includes/modules/payment/bankcomm.php');

$order_['orderid'] = $order['order_sn'];

$order_['amount'] = $order['yd_price'];

$order_['orderMono'] = '测试'; //商家备注

$order_['goodsURL'] = "http://".$_SERVER['HTTP_HOST'].'/respond.php?code=bankcomm'; //取货URL

$pay_code = new bankcomm;

$pay_button = $pay_code->get_code($order_);

$order['pay_button'] = $pay_button; //即此时已经生成了一个支付按钮


源码(includes/modules/payment/bankcomm.php):

 

 代码如下 复制代码

<?php


/**

 * 交通银行在线支付插件 For Ecshop

 * Author: Reson

 * Date: 2014/03/31

 */


if (!defined('IN_ECS'))

{

die('Hacking attempt');

}


$payment_lang = ROOT_PATH . 'languages/' .$GLOBALS['_CFG']['lang']. '/payment/bankcomm.php';


if (file_exists($payment_lang))

{

global $_LANG;

include_once($payment_lang);

}


/* 模块的基本信息 */

if (isset($set_modules) && $set_modules == TRUE)

{

$i = isset($modules) ? count($modules) : 0;


/* 代码 */

$modules[$i]['code']    = basename(__FILE__, '.php');


/* 描述对应的语言项 */

$modules[$i]['desc']    = 'bankcomm_desc';


/* 是否支持货到付款 */

$modules[$i]['is_cod']  = '0';


/* 是否支持在线支付 */

$modules[$i]['is_online']  = '1';


/* 支付费用,由配送决定 */

$modules[$i]['pay_fee'] = '0';


/* 作者 */

$modules[$i]['author']  = 'Reson';


/* 网址 */

$modules[$i]['website'] = 'http://www.daixiaorui.com';


/* 版本号 */

$modules[$i]['version'] = '1.0.0.0';


/* 配置信息 */

$modules[$i]['config']  = array();

return;

}


/**

 * 类

 */

class bankcomm

{

/**

* 构造函数

*

* @return void

*/

function bankcomm()

{

}


function __construct()

{

$this->bankcomm();

}


/**

* 提交函数

*/

function get_code($order)

{

//获得表单传过来的数据

$param['interfaceVersion'] = '1.0.0.0'; //消息版本号*

$param['merID'] = '301310063009501'; //商户号 (测试号,后期可自行更改)

$param['orderid'] = $order['orderid']; //订单号*

$param['orderDate'] = local_date("Ymd",gmtime()); //商户订单日期* yyyyMMdd

$param['orderTime'] = local_date("His",gmtime()); //商户订单时间* HHmmss

$param['tranType'] = 0; //交易类别* 0:B2C

$param['amount'] = $order['amount']; //订单金额*

$param['curType'] = 'CNY'; //交易币种* 默认CNY

$param['orderContent'] = '';

$param['orderMono'] = $order['orderMono']; //商家备注

$param['phdFlag'] = ''; //物流配送标志

$param['notifyType'] = 1; //通知方式* 1 通知

$param['merURL'] = ''; 

$param['goodsURL'] = $order['goodsURL']; //取货URL

$param['jumpSeconds'] = '';

$param['payBatchNo'] = '';

$param['proxyMerName'] = '';

$param['proxyMerType'] = '';

$param['proxyMerCredentials'] = '';

$param['netType'] = 0; //渠道编号* 0:html渠道

$param['issBankNo'] = '';

$tranCode = "cb2200_sign";


htmlentities($param['orderMono'],"ENT_QUOTES","utf-8");

//连接字符串

$source = '';

foreach($param as $key=>$val){

if($key != 'issBankNo')

$source .= $val.'|';

}

$source = substr($source,0,strlen($source)-1);


//连接地址 www.111cn.net

$socketUrl = "tcp://127.0.0.1:8080"; //这里的端口根据自己配置的情况

$fp = stream_socket_client($socketUrl, $errno, $errstr, 30);

$retMsg="";

//

if (!$fp) {

echo "$errstr ($errno)<br /> ";

} else

{

$in  = "<?xml version='1.0' encoding='UTF-8'?>";

$in .= "<Message>";

$in .= "<TranCode>".$tranCode."</TranCode>";

$in .= "<MsgContent>".$source."</MsgContent>";

$in .= "</Message>";

fwrite($fp, $in);

while (!feof($fp)) {

$retMsg =$retMsg.fgets($fp, 1024); 

}

fclose($fp);

//解析返回xml

$dom = new DOMDocument;

$dom->loadXML($retMsg);

$retCode = $dom->getElementsByTagName('retCode');

$retCode_value = $retCode->item(0)->nodeValue;

$errMsg = $dom->getElementsByTagName('errMsg');

$errMsg_value = $errMsg->item(0)->nodeValue;

$signMsg = $dom->getElementsByTagName('signMsg');

$signMsg_value = $signMsg->item(0)->nodeValue;

$orderUrl = $dom->getElementsByTagName('orderUrl');

$orderUrl_value = $orderUrl->item(0)->nodeValue;

$MerchID = $dom->getElementsByTagName('MerchID');

$merID = $MerchID->item(0)->nodeValue;

//echo "retMsg=".$retMsg;

//echo $retCode_value." ".$errMsg_value." ".$signMsg_value." ".$orderUrl_value;

if($retCode_value != "0"){

//echo "交易返回码:".$retCode_value."<br>";

//echo "交易错误信息:" .$errMsg_value."<br>";

return "交易错误信息:" .$errMsg_value."<br>";

}else{

$param['signMsg_value'] = $signMsg_value;

$param['orderUrl_value'] = $orderUrl_value;

$form_code = $this->create_html($param); //创建提交表单

return $form_code;

}

}

/**

* 创建提交表单

*/

function create_html($param){

$pay_html ='<form name = "form1" method = "post" action = "'.$param['orderUrl_value'].'">

<input type = "hidden" name = "interfaceVersion" value = "'.$param['interfaceVersion'].'">

<input type = "hidden" name = "merID" value = "'.$param['merID'].'">

<input type = "hidden" name = "orderid" value = "'.$param['orderid'].'">

<input type = "hidden" name = "orderDate" value = "'.$param['orderDate'].'">

<input type = "hidden" name = "orderTime" value = "'.$param['orderTime'].'">

<input type = "hidden" name = "tranType" value = "'.$param['tranType'].'">

<input type = "hidden" name = "amount" value = "'.$param['amount'].'">

<input type = "hidden" name = "curType" value = "'.$param['curType'].'">

<input type = "hidden" name = "orderContent" value = "'.$param['orderContent'].'">

<input type = "hidden" name = "orderMono" value = "'.$param['orderMono'].'">

<input type = "hidden" name = "phdFlag" value = "'.$param['phdFlag'].'">

<input type = "hidden" name = "notifyType" value = "'.$param['notifyType'].'">

<input type = "hidden" name = "merURL" value = "'.$param['merURL'].'">

<input type = "hidden" name = "goodsURL" value = "'.$param['goodsURL'].'">

<input type = "hidden" name = "jumpSeconds" value = "'.$param['jumpSeconds'].'">

<input type = "hidden" name = "payBatchNo" value = "'.$param['payBatchNo'].'">

<input type = "hidden" name = "proxyMerName" value = "'.$param['proxyMerName'].'">

<input type = "hidden" name = "proxyMerType" value = "'.$param['proxyMerType'].'">

<input type = "hidden" name = "proxyMerCredentials" value = "'.$param['proxyMerCredentials'].'">

<input type = "hidden" name = "netType" value = "'.$param['netType'].'">

<input type = "hidden" name = "merSignMsg" value = "'.$param['signMsg_value'].'">

<input type = "hidden" name = "issBankNo" value = "'.$param['issBankNo'].'">

<input type="submit" value=" " class="pay_button" />

</form>';

return $pay_html;

}


/**

* 处理函数

*/

function respond()

$tranCode = "cb2200_verify";

$notifyMsg = $_REQUEST["notifyMsg"];  

$lastIndex = strripos($notifyMsg,"|");

$signMsg = substr($notifyMsg,$lastIndex+1); //签名信息

$srcMsg = substr($notifyMsg,0,$lastIndex+1);//原文

//连接地址

$socketUrl = "tcp://127.0.0.1:8080";

$fp = stream_socket_client($socketUrl, $errno, $errstr, 30);

$retMsg="";

if (!$fp) {

//echo "$errstr ($errno)<br /> ";

return false;

}else{

$in  = "<?xml version='1.0' encoding='UTF-8'?>";

$in .= "<Message>";

$in .= "<TranCode>".$tranCode."</TranCode>";

$in .= "<MsgContent>".$notifyMsg."</MsgContent>";

$in .= "</Message>";

fwrite($fp, $in);

while (!feof($fp)) {

$retMsg =$retMsg.fgets($fp, 1024); 

}

fclose($fp);

//解析返回xml

$dom = new DOMDocument;

$dom->loadXML($retMsg);

$retCode = $dom->getElementsByTagName('retCode');

$retCode_value = $retCode->item(0)->nodeValue;

$errMsg = $dom->getElementsByTagName('errMsg');

$errMsg_value = $errMsg->item(0)->nodeValue;

$signMsg = $dom->getElementsByTagName('signMsg');

$signMsg_value = $signMsg->item(0)->nodeValue;

if($retCode_value != ''){

//echo "交易返回码:".$retCode_value."<br>";

//echo "交易错误信息:" .$errMsg_value."<br>";

return false;

}else{

$arr = preg_split("/|{1,}/",$srcMsg); 

$pay_id = $arr[1];

$action_note = base64_decode($arr[16]);

// 完成订单。

order_paid($pay_id, PS_PAYED, $action_note);

//告诉用户交易完成

return true; 

}

///////////////// respond END ///////////////

}

}


?>


源码(languages/zh_cn/payment/bankcomm.php):


<?php


/**

 * 交通银行语言文件

 * by: Reson www.111cn.net

 * 2014/03/31

 */


global $_LANG;


$_LANG['bankcomm'] = '交通银行在线支付';

$_LANG['bankcomm_desc'] = '交通银行在线支付';

$_LANG['pay_button'] = '交通银行支付';


?>

 原文件址:http://www.daixiaorui.com/read/80.html

原文下载:http://file.111cn.net/upload/2014/4/13962827995368.zip

 

这里我们是在上传文件时把上传的文件转换成二进制然后保存到数据的字段中去,下次读读出我们也用同样的方法显示即可。

html:

 代码如下 复制代码
<form action=”insertPic.php” method=”post” enctype=”multipart/form-data” name=”mainForm” id=”mainForm”>
<input type=”file” name=”myFile” />
<input type=”submit” name=”Submit” value=”Submit”/>
</form>

将图片保存到数据库:

 代码如下 复制代码
<?php
//由于上传过来的图片被保存在一个临时文件中,所以
//我们仅需要读取该文件就可以获取传过来的图片
$fp = fopen($_FILES["myFile"]["tmp_name"],”rb”);
$buf = addslashes(fread($fp,$_FILES["myFile"]["size"]));
//创建一个PDO对象
$dbh = new PDO(“mysql:host=localhost;port=
3306;dbname=test”, “root”, “123456″);
//执行插入操作并将结果保存在一个变量中
$result = $dbh->query(“INSERT INTO img (images) VALUES (‘$buf’)”);
//获取影响的行数
if ($result->rowCount() >0) {
echo(“数据已插入。”);
} else {
echo(“不能执行插入操作。”);
}
//显式的关闭PDO连接
$dbh = NULL;
?>
显示图片:(show.php)
<?php
$conn=@mysql_connect(“localhost”,”root”,”123456″) or die(“服务器连接错误!”); //链接数据库
@mysql_select_db(“test”,$conn) or die(“未发现数据库!”);
$query=”select * from img where Id=”.$_GET['id'];
$result=mysql_query($query); www.111cn.net
$num=mysql_num_rows($result);
$data = mysql_result($result,0,”images”);
header(“Content-type: image/” . $num['imgType']);
echo $data;
?>

或者

 代码如下 复制代码
<img src=”show.php?id=5″ />

1、fopen函数。
fopen()函数用于打开文件或者URL。语法如下:
int fopen(string filename, string mode);
字符串参数mode可以是下列的情形:
“r”开文件方式为只读,文件指针指到开始处。
“r+”开文件方式为可读写,文件指针指到开始处。
“w”开文件方式为写入,文件指针指到开始处,并将原文件的长度设为0。若文件不存在,则建立新文件。
“w+”开文件方式为可读写,文件指针指到开始处,并将原文件的长度设为0。若文件不存在,则建立新文件。
“a”开文件方式为写入,文件指针指到文件最后。若文件不存在,则建立新文件。
“a+”开文件方式为可读写,文件指针指到文件最后。若文件不存在,则建立新文件。
“b”若操作系统的文字及二进位文件不同,则可以用此参数,UNIX系统不需要使用本参数。
2、Addslashes函数。
Addslashes函数用于将字符串加入斜线。语法如下:【注:我测试的时候是把这个函数去掉后成功了,道理你懂的。自己试下就明白了】
string addslashes(string str);
该函数使需要让数据库处理的字符串,引号的部份加上斜线,以供数据库查询(query)能顺利运作。这些会被改的字符包括单引号(’)、双引号(”)、反斜线backslash()以及空字符NULL(the null byte)。
3、fread函数。
fread函数用于读到指定长度的位组或到文件尾EOF。语法如下:
string fread(int fp, int length);可安全用于二进制文件
fread() 从文件指针 file 读取最多 length 个字节。该函数在读取完最多 length 个字节数,或到达 EOF 的时候,或(对于网络流)当一个包可用时,或(在打开用户空间流之后)已读取了 8192 个字节时就会停止读取文件,视乎先碰到哪种情况。
二进制转换成图片
注:$newFilePath 对生成的图片名和路径做处理,这里自己去实现。

 代码如下 复制代码
$newFilePath='1.jpg';
$data = $GLOBALS[HTTP_RAW_POST_DATA];//得到post过来的二进制原始数据
if(empty($data)){ www.111cn.net
 $data=file_get_contents("php://input");
}
$newFile = fopen($newFilePath,"w");//打开文件准备写入
fwrite($newFile,$data);//写入二进制流到文件
fclose($newFile);//关闭文件

可以把读取到的二进制流存到数据库,也可以直接写入成一个图片。
获取二进制头文件,从而得知属于什么类型文件

 代码如下 复制代码
$bin = substr($content,0,2);
    $strInfo = @unpack("C2chars", $bin);
    $typeCode = intval($strInfo['chars1'].$strInfo['chars2']);
    $fileType = '';
    switch ($typeCode)
    {
        case 7790:
            $fileType = 'exe';
            break;
        case 7784:
            $fileType = 'midi';
            break;
        case 8297:
            $fileType = 'rar';
            break;
        case 255216:
            $fileType = 'jpg';
            break;
        case 7173:
            $fileType = 'gif';
            break;
        case 6677:
            $fileType = 'bmp';
            break;
        case 13780:
            $fileType = 'png';
            break;
        default:
            echo 'unknown';
    }
临时性需求,研究了一下天翼开发平台的东西,用来发送验证码还是不错的,但是每日限额不多,所以很鸡肋,但是保证100%到达 买的话还是蛮贵的,代码没有做任何优化处理,只是测试是否可以实现接口,用的同学记得完善代码,刚写完老大又说是鸡肋的东西,不用了,代码放在博客记录下
 代码如下 复制代码

<?php
//
date_default_timezone_set('PRC');
//获取access_token
$data = "app_id=x&app_secret=x&grant_type=client_credentials";
$ch = curl_init("https://oauth.api.189.cn/emp/oauth2/v2/access_token");
curl_setopt($ch,CURLOPT_RETURNTRANSFER,1);
curl_setopt($ch,CURLOPT_POST,1);//使用post提交数据
curl_setopt($ch,CURLOPT_POSTFIELDS,$data);//设置 post提交的数据
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);
// 从证书中检查SSL加密算法是否存在

curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, false);
$access_token = curl_exec($ch);
curl_close($ch);
$access_token = json_decode($access_token,true);
//获取短信信任码 www.111cn.net
$timestamp = date('Y-m-d H:i:s');

$param['app_id'] = "app_id=x";
$param['access_token'] = "access_token=".$access_token['access_token'];
$param['timestamp'] = "timestamp=".$timestamp;
ksort($param);
$plaintext = implode("&",$param);
$sign = rawurlencode(base64_encode(hash_hmac('sha1',$plaintext,app_secret,true)));
//echo $sign;exit;
$code = file_get_contents("http://api.189.cn/v2/dm/randcode/token?app_id=x&access_token={$access_token['access_token']}&timestamp=".$timestamp."&sign=".$sign);
$code = json_decode($code,true);
$code = $code['token'];
echo $code;
//下发验证码
unset($param,$plaintext,$sign);
$param['app_id'] = "app_id=x";
$param['access_token'] = "access_token=".$access_token['access_token'];
$param['token'] = "token=".$code;
$param['phone'] = "phone=15091421612";
$param['url'] = "url=http://wx.podapi.com/test.php";
$param['exp_time'] = "exp_time=2";
$param['timestamp'] = "timestamp=".$timestamp;
ksort($param);
$plaintext = implode("&",$param);
$sign = rawurlencode(base64_encode(hash_hmac('sha1',$plaintext,'xx',true)));

$data = "app_id=x&access_token={$access_token['access_token']}&token={$code}&phone=15091421612&url=http://wx.podapi.com/test.php&exp_time=2&timestamp={$timestamp}&sign=".$sign;
$ch = curl_init("http://api.189.cn/v2/dm/randcode/send");
curl_setopt($ch,CURLOPT_RETURNTRANSFER,1);
curl_setopt($ch,CURLOPT_POST,1);//使用post提交数据
curl_setopt($ch,CURLOPT_POSTFIELDS,$data);//设置 post提交的数据
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);
// 从证书中检查SSL www.111cn.net 加密算法是否存在
curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, false);
$state = curl_exec($ch);
//var_dump(curl_getinfo($ch));
curl_close($ch);
//echo $state;

最近看到博客留言的头像有点别扭,因为游客的头像都是同一个头像,看着不是很舒服。虽然现在绝大多数的主题集成了Gavatar头像功能,先不说gavatar被墙的问题,我自己现在都没弄个gavatar头像。

因为我登陆了几次,连接速度巨慢,所以我就放弃了。当然留言插件也不胜枚举,比如现在比较火的多说,但对于没有注册多说的朋友,头像仍是个问题。对于多说的社交账号绑定,我测试多次,QQ,人人这些主流平台的绑定经常出错,而且有的朋友(像我)讨厌繁琐的授权。

鉴于此,我在想一个大众化的,比较简单的方法。我想到的是对于没有头像的朋友调用其QQ头像,因为QQ现在至少是人手一个,所以只需要留言时填写QQ号,然后调用其头像。这样一来就方便多了。

首先是获取QQ的头像了,这也是这个想法的第一步,即今天的主题:

第一种方法:

 代码如下 复制代码

<?php
$qq = 552452006;
echo '<img src="'.'http://q1.qlogo.cn/g?b=qq&nk='.$qq.'&s=100&t='. time() .'">';
?>

第二种方法:

 代码如下 复制代码

<?php
$qq = 552452006;
 
$src = 'http://q1.qlogo.cn/g?b=qq&nk=' . $qq . '&s=100&t=' . time();
 
header('Content-type: image/png');
 
$res = imagecreatefromstring(file_get_contents($src));
 
imagepng($res);
 
imagedestroy($res);
?>

这两种方法的区别:

第一种方法的优点是可以输出头像的原图,如果你的头像是动态的gif,那么输出的也是动态图。缺点是速度比较慢,不适合作为调用头像的方法。

第二种方法的优点是相比第一种速度比较快,但只抓取头像的静态图,不会显示动态头像,比较适合作为调用头像的方法。

[!--infotagslink--]

相关文章

  • C#从数据库读取图片并保存的两种方法

    这篇文章主要介绍了C#从数据库读取图片并保存的方法,帮助大家更好的理解和使用c#,感兴趣的朋友可以了解下...2021-01-16
  • python读取和保存mat文件的方法

    本文主要介绍了python读取和保存mat文件的方法,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...2021-08-25
  • python 实现将Numpy数组保存为图像

    今天小编就为大家分享一篇python 实现将Numpy数组保存为图像,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2020-04-27
  • 安卓开发之保存ImageView中的图片到本地相册

    下面我们来看一篇关于安卓开发之保存ImageView中的图片到本地相册教程吧,希望这篇教程能够给大家带来帮助. 代码如下. private void saveImage(ImageView imageVi...2016-11-01
  • C#抓取网络图片保存到本地的实现方法

    下面小编就为大家分享一篇C#抓取网络图片保存到本地的实现方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2020-06-25
  • C#网站生成静态页面的实例讲解

    今天小编就为大家分享一篇关于C#网站生成静态页面的实例讲解,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧...2020-06-25
  • Asp.net动态生成html页面的方法分享

    这篇文章介绍了Asp.net动态生成html页面的方法,有需要的朋友可以参考一下...2021-09-22
  • nginx配置访问图片路径以及html静态页面的调取方法

    这篇文章主要介绍了详解nginx配置访问图片路径以及html静态页面的调取方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。...2016-12-15
  • apache .htaccess 伪静态页

    apache .htaccess 伪静态页 静态页的地址: http://211.166.45.10/company/new/new_10000.html 指定的动态地址:php?id=10000">http://211.166.45.10/company/new.php?id=...2016-01-28
  • 百万数据级的网站静态页面的生成方案

    传统的生成静态页面的方法大家都很清楚,无非就是以下两种: 方案一: 1、每增加/修改一个栏目的信息的时候,就生成一次该栏目(包括父栏目)的页面; 2、每增加/修改一...2016-09-20
  • C#生成单页静态页简单实例

    这篇文章主要介绍了C#生成单页静态页简单实例,是一个非常实用的技巧,需要的朋友可以参考下...2020-06-25
  • 使用PHP实现生成HTML静态页面

    从PHP生成HTML静态页面并存储到以年份和月份为名称创建的目录。读取全部数据批量生成,全部生成后弹出提示。可指定批次生成数量,建议不超过800,否则执行速度会有问题。(出于众所周知的原因,涉及到数据库的数据字段名称做了...2015-11-24
  • OpenCV获取视频的每一帧并保存为.jpg图片

    这篇文章主要为大家详细介绍了OpenCV获取视频的每一帧,并保存为.jpg图片,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...2020-04-25
  • pytorch模型的保存和加载、checkpoint操作

    这篇文章主要介绍了pytorch模型的保存和加载、checkpoint操作,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教...2021-06-06
  • php定时自动生成html静态页面

    php定时自动生成html静态页面 "ob_start()、ob_end_clean()、ob_get_contents()" ob_start():是打开缓冲区的,就是要把您需要生成的静态文件的内容缓存在这里; ob_g...2016-11-25
  • 谈PHP生成静态页面

    一、引 言 在速度上,静态页面要比动态页面的比方php快很多,这是毫无疑问的,但是由于静态页面的灵活性较差,假如不借助数据库或其他的设备保存相关信息的话,整体的治...2016-11-25
  • Python3中PyQt5简单实现文件打开及保存

    本文将结合实例代码,介绍Python3中PyQt5简单实现文件打开及保存,具有一定的参考价值,需要的朋友们下面随着小编来一起学习学习吧...2021-06-10
  • C#中实现伪静态页面两种方式介绍

    伪静态技术的诞生,带动了于搜索引擎友好C#中实现伪静态页面有两种方式,本文将一一详解,感兴趣的朋友可以参考下,希望本文对你学习伪静态有所帮助...2021-09-22
  • php读取和保存base64编码的图片内容

    这篇文章主要为大家详细介绍了php读取和保存base64编码的图片内容,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...2017-04-26
  • php生成静态页面程序与原理分析

    生成静态页面是php中来减少服务器负载与seo网站优化一个不错的选择,所以php生成静态页面功能是几乎所有php程序员必须了解并掌握的一个知识点,下面我来给大家介绍php生...2016-11-25