你好,欢迎来到织梦之家,你可以免费观看大量视频教程以及大量模板下载!

MIP技能分享:织织梦CMS梦gbk站点mip改革方案分享-织梦之家(dedehome.com)

时间:2017-06-18 13:02 来源:织梦之家作者:织梦之家 点击:
A5创业网是海内领先的创业资讯和处事平台,提供权威的创业资讯和精准的品牌营销处事。以创业融资动态、创业学院、产物司理、人物访谈为内容驱动,与互联网创业者

mip

  媒介:

  近期实验对一个做过跳转适配的dedecms/gbk手机站举办整站mip改革,颠末一系列思路完善和测试,终于完成,回首下进程,主要问题可分为以下几类:

  1、非utf-8站点的编码问题

  前些时候宋同学在站长社区宣布了新装utf-8版cms和转换数据库编码的教程,我刚开始也是雷同思路,但因为站点颠末二次开拓以及包括一些参差不齐的冈蹲隳件等,重装cms很难复兴之前的修改,此思路卒。后又实验在数据库调用时以gbk编码读取,测试生成后虽概略上欣赏正常,但照旧存在些许后续问题和少部门乱码,也放弃了该方案。最终,灵光一闪——为什么要在措施执行进程中纠结?完全可以在生成静态页面时举办替换整改啊!即刻柳暗花明之感油然而生,测试公然可行,之后遇到后续问题(如下面问题2、3)也因此思路而变得易办理了。

  2、路径问题

  、/等标签中的相对路径需均转换为完整url,这个在今朝教程里貌似没有明了提出,根目录相对路径还好,主要是相对当前页面路径转换完整url需加上地址目录有些难度(出格是标签调用生成的相对路径,如分页)。

  3、内联样式问题

  模板里的内联样式可以手动整改,虽啰嗦但难度不大,主要问题在于靠山宣布文章时,cms编辑器会自动生成包罗内联样式在内的各类不切合mip法则的原始代码,除了折腾一下对编辑器举办修改,其他也很难办理了。

  4、js问题

  mip类型范围了js的利用,织梦仿站,这个简直挺头疼的,亏得我改革的站点内js不多,所以删掉部门结果和利用现有组件替换,也拼集办理了此问题。不外照旧但愿百度mip团队能在思量下此方面的类型方案优化,不少站点有许多js代码且不能去除,全部以组件形式提交也很费事且需要必然的措施基本,其他问题还可以按统一教程去办理,但js上的mip改革却无法如此,凭据今朝的限制会导致许多站长因此一点就不得不放弃mip改革。

  5、其他小问题

  ·发明少部门样式有斗嘴,需按照实际环境对自己css举办局部修改。

  ·发明mip cache无法识别站点中图片的302跳转,如原站利用302跳转的图片,mip生效后无法显示图片。该问题已和百度技能人员相同,说后续可以思量支持,今朝我本身加了一段代码对路径做了下处理惩罚。

  ·组件利用bug(如mip-carousel多图轮播图片套链接会导致图片显示空缺,且无法自适应屏幕)。

  ·mip引入提交后就回显个success,也没有提交记录和状态,织梦网,用户体验上有所欠缺。

  正题:基于dedecms/gbk的整站mip改革

  第一部门:模板修改

  1、js部门:删除或利用现有组件替换

  2、调用百度mip文件:

  head里加

  body里加

  3、head里加,通过dedecms标签直接调用当前页url。

  4、外部通用css文件:发起将css文件中的样式代码嵌入

  中,另存为模板文件(如css.htm),用{dede:includefilename="css.htm"/}替换相关模板中的。

  模板中的内联css可人工举办查找替换,归并至中。(虽在下面代码中可以自动举办处理惩罚,但从静态文件生成机能角度思量,照旧发起人工先将模板中的内联样式一次性整改好。)

  注:以上操纵大多可通过批量查找替换来完成,看似需要修改许多,但实际事情量并不大。

  第二部门:措施文件修改

  · 静态生成移动站:

  找到/include/dedetag.class.php文件中理会模板输出为文件的函数:

  function SaveTo($filename)

  {

  $fp = @fopen($filename,"w")or die("DedeTag Engine Create File False");

  fwrite($fp,$this->GetResult());

  fclose($fp);

  }

  替换为(部门代码可按照实际环境举办窜改):

  //路径转换函数文件。$content:代码源,$feed_url:首页,$f_url:相对路径的目录部门

  function relative_to_absolute($content,$protocol, $domain, $f_url) {

  //根目录相对路径(如href="/a/b.html")转换

  $new_content =preg_replace('/href\s*\=\s*([\'"])\s*\//','href=\\1'.$protocol.$domain.'http://www.admin5.com/', $content);

  $new_content =preg_replace('/src\s*\=\s*([\'"])\s*\//', 'src=\\1'.$protocol.$domain.'http://www.admin5.com/',$new_content);

  //当前页相对路径(如href="a/b.html")转换

  $new_content

  =preg_replace('/href\s*\=\s*([\'"])(?!(http|https):\/\/)/','href=\\1'.$protocol.$domain.$f_url,$new_content);

  $new_content

  =preg_replace('/src\s*\=\s*([\'"])(?!(http|https):\/\/)/','src=\\1'.$protocol.$domain.$f_url, $new_content);

  return $new_content;

  }

  function SaveTo($filename)

  {

  $fp=@fopen($filename,"w") ordie("DedeTag Engine Create File False");

  if(substr($_SERVER['PHP_SELF'],-6)=='_m.php'||substr($filename,-13)=='/m/index.html'){//跳转适配站识别是否为移动端生成,不影响pc端的gbk编码。移动端为独立站点需去掉此判断条件。

  $f_url=explode('www.域名.com/m',dirname($filename));//支解路径,获取当前页相对路径的目录部门

  //如dirname($filename)获得的当地绝对路径为D:/wwwroot/www.域名.com/m/yygk/xwzx,用网站目录“域名.com/m”作为标识支解路径,获得目录部门“/yygk/xwzx”。

  $html=$this->GetResult();

  $html=$this->relative_to_absolute($html,'http://','m.域名.com',$f_url[1].'http://www.admin5.com/');//相对路径转换绝对路径

  $html=str_replace('<metacharset="gb2312">','<metacharset="utf-8">',iconv('gbk','utf-8//ignore',$html));//转换为utf-8编码声明,fwrite会以今生成对应编码的静态页面

  $html=str_replace('<a','标签加target< p="">

  $html=str_replace('<img','

  /*主要针对编辑器生成的内联样式,将内联样式转换到head的style标签中*/

  if(preg_match_all('/\sstyle\s*\=\s*[\'"](.*?)[\'"]/',$html,$css)){

  $css0=array_unique($css[0]);//过滤反复style

  foreach($css0as $k => $v){

  $html=str_replace($v,'class="mip_add_css_'.$k.'"',$html);//mip_add_css_为自界说样式名前缀,可自行修改,但需制止与原有样式名反复

  $temp_name='mip_add_css_'.$k;

  $$temp_name=$css[1][$k];

  $add_css.='.'.$temp_name.'{'.$css[1][$k]."}\n";

  }

  $html=str_replace('',"

感谢支持织梦之家,你的支持,我们的无限动力!!!
“DEDECMS教程”欢迎分享!:

相关标签:百度MIP(51)

    顶一下
    (0)
    0%
    踩一下
    (0)
    0%

    欢迎您报错,或提出宝贵建议,我们将第一时间处理,为大家营造一个良好网上交流平台,感谢支持织梦之家!

    发表评论
    请自觉遵守互联网相关的政策法规,严禁发布色情、暴力、反动的言论。
    评价:
    验证码: 点击我更换图片