多种长连接转换为短连接方案,支持失败切换

本文介绍了一种利用第三方服务实现长链接转换为短链接的Java工具类。该工具类提供了两种实现方式,一种通过suo.im API进行转换,另一种通过新浪API实现。文中详细展示了如何构建HTTP请求并解析返回的JSON数据。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.PrintWriter;
import java.net.URL;
import java.net.URLConnection;
import java.net.URLEncoder;
import java.util.ArrayList;
import java.util.List;

import org.apache.http.HttpResponse;
import org.apache.http.NameValuePair;
import org.apache.http.client.HttpClient;
import org.apache.http.client.entity.UrlEncodedFormEntity;
import org.apache.http.client.methods.HttpPost;
import org.apache.http.impl.client.HttpClientBuilder;
import org.apache.http.message.BasicNameValuePair;
import org.apache.http.util.EntityUtils;
import org.apache.log4j.Logger;

import com.alibaba.fastjson.JSON;
import com.alibaba.fastjson.JSONArray;
import com.alibaba.fastjson.JSONObject;
 
/**
 * @ClassName: ShortUrlUtil  
 * @Description:  工具类:借助第三方,将长连接转换为短连接  
 * @date 2018/07/23 17:21:48 
 *
 */
public class ShortUrlUtil {
	private static Logger log = Logger.getLogger(ShortUrlUtil.class);
 
	public static ShortUrlUtil shortUrlUtil;
	public static HttpClient httpclient;
	static {
		shortUrlUtil = new ShortUrlUtil();
		httpclient = HttpClientBuilder.create().build();
	}
 
	/**
	 * 生成短连接信息
	 */
	public String generateShortUrl(String url) {
		try {
			String apiUrl = "http://suo.im/api.php";
			HttpPost httpost = new HttpPost(apiUrl);
			List<NameValuePair> params = new ArrayList<NameValuePair>();
			params.add(new BasicNameValuePair("format", "utf-8")); 	// 编码
			params.add(new BasicNameValuePair("url", url)); 		// 用户名称
			httpost.setEntity(new UrlEncodedFormEntity(params, "utf-8"));
			HttpResponse response = httpclient.execute(httpost);
			String jsonStr = EntityUtils.toString(response.getEntity(), "utf-8");
			return jsonStr;
		} catch (Exception e) {
			shortUrlUtil = new ShortUrlBySinaUtil();
			log.info("ShortUrlUtil", e);
			return "";
		}
	}
 
	/**
	 * 测试生成短连接
	 */
	public static void main(String[] args) {
		String url = ShortUrlUtil.shortUrlUtil.generateShortUrl("https://mp.weixin.qq.com/debug/cgi-bin/sandbox?t=sandbox/login");
		System.err.println(url);
	}
	
	class ShortUrlBySinaUtil extends ShortUrlUtil {
		static final String actionUrl = "http://api.t.sina.com.cn/short_url/shorten.json";
	    static final String APPKEY = "2024358821,3925598208,3271760578,31641035,2815391962";

	    public String generateShortUrl(String longUrl) {
	        try {
				longUrl = URLEncoder.encode(longUrl, "UTF-8");
				String appkey = APPKEY;
				String[] sourceArray = appkey.split(",");
				for (String key : sourceArray) {
				    String shortUrl = sinaShortUrl(key, longUrl);
				    System.out.println("key====>"+ key + "   " + shortUrl);
				    if (shortUrl != null) {
				        return shortUrl;
				    }
				}
			} catch (Exception e) {
				shortUrlUtil = new ShortUrlBySuoUtil();
				log.info("ShortUrlBySinaUtil", e);
			}
	        return "";
	    }

	    public String sinaShortUrl(String source, String longUrl) {
	        String result = sendPost(actionUrl, "url_long=" + longUrl + "&source=" + source);
	        if (result == null || "".equals(result)) {
	            return "";
	        }

	        JSONArray jsonArr = JSON.parseArray(result);
	        JSONObject json = JSON.parseObject(jsonArr.get(0).toString());
	        String ret = json.get("url_short").toString();
	        return ret;
	    }


	    /**
	     * 向指定 URL 发送POST方法的请求
	     *
	     * @param url   发送请求的 URL
	     * @param param 请求参数,请求参数应该是 name1=value1&name2=value2 的形式。
	     * @return 所代表远程资源的响应结果
	     */

