【网站建设】将新浪微博图床图片保存到本地解决限制外链的方法

2019年4月27日16:42:19 4 7,671

【解决方案】1. 修改引用地址

  1. ws1/2/3/4s替换成x以后就可以访问
  2. 或者引用http地址

【解决方案】2. 保存到本地

  • 既然新浪图床不能引用了,最好的容灾的方式就是将图片保存到自己的服务器中
  • 我这里以WordPress为例,将WordPress文章中引用的图片全部更换为本地链接
  • 先来一个Sql,使用phpMyAdmin等工具查询
SELECT id from wp_posts WHERE post_content like '%sinaimg%'
  • 找到包含新浪图床图片链接的文章,将此方法加入functions.php
此处为隐藏的内容!
发表评论并刷新,方可查看
  • 此方法为了获取到文章中所有的图片链接,如果你引用的新浪图片文件比较多,建议直接将$post改为写Sql查询全部,然后正则匹配直接打印出来图片地址
  • 在静态资源目录中新建一个PHP文件,推荐在当前月的/wp-content/uploads目录下新建,比如/wp-content/uploads/2019/04/
  • 将图片链接定义为数组
$data = [
    "https://ws1.sinaimg.cn/large/006tKfTcgy1g12lp87my3j30ow0780sz.jpg",
    "https://ws2.sinaimg.cn/large/0072Lfvtly1fymh07hzkkj30dq0dqagc.jpg",
    "https://ws3.sinaimg.cn/large/006tNc79gy1g2cj78h6x5j31gf0itwhj.jpg",
    "https://ws4.sinaimg.cn/large/0072Lfvtly1fzmelgwrkkj30el09taag.jpg",
];
  • 然后开始循环处理将图片保存到本地
foreach ($data as $item) {
    preg_match('/\/(?P<name>\w+\.(?:png|jpg|gif))$/i', $item,$matches);
    $content = file_get_contents($item);
    file_put_contents('./'.$matches['name'], $content);
}
echo 'Done!!!';
  • /wp-content/uploads/2019/04/目录下的命令行中执行
php sinaimg.php
  • 等待执行完毕,查看当前目录下的文件,应该就会有对应的图片文件
  • 我们可以修改对应的权限和对应等所属组等
chmod 755 ./* && chown www ./* && chgrp www ./*
  • 以上对应的操作完成后,少不了的就是替换数据库中已经写入的地址,还是之前熟悉的操作
  • 备份数据库,然后执行命令(将后面的地址替换为你自己的)
UPDATE wp_posts SET post_content = REPLACE( post_content, 'https://ws1.sinaimg.cn/large', 'https://www.7585.net.cn/wp-content/uploads/2019/04');
UPDATE wp_posts SET post_content = REPLACE( post_content, 'https://ws2.sinaimg.cn/large', 'https://www.7585.net.cn/wp-content/uploads/2019/04');
UPDATE wp_posts SET post_content = REPLACE( post_content, 'https://ws3.sinaimg.cn/large', 'https://www.7585.net.cn/wp-content/uploads/2019/04');
UPDATE wp_posts SET post_content = REPLACE( post_content, 'https://ws4.sinaimg.cn/large', 'https://www.7585.net.cn/wp-content/uploads/2019/04');
  • 就这样,剔除文章中引用新浪微博图床的图片成功,其他地方同理即可

发表评论

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen:

目前评论:4   其中:访客  4   博主  0

    • 感谢分享 感谢分享

      感谢,正愁图片不知道怎么办了。

      • 55boy 55boy

        感谢分享

        • 每天 每天

          感谢分享

          • 望

            看看