
在实际需求中,有时链接地址特别长,或者不愿让其他人知道实际的地址。这时生成短链接就排上用场了。本篇是通过调用百度API来实现功能。
1.相应的pom依赖
<!-- https://mvnrepository.com/artifact/com.google.code.gson/gson -->
<dependency>
<groupId>com.google.code.gson</groupId>
<artifactId>gson</artifactId>
<version>2.8.5</version>
</dependency>
2.请求介绍
请求地址:https://dwz.cn/admin/v2/create
请求方式:POST
Content-Type类型:application/json; charset=UTF-8
请求必填参数(Headers): Token
请求必填参数(Body): url 长网址
Token获取方式 : 跳转https://dwz.cn/ 并注册登陆然后选择Token设置

public class BaiduDwz {
//短网址还原接口
//final static String CREATE_API = "https://dwz.cn/admin/v2/query";
//短网址生成接口
final static String CREATE_API = "https://dwz.cn/admin/v2/create";
final static String TOKEN = ""; // TODO:设置Token
/**
* 创建短网址
*
* @param longUrl
* 长网址:即原网址
* @return 成功:短网址
* 失败:返回空字符串
*/
public static String createShortUrl(String longUrl) {
String params = "{\"url\":\""+ longUrl + "\"}";
BufferedReader reader = null;
try {
// 创建连接
URL url = new URL(CREATE_API);
HttpURLConnection connection = (HttpURLConnection) url.openConnection();
connection.setDoOutput(true);
connection.setDoInput(true);
connection.setUseCaches(false);
connection.setInstanceFollowRedirects(true);
connection.setRequestMethod("POST"); // 设置请求方式
connection.setRequestProperty("Content-Type", "application/json"); // 设置发送数据的格式
connection.setRequestProperty("Token", TOKEN); // 设置发送数据的格式");
// 发起请求
connection.connect();
OutputStreamWriter out = new OutputStreamWriter(connection.getOutputStream(), "UTF-8"); // utf-8编码
out.append(params);
out.flush();
out.close();
// 读取响应
reader = new BufferedReader(new InputStreamReader(connection.getInputStream(), "UTF-8"));
String line;
String res = "";
while ((line = reader.readLine()) != null) {
res += line;
}
reader.close();
// 抽取生成短网址
UrlResponse urlResponse = new Gson().fromJson(res, UrlResponse.class);
if (urlResponse.getCode() == 0) {
return urlResponse.getShortUrl();
} else {
System.out.println(urlResponse.getErrMsg());
}
return ""; // TODO:自定义错误信息
} catch (IOException e) {
// TODO
e.printStackTrace();
}
return ""; // TODO:自定义错误信息
}
}
4.测试
长地址选择了我的简书首页地址: https://www.jianshu.com/u/3d0829501918。启动mian方法生成短链接的地址: https://dwz.cn/q8jsV8jC
public static void main(String[] args) {
String shortUrl = createShortUrl("https://www.jianshu.com/u/3d0829501918");
System.out.println(shortUrl);
}
1.请求介绍
请求地址:https://dwz.cn/admin/v2/query
请求方式:POST
Content-Type类型:application/json; charset=UTF-8
请求数据结构:JSON
请求必填参数(Headers): Token
请求必填参数(Body): shortUrl 短网址
2.还原短网址方法
package com.rxlm.practice.util;
import com.google.gson.Gson;
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.OutputStreamWriter;
import java.net.HttpURLConnection;
import java.net.URL;
public class BaiduDwz {
//短网址还原接口
final static String CREATE_API = "https://dwz.cn/admin/v2/query";
final static String TOKEN = ""; // TODO:设置Token
/**
* 还原长网址短网址
*
* @param shortUrl 短网址
* @return 成功:长网址
*
*/
public static String queryLongUrl(String shortUrl) {
String params = "{\"shortUrl\":\""+ shortUrl + "\"}";
BufferedReader reader = null;
try {
// 创建连接
URL url = new URL(CREATE_API);
HttpURLConnection connection = (HttpURLConnection) url.openConnection();
connection.setDoOutput(true);
connection.setDoInput(true);
connection.setUseCaches(false);
connection.setInstanceFollowRedirects(true);
connection.setRequestMethod("POST"); // 设置请求方式
connection.setRequestProperty("Content-Type", "application/json"); // 设置发送数据的格式
connection.setRequestProperty("Token", TOKEN); // 设置发送数据的格式");
// 发起请求
connection.connect();
OutputStreamWriter out = new OutputStreamWriter(connection.getOutputStream(), "UTF-8"); // utf-8编码
out.append(params);
out.flush();
out.close();
// 读取响应
reader = new BufferedReader(new InputStreamReader(connection.getInputStream(), "UTF-8"));
String line;
String res = "";
while ((line = reader.readLine()) != null) {
res += line;
}
reader.close();
// 抽取生成长网址
UrlResponse urlResponse = new Gson().fromJson(res, UrlResponse.class);
if (urlResponse.getCode() == 0) {
return urlResponse.getLongUrl();
} else {
System.out.println(urlResponse.getErrMsg());
}
return ""; // TODO:自定义错误信息
} catch (IOException e) {
// TODO
e.printStackTrace();
}
return ""; // TODO:自定义错误信息
}
}
3.测试
用上述方法生成的短地址https://dwz.cn/q8jsV8jC测试
public static void main(String[] args) {
String res = queryLongUrl("https://dwz.cn/q8jsV8jC");
System.out.println(shortUrl);
}
然后还原了长地址。