	    public String sendPost(String url, String param) {
	        PrintWriter out = null;
	        BufferedReader in = null;
	        String result = "";
	        try {
	            URL realUrl = new URL(url);
	            // 打开和URL之间的连接
	            URLConnection conn = realUrl.openConnection();
	            // 设置通用的请求属性
	            conn.setRequestProperty("accept", "*/*");
	            conn.setRequestProperty("connection", "Keep-Alive");
	            conn.setRequestProperty("user-agent", "Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1;SV1)");

	            // 发送POST请求必须设置如下两行

	            conn.setDoOutput(true);
	            conn.setDoInput(true);
	            // 获取URLConnection对象对应的输出流
	            out = new PrintWriter(conn.getOutputStream());

	            // 发送请求参数
	            out.print(param);
	            // flush输出流的缓冲
	            out.flush();
	            // 定义BufferedReader输入流来读取URL的响应
	            in = new BufferedReader(new InputStreamReader(conn.getInputStream()));
	            String line;
	            while ((line = in.readLine()) != null) {
	                result += line;
	            }

	        } catch (Exception e) {
	            System.out.println("发送 POST 请求出现异常!" + e);
	            e.printStackTrace();
	        }
	        //使用finally块来关闭输出流、输入流
	        finally {
	            try {
	                if (out != null) {
	                    out.close();
	                }
	                if (in != null) {
	                    in.close();
	                }
	            } catch (IOException ex) {
	                ex.printStackTrace();
	            }
	        }
	        return result;
	    }
	}
	
	class ShortUrlBySuoUtil extends ShortUrlUtil {
		/**
		 * 生成短连接信息
		 */
		public String generateShortUrl(String url) {
			try {
				String apiUrl = "http://a.bbest.me/short/create";
				HttpPost httpost = new HttpPost(apiUrl);
				List<NameValuePair> params = new ArrayList<NameValuePair>();
				params.add(new BasicNameValuePair("format", "utf-8")); 	// 编码
				params.add(new BasicNameValuePair("l", url)); 			// 用户名称
				httpost.setEntity(new UrlEncodedFormEntity(params, "utf-8"));
				HttpResponse response = httpclient.execute(httpost);
				String jsonStr = EntityUtils.toString(response.getEntity(), "utf-8");
				JSONObject jsonResult = JSON.parseObject(jsonStr);
	            String shortUrl = jsonResult.getString("short_url");
				return "http://bbest.me/"+ shortUrl;
			} catch (Exception e) {
				log.info("ShortUrlBySuoUtil", e);
				return "";
			}
		}
	}
 
}
 

 

### HC-05蓝牙模块连接失败解决方案 HC-05蓝牙模块是一种常见的无线通信设备,支持多种工作模式和功能配置。然而,在实际应用中可能会遇到连接失败的情况。以下是针对该问题的具体分析与解决方法。 #### 1. 检查硬件连接 确保HC-05模块与其他设备之间的连线正确无误。通常情况下,HC-05模块需要通过TXD(发送)、RXD(接收)、GND(接地)以及VCC(电源正极)四个引脚进行连接[^1]。如果使用的是USBTTL串口适配器,则需确认其电压等级是否匹配(HC-05一般为3.3V逻辑电平),并避免因过压损坏模块。 #### 2. 验证供电状态 稳定的电源供应对于正常运行至关重要。建议采用独立稳压源向HC-05提供约4~6伏特直流输入,并保证电流充足以满足峰值需求。当发现指示灯闪烁异常或者完全熄灭时,应优先排查是否存在欠压现象[^3]。 #### 3. 设置正确的波特率 默认状态下,HC-05出厂预设的通信速率为9600bps;但在某些特殊场景下可能被调整至其他数值如38400bps甚至更高。因此,在尝试进入命令响应界面之前,请先利用串口调试软件将本地计算机端口速率同步到目标值上再继续操作[^2]。 #### 4. 切换为主/从角色 根据具体应用场景的不同,可以选择让当前使用的HC-05实例扮演主机还是从机身份参与组网活动。需要注意的是并非所有的版本都具备双向切换能力——部分仅限单方向运作的产品无法实现预期效果。可以通过执行`AT+ROLE?`查询现有设定并通过相应参数修改来完成转换过程。 #### 5. 执行重置恢复初始参数 假如上述措施均未能奏效的话,不妨考虑实施硬复位动作使装置回到刚生产出来时候的状态(即清除自定义属性),然后再重新按照官方指导手册逐步定制各项必要选项直至成功建立链路为止。此步骤涉及断开所有外部负载后再短时间同时拉低KEY管脚与地线之间距离触发内部机制生效。 #### 6. 测试基本功能 最后一步就是运用简单的回环测试程序验证整个系统的连贯性和稳定性。比如编写一段Python脚本模拟数据包收发流程: ```python import serial,time ser=serial.Serial('COM7',baudrate=9600,timeout=None) def send_data(data): ser.write((data+'\r\n').encode()) while True: cmd=input("Enter AT command:") if 'exit'==cmd.lower(): break; else : send_data(cmd) time.sleep(.5) # wait half second before reading output. print(repr(ser.read_all())) ser.close() ``` 以上代码片段展示了如何借助PySerial库创建一个基础框架用于交互式探索目的下的实验环境构建。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值