From bd3fb69befd63826975b281bbe23d05622496219 Mon Sep 17 00:00:00 2001 From: Daniel Qian Date: Wed, 27 May 2015 09:18:06 +0800 Subject: [PATCH 1/5] update to 1.1.6-SNAPSHOT --- README.md | 4 ++-- pom.xml | 2 +- weixin-java-common/pom.xml | 2 +- weixin-java-cp/pom.xml | 2 +- weixin-java-mp/pom.xml | 2 +- 5 files changed, 6 insertions(+), 6 deletions(-) diff --git a/README.md b/README.md index f4ea8ca65c..881af49cf8 100644 --- a/README.md +++ b/README.md @@ -17,7 +17,7 @@ weixin-java-tools me.chanjar weixin-java-mp - 1.1.5 + 1.1.6 ``` @@ -27,7 +27,7 @@ weixin-java-tools me.chanjar weixin-java-cp - 1.1.5 + 1.1.6 ``` diff --git a/pom.xml b/pom.xml index 090e4760ff..4511dbc7a3 100644 --- a/pom.xml +++ b/pom.xml @@ -5,7 +5,7 @@ 4.0.0 me.chanjar weixin-java-parent - 1.1.5 + 1.1.6-SNAPSHOT pom WeiXin Java Tools - Parent 微信公众号、企业号上级POM diff --git a/weixin-java-common/pom.xml b/weixin-java-common/pom.xml index b34d29be46..05719571e2 100644 --- a/weixin-java-common/pom.xml +++ b/weixin-java-common/pom.xml @@ -6,7 +6,7 @@ me.chanjar weixin-java-parent - 1.1.5 + 1.1.6-SNAPSHOT weixin-java-common diff --git a/weixin-java-cp/pom.xml b/weixin-java-cp/pom.xml index e7b7501694..beef159fa0 100644 --- a/weixin-java-cp/pom.xml +++ b/weixin-java-cp/pom.xml @@ -6,7 +6,7 @@ me.chanjar weixin-java-parent - 1.1.5 + 1.1.6-SNAPSHOT weixin-java-cp diff --git a/weixin-java-mp/pom.xml b/weixin-java-mp/pom.xml index 3893b1cc0e..29bd515914 100644 --- a/weixin-java-mp/pom.xml +++ b/weixin-java-mp/pom.xml @@ -6,7 +6,7 @@ me.chanjar weixin-java-parent - 1.1.5 + 1.1.6-SNAPSHOT weixin-java-mp WeiXin Java Tools - MP From 622094bcdf8e1dbe3b4e4b06103b206e77cb6226 Mon Sep 17 00:00:00 2001 From: darknesstm Date: Wed, 3 Jun 2015 15:39:06 +0800 Subject: [PATCH 2/5] =?UTF-8?q?=E7=BB=9F=E4=B8=80=E4=BD=BF=E7=94=A8getHttp?= =?UTF-8?q?Client=EF=BC=8C=E4=BD=BF=E5=BE=97=E5=8F=AF=E4=BB=A5=E5=A4=8D?= =?UTF-8?q?=E7=94=A8httpClient?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../main/java/me/chanjar/weixin/mp/api/WxMpServiceImpl.java | 5 ++--- 1 file changed, 2 insertions(+), 3 deletions(-) diff --git a/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/WxMpServiceImpl.java b/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/WxMpServiceImpl.java index 1e08a69f75..ce198b0804 100644 --- a/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/WxMpServiceImpl.java +++ b/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/WxMpServiceImpl.java @@ -108,8 +108,7 @@ public String getAccessToken(boolean forceRefresh) throws WxErrorException { RequestConfig config = RequestConfig.custom().setProxy(httpProxy).build(); httpGet.setConfig(config); } - CloseableHttpClient httpclient = getHttpclient(); - CloseableHttpResponse response = httpclient.execute(httpGet); + CloseableHttpResponse response = getHttpclient().execute(httpGet); String resultContent = new BasicResponseHandler().handleResponse(response); WxError error = WxError.fromJson(resultContent); if (error.getErrorCode() != 0) { @@ -672,7 +671,7 @@ public WxMpPrepayIdResult getPrepayId(String openId, String outTradeNo, double a StringEntity entity = new StringEntity(xml, Consts.UTF_8); httpPost.setEntity(entity); try { - CloseableHttpResponse response = httpClient.execute(httpPost); + CloseableHttpResponse response = getHttpclient().execute(httpPost); String responseContent = Utf8ResponseHandler.INSTANCE.handleResponse(response); XStream xstream = XStreamInitializer.getInstance(); xstream.alias("xml", WxMpPrepayIdResult.class); From 50949b1ff516591f53fdc735d5d23499ba40d1c6 Mon Sep 17 00:00:00 2001 From: huansinho Date: Sun, 14 Jun 2015 01:16:20 +0800 Subject: [PATCH 3/5] =?UTF-8?q?=E5=A2=9E=E5=8A=A0=E5=BF=BD=E7=95=A5eclipse?= =?UTF-8?q?=E6=9C=AC=E5=9C=B0=E9=85=8D=E7=BD=AE=E6=96=87=E4=BB=B6=E7=9B=AE?= =?UTF-8?q?=E5=BD=95?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .gitignore | 45 +++++++++++++++++++++++---------------------- 1 file changed, 23 insertions(+), 22 deletions(-) diff --git a/.gitignore b/.gitignore index 336065509d..66e4038250 100644 --- a/.gitignore +++ b/.gitignore @@ -1,22 +1,23 @@ -*.class -test-output - -# Mobile Tools for Java (J2ME) -.mtj.tmp/ - -# Package Files # -*.jar -*.war -*.ear - -# virtual machine crash logs, see http://www.java.com/en/download/help/error_hotspot.xml -hs_err_pid* - -target -.project -.classpath - -sw-pom.xml -*.iml -test-config.xml -.idea +*.class +test-output + +# Mobile Tools for Java (J2ME) +.mtj.tmp/ + +# Package Files # +*.jar +*.war +*.ear + +# virtual machine crash logs, see http://www.java.com/en/download/help/error_hotspot.xml +hs_err_pid* + +target +.project +.classpath +.settings + +sw-pom.xml +*.iml +test-config.xml +.idea From f107bd2f440cea5ff55f19bccea33fdbe5defccf Mon Sep 17 00:00:00 2001 From: huansinho Date: Sun, 14 Jun 2015 02:37:31 +0800 Subject: [PATCH 4/5] =?UTF-8?q?=E5=A2=9E=E5=8A=A0=E4=B8=B4=E6=97=B6?= =?UTF-8?q?=E6=96=87=E4=BB=B6=E7=9B=AE=E5=BD=95=E9=85=8D=E7=BD=AE?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit 在下载多媒体文件下载时可以指定临时文件目录。 --- .../weixin/common/util/fs/FileUtils.java | 23 +++++++++++++++++-- .../http/MediaDownloadRequestExecutor.java | 14 ++++++++++- .../weixin/cp/api/WxCpConfigStorage.java | 4 ++++ .../cp/api/WxCpInMemoryConfigStorage.java | 13 +++++++++++ .../weixin/cp/api/WxCpServiceImpl.java | 16 ++++++++++++- .../weixin/mp/api/WxMpConfigStorage.java | 5 +++- .../mp/api/WxMpInMemoryConfigStorage.java | 17 ++++++++++++-- .../weixin/mp/api/WxMpServiceImpl.java | 4 +++- 8 files changed, 88 insertions(+), 8 deletions(-) diff --git a/weixin-java-common/src/main/java/me/chanjar/weixin/common/util/fs/FileUtils.java b/weixin-java-common/src/main/java/me/chanjar/weixin/common/util/fs/FileUtils.java index d2ecc42a66..718f33e631 100644 --- a/weixin-java-common/src/main/java/me/chanjar/weixin/common/util/fs/FileUtils.java +++ b/weixin-java-common/src/main/java/me/chanjar/weixin/common/util/fs/FileUtils.java @@ -7,18 +7,25 @@ public class FileUtils { + /** * 创建临时文件 * @param inputStream * @param name 文件名 * @param ext 扩展名 + * @param tmpDirFile 临时文件夹目录 * @return * @throws IOException */ - public static File createTmpFile(InputStream inputStream, String name, String ext) throws IOException { + public static File createTmpFile(InputStream inputStream, String name, String ext, File tmpDirFile) throws IOException { FileOutputStream fos = null; try { - File tmpFile = File.createTempFile(name, '.' + ext); + File tmpFile; + if (tmpDirFile == null) { + tmpFile = File.createTempFile(name, '.' + ext); + } else { + tmpFile = File.createTempFile(name, '.' + ext, tmpDirFile); + } tmpFile.deleteOnExit(); fos = new FileOutputStream(tmpFile); int read = 0; @@ -43,5 +50,17 @@ public static File createTmpFile(InputStream inputStream, String name, String ex } } } + + /** + * 创建临时文件 + * @param inputStream + * @param name 文件名 + * @param ext 扩展名 + * @return + * @throws IOException + */ + public static File createTmpFile(InputStream inputStream, String name, String ext) throws IOException { + return createTmpFile(inputStream, name, ext, null); + } } diff --git a/weixin-java-common/src/main/java/me/chanjar/weixin/common/util/http/MediaDownloadRequestExecutor.java b/weixin-java-common/src/main/java/me/chanjar/weixin/common/util/http/MediaDownloadRequestExecutor.java index dc7f28b4b7..32a7c917c9 100644 --- a/weixin-java-common/src/main/java/me/chanjar/weixin/common/util/http/MediaDownloadRequestExecutor.java +++ b/weixin-java-common/src/main/java/me/chanjar/weixin/common/util/http/MediaDownloadRequestExecutor.java @@ -25,6 +25,18 @@ * */ public class MediaDownloadRequestExecutor implements RequestExecutor { + + private File tmpDirFile; + + public MediaDownloadRequestExecutor() { + super(); + } + + public MediaDownloadRequestExecutor(File tmpDirFile) { + super(); + this.tmpDirFile = tmpDirFile; + } + @Override public File execute(CloseableHttpClient httpclient, HttpHost httpProxy, String uri, String queryParam) throws WxErrorException, ClientProtocolException, IOException { @@ -59,7 +71,7 @@ public File execute(CloseableHttpClient httpclient, HttpHost httpProxy, String u return null; } String[] name_ext = fileName.split("\\."); - File localFile = FileUtils.createTmpFile(inputStream, name_ext[0], name_ext[1]); + File localFile = FileUtils.createTmpFile(inputStream, name_ext[0], name_ext[1], tmpDirFile); return localFile; } diff --git a/weixin-java-cp/src/main/java/me/chanjar/weixin/cp/api/WxCpConfigStorage.java b/weixin-java-cp/src/main/java/me/chanjar/weixin/cp/api/WxCpConfigStorage.java index 94029841dc..f5fca81a72 100644 --- a/weixin-java-cp/src/main/java/me/chanjar/weixin/cp/api/WxCpConfigStorage.java +++ b/weixin-java-cp/src/main/java/me/chanjar/weixin/cp/api/WxCpConfigStorage.java @@ -1,5 +1,7 @@ package me.chanjar.weixin.cp.api; +import java.io.File; + import me.chanjar.weixin.common.bean.WxAccessToken; /** @@ -58,5 +60,7 @@ public interface WxCpConfigStorage { public String getHttp_proxy_username(); public String getHttp_proxy_password(); + + public File getTmpDirFile(); } diff --git a/weixin-java-cp/src/main/java/me/chanjar/weixin/cp/api/WxCpInMemoryConfigStorage.java b/weixin-java-cp/src/main/java/me/chanjar/weixin/cp/api/WxCpInMemoryConfigStorage.java index 59fc6f2a16..638deb6b1a 100644 --- a/weixin-java-cp/src/main/java/me/chanjar/weixin/cp/api/WxCpInMemoryConfigStorage.java +++ b/weixin-java-cp/src/main/java/me/chanjar/weixin/cp/api/WxCpInMemoryConfigStorage.java @@ -1,5 +1,7 @@ package me.chanjar.weixin.cp.api; +import java.io.File; + import me.chanjar.weixin.common.bean.WxAccessToken; /** @@ -28,6 +30,8 @@ public class WxCpInMemoryConfigStorage implements WxCpConfigStorage { protected volatile String jsapiTicket; protected volatile long jsapiTicketExpiresTime; + protected volatile File tmpDirFile; + public String getAccessToken() { return this.accessToken; } @@ -189,7 +193,16 @@ public String toString() { ", http_proxy_password='" + http_proxy_password + '\'' + ", jsapiTicket='" + jsapiTicket + '\'' + ", jsapiTicketExpiresTime='" + jsapiTicketExpiresTime + '\'' + + ", tmpDirFile='" + tmpDirFile + '\'' + '}'; } + public File getTmpDirFile() { + return tmpDirFile; + } + + public void setTmpDirFile(File tmpDirFile) { + this.tmpDirFile = tmpDirFile; + } + } diff --git a/weixin-java-cp/src/main/java/me/chanjar/weixin/cp/api/WxCpServiceImpl.java b/weixin-java-cp/src/main/java/me/chanjar/weixin/cp/api/WxCpServiceImpl.java index 0ef29b55f1..4469db0157 100644 --- a/weixin-java-cp/src/main/java/me/chanjar/weixin/cp/api/WxCpServiceImpl.java +++ b/weixin-java-cp/src/main/java/me/chanjar/weixin/cp/api/WxCpServiceImpl.java @@ -78,6 +78,11 @@ public class WxCpServiceImpl implements WxCpService { protected WxSessionManager sessionManager = new StandardSessionManager(); + /** + * 临时文件目录 + */ + protected File tmpDirFile; + public boolean checkSignature(String msgSignature, String timestamp, String nonce, String data) { try { return SHA1.gen(wxCpConfigStorage.getToken(), timestamp, nonce, data).equals(msgSignature); @@ -236,7 +241,8 @@ public WxMediaUploadResult mediaUpload(String mediaType, File file) throws WxErr public File mediaDownload(String media_id) throws WxErrorException { String url = "https://qyapi.weixin.qq.com/cgi-bin/media/get"; - return execute(new MediaDownloadRequestExecutor(), url, "media_id=" + media_id); + + return execute(new MediaDownloadRequestExecutor(wxCpConfigStorage.getTmpDirFile()), url, "media_id=" + media_id); } @@ -638,6 +644,14 @@ public WxSession getSession(String id, boolean create) { public void setSessionManager(WxSessionManager sessionManager) { this.sessionManager = sessionManager; } + + public File getTmpDirFile() { + return tmpDirFile; + } + + public void setTmpDirFile(File tmpDirFile) { + this.tmpDirFile = tmpDirFile; + } public static void main(String[] args) { Float a = 3.1f; diff --git a/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/WxMpConfigStorage.java b/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/WxMpConfigStorage.java index 46d58bc379..3ee436595d 100644 --- a/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/WxMpConfigStorage.java +++ b/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/WxMpConfigStorage.java @@ -1,5 +1,7 @@ package me.chanjar.weixin.mp.api; +import java.io.File; + import me.chanjar.weixin.common.bean.WxAccessToken; /** @@ -68,7 +70,8 @@ public interface WxMpConfigStorage { public String getHttp_proxy_username(); - public String getHttp_proxy_password(); + + public File getTmpDirFile(); } diff --git a/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/WxMpInMemoryConfigStorage.java b/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/WxMpInMemoryConfigStorage.java index c14241f418..45adc4fe76 100644 --- a/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/WxMpInMemoryConfigStorage.java +++ b/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/WxMpInMemoryConfigStorage.java @@ -1,5 +1,7 @@ package me.chanjar.weixin.mp.api; +import java.io.File; + import me.chanjar.weixin.common.bean.WxAccessToken; /** @@ -11,8 +13,8 @@ public class WxMpInMemoryConfigStorage implements WxMpConfigStorage { protected volatile String appId; protected volatile String secret; - protected volatile String partnerId; - protected volatile String partnerKey; + protected volatile String partnerId; + protected volatile String partnerKey; protected volatile String token; protected volatile String accessToken; protected volatile String aesKey; @@ -28,6 +30,11 @@ public class WxMpInMemoryConfigStorage implements WxMpConfigStorage { protected volatile String jsapiTicket; protected volatile long jsapiTicketExpiresTime; + /** + * 临时文件目录 + */ + protected volatile File tmpDirFile; + public String getAccessToken() { return this.accessToken; } @@ -181,6 +188,7 @@ public String toString() { ", http_proxy_password='" + http_proxy_password + '\'' + ", jsapiTicket='" + jsapiTicket + '\'' + ", jsapiTicketExpiresTime='" + jsapiTicketExpiresTime + '\'' + + ", tmpDirFile='" + tmpDirFile + '\'' + '}'; } @@ -201,4 +209,9 @@ public String getPartnerKey() { public void setPartnerKey(String partnerKey) { this.partnerKey = partnerKey; } + + @Override + public File getTmpDirFile() { + return this.getTmpDirFile(); + } } diff --git a/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/WxMpServiceImpl.java b/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/WxMpServiceImpl.java index 1e08a69f75..ca054af062 100644 --- a/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/WxMpServiceImpl.java +++ b/weixin-java-mp/src/main/java/me/chanjar/weixin/mp/api/WxMpServiceImpl.java @@ -7,6 +7,7 @@ import com.google.gson.reflect.TypeToken; import com.google.gson.stream.JsonReader; import com.thoughtworks.xstream.XStream; + import me.chanjar.weixin.common.bean.WxAccessToken; import me.chanjar.weixin.common.bean.WxMenu; import me.chanjar.weixin.common.bean.WxJsapiSignature; @@ -27,6 +28,7 @@ import me.chanjar.weixin.mp.bean.result.*; import me.chanjar.weixin.mp.util.http.QrCodeRequestExecutor; import me.chanjar.weixin.mp.util.json.WxMpGsonBuilder; + import org.apache.http.Consts; import org.apache.http.HttpHost; import org.apache.http.auth.AuthScope; @@ -214,7 +216,7 @@ public WxMediaUploadResult mediaUpload(String mediaType, File file) throws WxErr public File mediaDownload(String media_id) throws WxErrorException { String url = "http://file.api.weixin.qq.com/cgi-bin/media/get"; - return execute(new MediaDownloadRequestExecutor(), url, "media_id=" + media_id); + return execute(new MediaDownloadRequestExecutor(wxMpConfigStorage.getTmpDirFile()), url, "media_id=" + media_id); } public WxMpMassUploadResult massNewsUpload(WxMpMassNews news) throws WxErrorException { From 0491e234565a2bbac49e26a18d18a2fcb295c0a4 Mon Sep 17 00:00:00 2001 From: Daniel Qian Date: Fri, 26 Jun 2015 16:38:08 +0800 Subject: [PATCH 5/5] upgrade to 1.1.6 --- pom.xml | 2 +- weixin-java-common/pom.xml | 2 +- weixin-java-cp/pom.xml | 2 +- weixin-java-mp/pom.xml | 2 +- 4 files changed, 4 insertions(+), 4 deletions(-) diff --git a/pom.xml b/pom.xml index 4511dbc7a3..276d4a6946 100644 --- a/pom.xml +++ b/pom.xml @@ -5,7 +5,7 @@ 4.0.0 me.chanjar weixin-java-parent - 1.1.6-SNAPSHOT + 1.1.6 pom WeiXin Java Tools - Parent 微信公众号、企业号上级POM diff --git a/weixin-java-common/pom.xml b/weixin-java-common/pom.xml index 05719571e2..194cfa6f09 100644 --- a/weixin-java-common/pom.xml +++ b/weixin-java-common/pom.xml @@ -6,7 +6,7 @@ me.chanjar weixin-java-parent - 1.1.6-SNAPSHOT + 1.1.6 weixin-java-common diff --git a/weixin-java-cp/pom.xml b/weixin-java-cp/pom.xml index beef159fa0..607d4cd245 100644 --- a/weixin-java-cp/pom.xml +++ b/weixin-java-cp/pom.xml @@ -6,7 +6,7 @@ me.chanjar weixin-java-parent - 1.1.6-SNAPSHOT + 1.1.6 weixin-java-cp diff --git a/weixin-java-mp/pom.xml b/weixin-java-mp/pom.xml index 29bd515914..04d162327e 100644 --- a/weixin-java-mp/pom.xml +++ b/weixin-java-mp/pom.xml @@ -6,7 +6,7 @@ me.chanjar weixin-java-parent - 1.1.6-SNAPSHOT + 1.1.6 weixin-java-mp WeiXin Java Tools - MP