1.响应结果示例
{
"Code": 0,
"ShortUrl": "https://dwz.cn/q8jsV8jC",
"LongUrl": "https://www.jianshu.com/u/3d0829501918",
"ErrMsg": ""
}
Code:
0:正常返回短网址
-1:短网址对应的长网址不合法
-2:短网址不存在
-3:查询的短网址不合法
ShortUrl:
短网址
LongUrl:
长网址(原网址)
ErrMsg:
错误信息
最后详细的介绍请移步百度API,注意需要用户登陆。
我有一个Ruby程序,它使用rubyzip压缩XML文件的目录树。gem。我的问题是文件开始变得很重,我想提高压缩级别,因为压缩时间不是问题。我在rubyzipdocumentation中找不到一种为创建的ZIP文件指定压缩级别的方法。有人知道如何更改此设置吗?是否有另一个允许指定压缩级别的Ruby库? 最佳答案 这是我通过查看rubyzip内部创建的代码。level=Zlib::BEST_COMPRESSIONZip::ZipOutputStream.open(zip_file)do|zip|Dir.glob("**/*")d
在MRIRuby中我可以这样做:deftransferinternal_server=self.init_serverpid=forkdointernal_server.runend#Maketheserverprocessrunindependently.Process.detach(pid)internal_client=self.init_client#Dootherstuffwithconnectingtointernal_server...internal_client.post('somedata')ensure#KillserverProcess.kill('KILL',
我正在编写一个小脚本来定位aws存储桶中的特定文件,并创建一个临时验证的url以发送给同事。(理想情况下,这将创建类似于在控制台上右键单击存储桶中的文件并复制链接地址的结果)。我研究过回形针,它似乎不符合这个标准,但我可能只是不知道它的全部功能。我尝试了以下方法:defauthenticated_url(file_name,bucket)AWS::S3::S3Object.url_for(file_name,bucket,:secure=>true,:expires=>20*60)end产生这种类型的结果:...-1.amazonaws.com/file_path/file.zip.A
我真的很习惯使用Ruby编写以下代码:my_hash={}my_hash['test']=1Java中对应的数据结构是什么? 最佳答案 HashMapmap=newHashMap();map.put("test",1);我假设? 关于java-等价于Java中的RubyHash,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/22737685/
我正在尝试编写一个将文件上传到AWS并公开该文件的Ruby脚本。我做了以下事情:s3=Aws::S3::Resource.new(credentials:Aws::Credentials.new(KEY,SECRET),region:'us-west-2')obj=s3.bucket('stg-db').object('key')obj.upload_file(filename)这似乎工作正常,除了该文件不是公开可用的,而且我无法获得它的公共(public)URL。但是当我登录到S3时,我可以正常查看我的文件。为了使其公开可用,我将最后一行更改为obj.upload_file(file
我有用于控制用户任务的Rails5API项目,我有以下错误,但并非总是针对相同的Controller和路由。ActionController::RoutingError:uninitializedconstantApi::V1::ApiController我向您描述了一些我的项目,以更详细地解释错误。应用结构路线scopemodule:'api'donamespace:v1do#=>Loginroutesscopemodule:'login'domatch'login',to:'sessions#login',as:'login',via::postend#=>Teamroutessc
如何在ruby中调用C#dll? 最佳答案 我能想到几种可能性:为您的DLL编写(或找人编写)一个COM包装器,如果它还没有,则使用Ruby的WIN32OLE库来调用它;看看RubyCLR,其中一位作者是JohnLam,他继续在Microsoft从事IronRuby方面的工作。(估计不会再维护了,可能不支持.Net2.0以上的版本);正如其他地方已经提到的,看看使用IronRuby,如果这是您的技术选择。有一个主题是here.请注意,最后一篇文章实际上来自JohnLam(看起来像是2009年3月),他似乎很自在地断言RubyCL
我是Rails的新手,所以请原谅简单的问题。我正在为一家公司创建一个网站。那家公司想在网站上展示它的客户。我想让客户自己管理这个。我正在为“客户”生成一个表格,我想要的三列是:公司名称、公司描述和Logo。对于名称,我使用的是name:string但不确定如何在脚本/生成脚手架终端命令中最好地创建描述列(因为我打算将其设置为文本区域)和图片。我怀疑描述(我想成为一个文本区域)应该仍然是描述:字符串,然后以实际形式进行调整。不确定如何处理图片字段。那么……说来话长:我在脚手架命令中输入什么来生成描述和图片列? 最佳答案 对于“文本”数
我正在尝试使用boilerpipe来自JRuby。我看过guide从JRuby调用Java,并成功地将它与另一个Java包一起使用,但无法弄清楚为什么同样的东西不能用于boilerpipe。我正在尝试基本上从JRuby中执行与此Java等效的操作:URLurl=newURL("http://www.example.com/some-location/index.html");Stringtext=ArticleExtractor.INSTANCE.getText(url);在JRuby中试过这个:require'java'url=java.net.URL.new("http://www
我需要一些关于TDD概念的帮助。假设我有以下代码defexecute(command)casecommandwhen"c"create_new_characterwhen"i"display_inventoryendenddefcreate_new_character#dostufftocreatenewcharacterenddefdisplay_inventory#dostufftodisplayinventoryend现在我不确定要为什么编写单元测试。如果我为execute方法编写单元测试,那不是几乎涵盖了我对create_new_character和display_invent