震惊了:调用渣浪短网址服务(旧)生成短网址,小心掉坑

2023-10-30 05:30

本文主要是介绍震惊了:调用渣浪短网址服务(旧)生成短网址,小心掉坑,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

2019独角兽企业重金招聘Python工程师标准>>> hot3.png

24142757_PxQ0.png 本文通过 OscPress 同步至oschina,获取最新版本和更好的阅读体验请查看原文:
http://blog.cellmean.com/?p=1289

众所周知,新浪微博有一个短网址功能,会把你在微博发的原链接转成http://t.cn/XXOO的形式。开放了API,也就是这个:

http://open.weibo.com/wiki/2/short_url/shorten ,调用这玩意还居然要access_token ,我也是醉了,搜索了一下,找到一个旧版的接口,不需要access_token, 只要申请或者随便找一个appkey就能用了, 详细说明看这篇https://www.douban.com/note/249723561/ ,

对应的URL请求地址为:xml:http://api.t.sina.com.cn/short_url/shorten.xml
json:http://api.t.sina.com.cn/short_url/shorten.json请求方式:GET
请求参数:source:应用的appkeyurl_long:需要转换的长链接
举个例子:
xml:http://api.t.sina.com.cn/short_url/shorten.xml?source=3271760578&url_long=http://www.douban.com/note/249723561/
返回内容为:
<urls>
<url>
<url_short>http://t.cn/zWXySpZ</url_short>
<url_long>http://www.douban.com/note/249723561/</url_long>
<type>0</type>
</url>
</urls>json:http://api.t.sina.com.cn/short_url/shorten.json?source=3271760578&url_long=http://www.douban.com/note/249723561/
返回内容为:
[{"url_short":"http://t.cn/zWXySpZ","url_long":http://www.douban.com/note/249723561/","type":0}]

测试了一下,服务仍然可用,但这个接口是有问题的,貌似是旧版api遗留下来的, 首先这个请求参数url_long的地址不必使用url_encode, 新版是需要的(而且也是必要的),经测试发现被 url_encode过的long_url只会返回”[]”,这导致当请求原链接带”&”时就不能正确识别,比如http://blog.cellmean.com?post_type=post&id=10086, 则发送:

“http://api.t.sina.com.cn/short_url/shorten.json?source=3271760578&url_long=http://blog.cellmean.com?post_type=post&id=10086”;

返回:

[
{
“url_short”: “http://t.cn/RiZMd85”,
“url_long”: “http://blog.cellmean.com?post_type=post”,
“type”: 0
}
]

这样”&id=10086″的部分会被吃掉,实际上返回的是”http://blog.cellmean.com?post_type=post”的短链接。如果要得到正确的结果,只能对”&”单独进行一次urlencode,替换成”%26″,或者转换成html实体”&amp;”;
即请求:

“http://api.t.sina.com.cn/short_url/shorten.json?source=3271760578&url_long=http://blog.cellmean.com?post_type=post%26id=10086”

返回值:

[{“url_short”:”http://t.cn/RiZqrtU”,”url_long”:”http://blog.cellmean.com?post_type=post&id=10086″,”type”:0}]

 

然后我简单封装了一下, 代码如下:

function sina_url_shorten( $url,$source='3271760578' ) {echo $request_url = "http://api.t.sina.com.cn/short_url/shorten.json?source=".$source .'&url_long='. str_replace("&","%26",$url);$data = file_get_contents($request_url);$array = json_decode($data,true);if( isset($array[0] )) {return $array[0]['url_short'];}else{return false;}}$long_url = 'http://blog.cellmean.com/book/%E5%8F%B2%E8%AE%B0/?cid=5689142fa8c4a4100065298&from=10086';
echo sina_url_shorten($long_url);

没有弄http的错误处理,密钥是网上找到的,可能会有调用频率限制,可以在这个页面申请一个 : http://open.weibo.com/connect 然而这个立即连接半天点不动。

最后说明:标题灵感源于“UC震惊部”:)


感谢阅读本文,欢迎访问 异想录 获取更多内容或 查看原文

转载于:https://my.oschina.net/falcon10086/blog/845526

这篇关于震惊了:调用渣浪短网址服务(旧)生成短网址,小心掉坑的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/305879

相关文章

Java调用Python代码的几种方法小结

《Java调用Python代码的几种方法小结》Python语言有丰富的系统管理、数据处理、统计类软件包,因此从java应用中调用Python代码的需求很常见、实用,本文介绍几种方法从java调用Pyt... 目录引言Java core使用ProcessBuilder使用Java脚本引擎总结引言python

详解Java中如何使用JFreeChart生成甘特图

《详解Java中如何使用JFreeChart生成甘特图》甘特图是一种流行的项目管理工具,用于显示项目的进度和任务分配,在Java开发中,JFreeChart是一个强大的开源图表库,能够生成各种类型的图... 目录引言一、JFreeChart简介二、准备工作三、创建甘特图1. 定义数据集2. 创建甘特图3.

java如何调用kettle设置变量和参数

《java如何调用kettle设置变量和参数》文章简要介绍了如何在Java中调用Kettle,并重点讨论了变量和参数的区别,以及在Java代码中如何正确设置和使用这些变量,避免覆盖Kettle中已设置... 目录Java调用kettle设置变量和参数java代码中变量会覆盖kettle里面设置的变量总结ja

AI一键生成 PPT

AI一键生成 PPT 操作步骤 作为一名打工人,是不是经常需要制作各种PPT来分享我的生活和想法。但是,你们知道,有时候灵感来了,时间却不够用了!😩直到我发现了Kimi AI——一个能够自动生成PPT的神奇助手!🌟 什么是Kimi? 一款月之暗面科技有限公司开发的AI办公工具,帮助用户快速生成高质量的演示文稿。 无论你是职场人士、学生还是教师,Kimi都能够为你的办公文

如何在页面调用utility bar并传递参数至lwc组件

1.在app的utility item中添加lwc组件: 2.调用utility bar api的方式有两种: 方法一,通过lwc调用: import {LightningElement,api ,wire } from 'lwc';import { publish, MessageContext } from 'lightning/messageService';import Ca

pdfmake生成pdf的使用

实际项目中有时会有根据填写的表单数据或者其他格式的数据,将数据自动填充到pdf文件中根据固定模板生成pdf文件的需求 文章目录 利用pdfmake生成pdf文件1.下载安装pdfmake第三方包2.封装生成pdf文件的共用配置3.生成pdf文件的文件模板内容4.调用方法生成pdf 利用pdfmake生成pdf文件 1.下载安装pdfmake第三方包 npm i pdfma

poj 1258 Agri-Net(最小生成树模板代码)

感觉用这题来当模板更适合。 题意就是给你邻接矩阵求最小生成树啦。~ prim代码:效率很高。172k...0ms。 #include<stdio.h>#include<algorithm>using namespace std;const int MaxN = 101;const int INF = 0x3f3f3f3f;int g[MaxN][MaxN];int n

poj 1287 Networking(prim or kruscal最小生成树)

题意给你点与点间距离,求最小生成树。 注意点是,两点之间可能有不同的路,输入的时候选择最小的,和之前有道最短路WA的题目类似。 prim代码: #include<stdio.h>const int MaxN = 51;const int INF = 0x3f3f3f3f;int g[MaxN][MaxN];int P;int prim(){bool vis[MaxN];

poj 2349 Arctic Network uva 10369(prim or kruscal最小生成树)

题目很麻烦,因为不熟悉最小生成树的算法调试了好久。 感觉网上的题目解释都没说得很清楚,不适合新手。自己写一个。 题意:给你点的坐标,然后两点间可以有两种方式来通信:第一种是卫星通信,第二种是无线电通信。 卫星通信:任何两个有卫星频道的点间都可以直接建立连接,与点间的距离无关; 无线电通信:两个点之间的距离不能超过D,无线电收发器的功率越大,D越大,越昂贵。 计算无线电收发器D

【区块链 + 人才服务】可信教育区块链治理系统 | FISCO BCOS应用案例

伴随着区块链技术的不断完善,其在教育信息化中的应用也在持续发展。利用区块链数据共识、不可篡改的特性, 将与教育相关的数据要素在区块链上进行存证确权,在确保数据可信的前提下,促进教育的公平、透明、开放,为教育教学质量提升赋能,实现教育数据的安全共享、高等教育体系的智慧治理。 可信教育区块链治理系统的顶层治理架构由教育部、高校、企业、学生等多方角色共同参与建设、维护,支撑教育资源共享、教学质量评估、