/* /** * 网络请求工具类 * @author 阿福 * */ public class HttpUtils { public final static HttpCache sHttpCache = new HttpCache(); private final DefaultHttpClient httpClient; private final HttpContext httpContext = new BasicHttpContext(); private HttpRedirectHandler httpRedirectHandler; /** * 构造方法,默认联网15秒超时 */ public HttpUtils() { this(HttpUtils.DEFAULT_CONN_TIMEOUT, null); } /** * 构造方法设置超时时间 * @param connTimeout 超时时间毫秒 */ public HttpUtils(int connTimeout) { this(connTimeout, null); } /** * 构造方法,浏览器的信息包 * @param userAgent */ public HttpUtils(String userAgent) { this(HttpUtils.DEFAULT_CONN_TIMEOUT, userAgent); } /** * 构造方法 * @param connTimeout 链接超时时间,毫秒单位 * @param userAgent 浏览器的信息包 */ public HttpUtils(int connTimeout, String userAgent) { HttpParams params = new BasicHttpParams(); ConnManagerParams.setTimeout(params, connTimeout); HttpConnectionParams.setSoTimeout(params, connTimeout); HttpConnectionParams.setConnectionTimeout(params, connTimeout); if (TextUtils.isEmpty(userAgent)) { userAgent = OtherUtils.getUserAgent(null); } HttpProtocolParams.setUserAgent(params, userAgent); ConnManagerParams.setMaxConnectionsPerRoute(params, new ConnPerRouteBean(10)); ConnManagerParams.setMaxTotalConnections(params, 10); HttpConnectionParams.setTcpNoDelay(params, true); HttpConnectionParams.setSocketBufferSize(params, 1024 * 8); HttpProtocolParams.setVersion(params, HttpVersion.HTTP_1_1); SchemeRegistry schemeRegistry = new SchemeRegistry(); schemeRegistry.register(new Scheme("http", PlainSocketFactory.getSocketFactory(), 80)); schemeRegistry.register(new Scheme("https", DefaultSSLSocketFactory.getSocketFactory(), 443)); httpClient = new DefaultHttpClient(new ThreadSafeClientConnManager(params, schemeRegistry), params); httpClient.setHttpRequestRetryHandler(new RetryHandler(DEFAULT_RETRY_TIMES)); httpClient.addRequestInterceptor(new HttpRequestInterceptor() { @Override public void process(org.apache.http.HttpRequest httpRequest, HttpContext httpContext) throws org.apache.http.HttpException, IOException { if (!httpRequest.containsHeader(HEADER_ACCEPT_ENCODING)) { httpRequest.addHeader(HEADER_ACCEPT_ENCODING, ENCODING_GZIP); } } }); httpClient.addResponseInterceptor(new HttpResponseInterceptor() { @Override public void process(HttpResponse response, HttpContext httpContext) throws org.apache.http.HttpException, IOException { final HttpEntity entity = response.getEntity(); if (entity == null) { return; } final Header encoding = entity.getContentEncoding(); if (encoding != null) { for (HeaderElement element : encoding.getElements()) { if (element.getName().equalsIgnoreCase("gzip")) { response.setEntity(new GZipDecompressingEntity(response.getEntity())); return; } } } } }); } // ************************************ default settings & fields **************************** private String responseTextCharset = HTTP.UTF_8; private long currentRequestExpiry = HttpCache.getDefaultExpiryTime(); private final static int DEFAULT_CONN_TIMEOUT = 1000 * 15; // 15s private final static int DEFAULT_RETRY_TIMES = 3; private static final String HEADER_ACCEPT_ENCODING = "Accept-Encoding"; private static final String ENCODING_GZIP = "gzip"; private final static int DEFAULT_POOL_SIZE = 3; private final static PriorityExecutor EXECUTOR = new PriorityExecutor(DEFAULT_POOL_SIZE); public HttpClient getHttpClient() { return this.httpClient; } // ***************************************** config ******************************************* /** * 配置请求文本编码,默认UTF-8 * @param charSet * @return */ public HttpUtils configResponseTextCharset(String charSet) { if (!TextUtils.isEmpty(charSet)) { this.responseTextCharset = charSet; } return this; } /** * http重定向处理 * @param httpRedirectHandler * @return */ public HttpUtils configHttpRedirectHandler(HttpRedirectHandler httpRedirectHandler) { this.httpRedirectHandler = httpRedirectHandler; return this; } /** * 配置http缓存大小 * @param httpCacheSize * @return */ public HttpUtils configHttpCacheSize(int httpCacheSize) { sHttpCache.setCacheSize(httpCacheSize); return this; } /** * 配置默认http缓存失效 ,默认是60秒 * @param defaultExpiry * @return */ public HttpUtils configDefaultHttpCacheExpiry(long defaultExpiry) { HttpCache.setDefaultExpiryTime(defaultExpiry); currentRequestExpiry = HttpCache.getDefaultExpiryTime(); return this; } /** * 配置当前http缓存失效,时间默认60秒 * @param currRequestExpiry * @return */ public HttpUtils configCurrentHttpCacheExpiry(long currRequestExpiry) { this.currentRequestExpiry = currRequestExpiry; return this; } /** * cookie存储配置 * @param cookieStore * @return */ public HttpUtils configCookieStore(CookieStore cookieStore) { httpContext.setAttribute(ClientContext.COOKIE_STORE, cookieStore); return this; } /** * 配置浏览器信息包 * @param userAgent * @return */ public HttpUtils configUserAgent(String userAgent) { HttpProtocolParams.setUserAgent(this.httpClient.getParams(), userAgent); return this; } /** * 配置时间链接超时 * @param timeout * @return */ public HttpUtils configTimeout(int timeout) { final HttpParams httpParams = this.httpClient.getParams(); ConnManagerParams.setTimeout(httpParams, timeout); HttpConnectionParams.setConnectionTimeout(httpParams, timeout); return this; } /** * 配置socket时间连接溢出 * @param timeout * @return */ public HttpUtils configSoTimeout(int timeout) { final HttpParams httpParams = this.httpClient.getParams(); HttpConnectionParams.setSoTimeout(httpParams, timeout); return this; } /** * 配置注册Scheme * @param scheme * @return */ public HttpUtils configRegisterScheme(Scheme scheme) { this.httpClient.getConnectionManager().getSchemeRegistry().register(scheme); return this; } /** * 配置SSLSocketFactory * @param sslSocketFactory * @return */ public HttpUtils configSSLSocketFactory(SSLSocketFactory sslSocketFactory) { Scheme scheme = new Scheme("https", sslSocketFactory, 443); this.httpClient.getConnectionManager().getSchemeRegistry().register(scheme); return this; } /** * 配置请求重试次数 * @param count 重试次数 * @return */ public HttpUtils configRequestRetryCount(int count) { this.httpClient.setHttpRequestRetryHandler(new RetryHandler(count)); return this; } /** * 配置请求线程池个数 * @param threadPoolSize 线程池个数 * @return */ public HttpUtils configRequestThreadPoolSize(int threadPoolSize) { HttpUtils.EXECUTOR.setPoolSize(threadPoolSize); return this; } // ***************************************** send request 发送请求******************************************* /** * 发送异步网络请求 -重要 * @param method get或者post请求等等 * @param url 网络请求路径 * @param callBack 回调 * @return */ public <T> HttpHandler<T> send(HttpRequest.HttpMethod method, String url, RequestCallBack<T> callBack) { return send(method, url, null, callBack); } /** * 发送异步网络请求 -重要 * @param method get或者post请求等等 * @param url 网络请求路径 * @param params 请求参数 * @param callBack 回调 * @return */ public <T> HttpHandler<T> send(HttpRequest.HttpMethod method, String url, RequestParams params, RequestCallBack<T> callBack) { if (url == null) throw new IllegalArgumentException("url may not be null"); HttpRequest request = new HttpRequest(method, url); return sendRequest(request, params, callBack); } /** * 发送同步网络请求 -用得不多 * @param method get或者post等方法 * @param url 联网网络url * @return * @throws HttpException */ public ResponseStream sendSync(HttpRequest.HttpMethod method, String url) throws HttpException { return sendSync(method, url, null); } /** * 发送同步网络请求 -用得不多 * @param method get或者post等方法 * @param url 联网网络url * @param params 请求参数 * @return * @throws HttpException */ public ResponseStream sendSync(HttpRequest.HttpMethod method, String url, RequestParams params) throws HttpException { if (url == null) throw new IllegalArgumentException("url may not be null"); HttpRequest request = new HttpRequest(method, url); return sendSyncRequest(request, params); } // ***************************************** download 下载******************************************* /** * 下载文件方法 * @param url 下载文件的url * @param target 下载保存的目录 * @param callback 回调 * @return */ public HttpHandler<File> download(String url, String target, RequestCallBack<File> callback) { return download(HttpRequest.HttpMethod.GET, url, target, null, false, false, callback); } /** * 下载文件方法 * @param url 下载文件的url * @param target 下载保存的目录 * @param autoResume 是否自动恢复下载 * @param callback 回调 * @return */ public HttpHandler<File> download(String url, String target, boolean autoResume, RequestCallBack<File> callback) { return download(HttpRequest.HttpMethod.GET, url, target, null, autoResume, false, callback); } /** * 下载文件方法 * @param url 下载文件的url * @param target 下载保存的目录 * @param autoResume 是否自动恢复下载 * @param autoRename 是否自动重命名 * @param callback 回调 * @return */ public HttpHandler<File> download(String url, String target, boolean autoResume, boolean autoRename, RequestCallBack<File> callback) { return download(HttpRequest.HttpMethod.GET, url, target, null, autoResume, autoRename, callback); } /** * 下载文件方法 * @param url 下载文件的url * @param target 下载保存的目录 * @param params 参数类 * @param callback 回调 * @return */ public HttpHandler<File> download(String url, String target, RequestParams params, RequestCallBack<File> callback) { return download(HttpRequest.HttpMethod.GET, url, target, params, false, false, callback); } /** * 下载文件方法 * @param url 下载文件的url * @param target 下载保存的目录 * @param params 参数类 * @param autoResume 是否自动恢复下载 * @param callback 回调 * @return */ public HttpHandler<File> download(String url, String target, RequestParams params, boolean autoResume, RequestCallBack<File> callback) { return download(HttpRequest.HttpMethod.GET, url, target, params, autoResume, false, callback); } /** * 下载文件方法 * @param url 下载文件的url * @param target 下载保存的目录 * @param params 参数 * @param autoResume 是否自动恢复 * @param autoRename 是否自动命名 * @param callback 回调 * @return */ public HttpHandler<File> download(String url, String target, RequestParams params, boolean autoResume, boolean autoRename, RequestCallBack<File> callback) { return download(HttpRequest.HttpMethod.GET, url, target, params, autoResume, autoRename, callback); } /** * 下载文件方法 * @param method 请求用get还是post等 * @param url 下载文件的url * @param target 下载保存的目录 * @param params 参数 * @param callback 回调 * @return */ public HttpHandler<File> download(HttpRequest.HttpMethod method, String url, String target, RequestParams params, RequestCallBack<File> callback) { return download(method, url, target, params, false, false, callback); } /** * 下载文件方法 * @param method 请求用get还是post等 * @param url 下载文件的url * @param target 下载保存的目录 * @param params 参数 * @param autoResume 是否自动恢复下载 * @param callback 回调 * @return */ public HttpHandler<File> download(HttpRequest.HttpMethod method, String url, String target, RequestParams params, boolean autoResume, RequestCallBack<File> callback) { return download(method, url, target, params, autoResume, false, callback); } /** * 下载文件方法 * @param method 请求用get还是post等 * @param url 下载文件的url * @param target 下载保存的目录 * @param params 参数 * @param autoResume 是否自动恢复下载 * @param autoRename 是否自动重命名 * @param callback 回调 * @return */ public HttpHandler<File> download(HttpRequest.HttpMethod method, String url, String target, RequestParams params, boolean autoResume, boolean autoRename, RequestCallBack<File> callback) { if (url == null) throw new IllegalArgumentException("url may not be null"); if (target == null) throw new IllegalArgumentException("target may not be null"); HttpRequest request = new HttpRequest(method, url); HttpHandler<File> handler = new HttpHandler<File>(httpClient, httpContext, responseTextCharset, callback); handler.setExpiry(currentRequestExpiry); handler.setHttpRedirectHandler(httpRedirectHandler); if (params != null) { request.setRequestParams(params, handler); handler.setPriority(params.getPriority()); } handler.executeOnExecutor(EXECUTOR, request, target, autoResume, autoRename); return handler; } //////////////////////////////////////////////////////////////////////////////////////////////// private <T> HttpHandler<T> sendRequest(HttpRequest request, RequestParams params, RequestCallBack<T> callBack) { HttpHandler<T> handler = new HttpHandler<T>(httpClient, httpContext, responseTextCharset, callBack); handler.setExpiry(currentRequestExpiry); handler.setHttpRedirectHandler(httpRedirectHandler); request.setRequestParams(params, handler); if (params != null) { handler.setPriority(params.getPriority()); } handler.executeOnExecutor(EXECUTOR, request); return handler; } private ResponseStream sendSyncRequest(HttpRequest request, RequestParams params) throws HttpException { SyncHttpHandler handler = new SyncHttpHandler(httpClient, httpContext, responseTextCharset); handler.setExpiry(currentRequestExpiry); handler.setHttpRedirectHandler(httpRedirectHandler); request.setRequestParams(params); return handler.sendRequest(request); } }
相关推荐
5. **资源管理**:Xutils3还提供了Utils类,它包含了各种通用的工具方法,如字符串处理、日期格式化等,方便开发者进行日常的资源管理和操作。 6. **注解驱动**:Xutils3大量使用了注解,如@Table用于定义数据库表...
在IT行业中,工具类(Utils Class)是一种常见的编程实践,用于封装一组静态方法,这些方法在各种场景下都能提供便利的功能。"日常用的工具类"这个标题暗示了这是一个包含了日常开发中常用功能的集合,可能包括字符...
在Android应用开发中,工具类(Utils类)是开发者经常使用的辅助组件,它们通常包含了一系列静态方法,用于处理各种常见的任务,从而提高代码的复用性和可维护性。本篇文章将详细探讨Android开发中常用的工具类及其...
在Java Android开发中,工具类(Utils类)是开发者经常使用的辅助代码集合,它们封装了一些通用功能,方便在多个类中复用,提高代码的可维护性和可读性。以下是一些常见的Java Android工具类及其包含的知识点: 1. ...
内容概要:本文详细介绍了一种基于STM32单片机的数控线性稳压电源设计方案。该电源采用220V市电输入,经过工频变压器降压、全桥整流及电容滤波,最终输出稳定的直流电压。设计中采用了线性稳压调整器方案,通过STM32单片机控制TLC5615数模转换器,实现了电压的数控调整。系统具备恒压恒流输出、过流保护、温度监测等功能,并配有LCD1602显示屏和声光报警装置。所有设计资料(源程序、原理图、PCB)均经过验证,具有较高的学习和设计参考价值。 适合人群:电子工程专业学生、嵌入式系统开发者、硬件工程师。 使用场景及目标:适用于实验室、工业自动化等领域,需要稳定电源供应的场合。目标是帮助读者理解和掌握基于STM32的数控线性稳压电源设计方法,提高电源系统的可靠性和安全性。 其他说明:文中提供的设计资料详尽完整,有助于读者深入理解每个环节的工作原理和技术细节。
LeddarTech客户案例研究.pdf
# 压缩文件中包含: 中文文档 jar包下载地址 Maven依赖 Gradle依赖 源代码下载地址 # 本文件关键字: jar中文文档.zip,java,jar包,Maven,第三方jar包,组件,开源组件,第三方组件,Gradle,中文API文档,手册,开发手册,使用手册,参考手册 # 使用方法: 解压最外层zip,再解压其中的zip包,双击 【index.html】 文件,即可用浏览器打开、进行查看。 # 特殊说明: ·本文档为人性化翻译,精心制作,请放心使用。 ·只翻译了该翻译的内容,如:注释、说明、描述、用法讲解 等; ·不该翻译的内容保持原样,如:类名、方法名、包名、类型、关键字、代码 等。 # 温馨提示: (1)为了防止解压后路径太长导致浏览器无法打开,推荐在解压时选择“解压到当前文件夹”(放心,自带文件夹,文件不会散落一地); (2)有时,一套Java组件会有多个jar,所以在下载前,请仔细阅读本篇描述,以确保这就是你需要的文件;
毕业论文-手机壁纸-整站商业源码.zip
毕业论文-二手跳蚤市场V5.4.1带微信支付、广告插件-整站商业源码.zip
毕业论文-体育新闻-整站商业源码.zip
# 压缩文件中包含: 中文文档 jar包下载地址 Maven依赖 Gradle依赖 源代码下载地址 # 本文件关键字: jar中文文档.zip,java,jar包,Maven,第三方jar包,组件,开源组件,第三方组件,Gradle,中文API文档,手册,开发手册,使用手册,参考手册 # 使用方法: 解压最外层zip,再解压其中的zip包,双击 【index.html】 文件,即可用浏览器打开、进行查看。 # 特殊说明: ·本文档为人性化翻译,精心制作,请放心使用。 ·只翻译了该翻译的内容,如:注释、说明、描述、用法讲解 等; ·不该翻译的内容保持原样,如:类名、方法名、包名、类型、关键字、代码 等。 # 温馨提示: (1)为了防止解压后路径太长导致浏览器无法打开,推荐在解压时选择“解压到当前文件夹”(放心,自带文件夹,文件不会散落一地); (2)有时,一套Java组件会有多个jar,所以在下载前,请仔细阅读本篇描述,以确保这就是你需要的文件;
傅里叶变换函数,Matlab脚本,可以直接调用
内容概要:本文档是2016年TI杯大学生电子设计竞赛G题——简易电子秤的设计要求与评分标准。任务要求设计并制作一个以电阻应变片为称重传感器的简易电子秤,其支架高度不超过40cm,悬臂梁上粘贴电阻应变片。具体要求包括:能以克为单位显示重量(10分),称重范围5.00g~500g且误差控制在特定范围内(50分),可设置单价并计算物品金额及累加(15分),具有去皮功能(15分),以及附加功能(10分)。设计报告涵盖方案论证、理论分析、电路与程序设计、测试方案及结果、报告结构及规范性(共20分)。此外,强调称重传感装置需自制,测试时以砝码为标准。 适合人群:电子工程及相关专业的学生或对电子设计有兴趣的学习者,尤其是准备参加类似竞赛的学生。 使用场景及目标:用于指导参赛选手完成竞赛作品,帮助他们理解竞赛的具体要求、评分细则,从而有针对性地进行设计与制作,确保作品符合竞赛规则。 其他说明:文档不仅提供了详细的任务要求,还明确了评分标准,有助于参赛者全面把握设计重点,合理分配时间和精力。同时,对于非参赛者而言,也是一个很好的学习案例,有助于了解电子秤的工作原理及设计思路。
灭火器识别数据集,识别率99.5%,分别率640x640,127张训练图,支持yolov7格式的标注框
# 压缩文件中包含: 中文-英文对照文档 jar包下载地址 Maven依赖 Gradle依赖 源代码下载地址 # 本文件关键字: jar中文-英文对照文档.zip,java,jar包,Maven,第三方jar包,组件,开源组件,第三方组件,Gradle,中文API文档,手册,开发手册,使用手册,参考手册 # 使用方法: 解压最外层zip,再解压其中的zip包,双击 【index.html】 文件,即可用浏览器打开、进行查看。 # 特殊说明: ·本文档为人性化翻译,精心制作,请放心使用。 ·只翻译了该翻译的内容,如:注释、说明、描述、用法讲解 等; ·不该翻译的内容保持原样,如:类名、方法名、包名、类型、关键字、代码 等。 # 温馨提示: (1)为了防止解压后路径太长导致浏览器无法打开,推荐在解压时选择“解压到当前文件夹”(放心,自带文件夹,文件不会散落一地); (2)有时,一套Java组件会有多个jar,所以在下载前,请仔细阅读本篇描述,以确保这就是你需要的文件;
内容概要:本文详细介绍了三相模块化多电平转换器(MMC)在开环控制环境下的运行机制和技术细节。首先,文章解释了MMC的基本概念,强调其高电压等级、模块化设计和灵活的拓扑结构。接着,阐述了开环控制策略,尤其是PWM脉冲发生器的作用,它根据预设的电压和电流参考值生成PWM信号,用于控制各子模块的通断状态。然后,描述了每个臂由四个功率模块组成的子模块与功率配置,确保电能的高效转换。再者,讨论了MMC与RLC结构或更大电网的连接方法,使其能够模拟不同负载条件并提供稳定电力输出。最后,介绍了示波器的应用,通过实时监测关键参数来评估和优化MMC的性能。 适合人群:从事电力电子领域的研究人员、工程师和技术爱好者。 使用场景及目标:适用于希望深入了解MMC工作原理及其在实际电力系统中应用的专业人士。目标是掌握MMC的设计、控制和优化方法,提高电力转换效率和稳定性。 其他说明:本文提供了丰富的理论背景和技术细节,对于理解和应用MMC技术具有重要指导意义。
基于python+NSGA2算法的供水管网水质监测点布局+源码+项目文档,适合毕业设计、课程设计、项目开发。项目源码已经过严格测试,可以放心参考并在此基础上延申使用,详情见md文档 供水管网水质监测点/传感器布局优化 1.基于整数编码的NSGA2算法 2.最短监测时间与最大监测概率双目标函数 3.使用基于epanet的wntr库进行水力水质模拟,并处理结果 4.将处理结果代入NSGA2算法, 迭代计算出结果 5. 所有功能基本实现, 流程基本可以走通 程序概述 本程序主要是解决供水管网水质监测点的布局优化问题; 面向的是突发污染情况下的水质监测点选取,因此需要多节点进行水质污染注入实验; 之前的做法都是使用epanet的程序包,链接库,但USEPA之后开源了基于Python的水力水质模拟库WNTR; 因此本程序使用了WNTR进行水力水质模拟,编写了水质模拟、数据处理模块;用于解决污染实验的实现与数据收集处理; 由于选择监测点是布局优化问题,因此使用了常见的进化算法NSGA2——非支配遗传算法; 水质监测布局常用的目标是最小化监测时间和最大化监测事件,即一组监测点尽可能对污染事件发生响应最快,对污染事件监测到的数量最多即为最优,但两个目标属于负相关。 有关帕累托解、NGSA2算法请自行搜索其他资料。 本程序实现了水质模拟、数据处理、算法迭代的全部过程。
内容概要:本文详细探讨了双馈风机(DFIG)低电压穿越(LVRT)能力的MATLAB仿真模型。首先介绍了转子侧变换器的控制策略,采用了基于定子电压定向的矢量控制方法,实现了有功无功解耦,并具备最大功率跟踪(MPPT)能力。其次,网侧变换器则采用电网电压定向的矢量控制策略,确保直流母线电压稳定,输入功率因数为1。此外,还深入解析了Crowbar电路的设计及其保护机制,当直流母线电压或转子电流超出设定阈值时,Crowbar电路将启动,防止系统损坏。仿真模型分为三层架构:风速模型和机械传动链、双PWM变流器控制层、电网故障模拟模块。最终通过仿真验证了系统的稳定性和有效性。 适合人群:从事风电系统设计、电力电子控制、MATLAB仿真等相关领域的工程师和技术人员。 使用场景及目标:适用于需要理解和优化双馈风机低电压穿越特性的研究人员和工程师。主要目标是掌握DFIG的LVRT控制策略,特别是矢量控制和Crowbar电路的工作原理,从而提高系统的可靠性和稳定性。 其他说明:文中提供了具体的MATLAB代码片段,帮助读者更好地理解各个控制环节的具体实现。调试过程中需要注意PI参数的设置和各控制环之间的参数匹配,以确保系统的最佳性能。
汽车轮胎识别数据集,837张训练图 识别率99.5%,支持yolov5格式的标注
内容概要:本文详细介绍了脉振方波HFI(高频注入模型)的技术背景及其在TI283x系列处理器上的实现方法。首先阐述了脉振方波HFI的基本概念和技术优势,接着展示了如何用C语言编写模型代码来生成和调制脉振方波信号。随后,利用Matlab进行了详细的仿真实验,包括创建仿真环境、定义参数、生成信号、配置仿真逻辑以及最终的数据分析。通过这一系列操作,不仅加深了对脉振方波HFI的理解,还验证了模型的有效性和可行性。 适合人群:从事高频信号处理、嵌入式系统开发的研究人员和技术爱好者,尤其是那些希望深入了解脉振方波HFI机制的人士。 使用场景及目标:适用于需要研究或开发高频注入技术的实际项目中,帮助开发者掌握从理论到实践的具体流程,提高技术水平。 其他说明:文中提供的代码片段和仿真步骤均经过测试,确保能够正常运行并得到预期效果。同时,附带的相关文档也为进一步学习提供了丰富的参考资料。