Commit 1a4476e9 authored by 宋帮潮's avatar 宋帮潮

'sbc'

parent 3f6f81a9
...@@ -2,16 +2,15 @@ ...@@ -2,16 +2,15 @@
<classpath> <classpath>
<classpathentry kind="src" path="src"/> <classpathentry kind="src" path="src"/>
<classpathentry kind="con" path="org.eclipse.jdt.launching.JRE_CONTAINER/org.eclipse.jdt.internal.debug.ui.launcher.StandardVMType/JavaSE-1.6"/> <classpathentry kind="con" path="org.eclipse.jdt.launching.JRE_CONTAINER/org.eclipse.jdt.internal.debug.ui.launcher.StandardVMType/JavaSE-1.6"/>
<classpathentry kind="lib" path="lib/json-lib-2.3-jdk15.jar"/>
<classpathentry kind="lib" path="lib/classes12.jar"/> <classpathentry kind="lib" path="lib/classes12.jar"/>
<classpathentry kind="lib" path="lib/commons-beanutils.jar"/> <classpathentry kind="lib" path="lib/commons-beanutils.jar"/>
<classpathentry kind="lib" path="lib/ezmorph-1.0.jar"/>
<classpathentry kind="lib" path="lib/json-lib-2.3-jdk15.jar"/>
<classpathentry kind="lib" path="lib/commons-httpclient-3.1.jar"/>
<classpathentry kind="lib" path="lib/commons-codec-1.4.jar"/> <classpathentry kind="lib" path="lib/commons-codec-1.4.jar"/>
<classpathentry kind="lib" path="lib/commons-collections.jar"/> <classpathentry kind="lib" path="lib/commons-collections.jar"/>
<classpathentry kind="lib" path="lib/commons-httpclient-3.1.jar"/>
<classpathentry kind="lib" path="lib/commons-lang.jar"/> <classpathentry kind="lib" path="lib/commons-lang.jar"/>
<classpathentry kind="lib" path="lib/commons-logging-1.1.1.jar"/> <classpathentry kind="lib" path="lib/commons-logging-1.1.1.jar"/>
<classpathentry kind="lib" path="D:/apache-tomcat-6.0.44/lib/servlet-api.jar"/> <classpathentry kind="lib" path="lib/ezmorph-1.0.jar"/>
<classpathentry kind="lib" path="E:/libs/commons-collections-3.1.jar"/> <classpathentry kind="con" path="org.eclipse.jst.server.core.container/org.eclipse.jst.server.tomcat.runtimeTarget/Apache Tomcat v7.0"/>
<classpathentry kind="output" path="bin"/> <classpathentry kind="output" path="bin"/>
</classpath> </classpath>
eclipse.preferences.version=1 eclipse.preferences.version=1
org.eclipse.jdt.core.compiler.codegen.inlineJsrBytecode=enabled org.eclipse.jdt.core.compiler.codegen.inlineJsrBytecode=enabled
org.eclipse.jdt.core.compiler.codegen.methodParameters=do not generate
org.eclipse.jdt.core.compiler.codegen.targetPlatform=1.6 org.eclipse.jdt.core.compiler.codegen.targetPlatform=1.6
org.eclipse.jdt.core.compiler.codegen.unusedLocal=preserve org.eclipse.jdt.core.compiler.codegen.unusedLocal=preserve
org.eclipse.jdt.core.compiler.compliance=1.6 org.eclipse.jdt.core.compiler.compliance=1.6
......
\u8D26\u53F7
appid=wx4257809fde0f5986
\u5BC6\u7801
secret=lyJAj3vUqDg2BJp4Yc2ZLq9qwCX1rOXKV8OHSTD7JqY
\u5FAE\u4FE1\u670D\u52A1\u5668\u4FDD\u5B58\u5730\u5740
weiXinSavePath=/u01/web/JUNCHUANG_WX/attachment
\u79DF\u8D41\u4FDD\u5B58\u5730\u5740
zuLinsavePath=/u01/web/JUNCHUANG_WX/attachment
\u5FAE\u4FE1\u670D\u52A1\u5668\u8BF7\u6C42\u5730\u5740
weixinserviceUrl=http://172.20.0.115:5371/junchuang_wx/WeixinServlet
file_type_code=image
\u79DF\u8D41\u8BF7\u6C42\u5730\u5740
zuLinserviceUrl=http://172.20.0.115:5371/junchuang_wx/ZuLinServlet
\ No newline at end of file
oracleDriver=oracle.jdbc.driver.OracleDriver oracleDriver=oracle.jdbc.driver.OracleDriver
url=jdbc:oracle:thin:@10.0.36.97:1521:hls url=jdbc:oracle:thin:@172.20.0.115:1521:hls
# url=jdbc:oracle:thin:@172.20.0.115:1521:hls username=jc_hls
username=hls_standard password=jc_hls
password=hls_standard \ No newline at end of file
\ No newline at end of file
package hls.plugin.weixin.common; package hls.plugin.weixin.common;
import hls.plugin.weixin.qiye.DBUtil; import hls.plugin.weixin.qiye.DBUtil;
import java.io.IOException; import java.io.IOException;
import java.io.InputStream; import java.io.InputStream;
import java.util.HashMap; import java.util.HashMap;
import java.util.Map; import java.util.Map;
import java.util.Properties; import java.util.Properties;
public class GetPropertiesValue { public class GetPropertiesValue
public Map<String, String> GetValue(){ {
Map<String, String> map=new HashMap<String, String>(); public Map<String, String> GetValue()
{
Map map = new HashMap();
Properties prop = new Properties(); Properties prop = new Properties();
InputStream in = null; InputStream in = null;
in = new DBUtil().getPathName("hls/plugin/weixin/qiye/constants.properties"); in = new DBUtil().getPathName("hls/plugin/weixin/qiye/constants.properties");
...@@ -25,7 +26,16 @@ public class GetPropertiesValue { ...@@ -25,7 +26,16 @@ public class GetPropertiesValue {
map.put("file_type_code", prop.getProperty("file_type_code")); map.put("file_type_code", prop.getProperty("file_type_code"));
} catch (Exception e) { } catch (Exception e) {
e.printStackTrace(); e.printStackTrace();
} finally {
if (in != null)
try {
in.close();
} catch (IOException e1) {
e1.printStackTrace();
}
}
finally
{
if (in != null) { if (in != null) {
try { try {
in.close(); in.close();
...@@ -35,6 +45,5 @@ public class GetPropertiesValue { ...@@ -35,6 +45,5 @@ public class GetPropertiesValue {
} }
} }
return map; return map;
} }
} }
\ No newline at end of file
package hls.plugin.weixin.common; package hls.plugin.weixin.common;
import java.io.IOException; import java.io.IOException;
import org.apache.commons.httpclient.HttpClient; import org.apache.commons.httpclient.HttpClient;
import org.apache.commons.httpclient.HttpException; import org.apache.commons.httpclient.HttpException;
import org.apache.commons.httpclient.HttpMethod; import org.apache.commons.httpclient.HttpMethod;
import org.apache.commons.httpclient.methods.GetMethod; import org.apache.commons.httpclient.methods.GetMethod;
import org.apache.commons.httpclient.methods.PostMethod; import org.apache.commons.httpclient.methods.PostMethod;
public class HttpUtil { public class HttpUtil
public static String httpRequestUrl(String requestUrl,String method){ {
HttpClient client=new HttpClient(); public static String httpRequestUrl(String requestUrl, String method)
HttpMethod httpMethod=null; {
String responseMessage=""; HttpClient client = new HttpClient();
if("GET".equals(method)){ HttpMethod httpMethod = null;
httpMethod=new GetMethod(requestUrl); String responseMessage = "";
}else{ if ("GET".equals(method))
httpMethod = new GetMethod(requestUrl);
else {
httpMethod = new PostMethod(requestUrl); httpMethod = new PostMethod(requestUrl);
try {
} catch (Exception e) {
e.printStackTrace();
} }
}
try { try
{
client.executeMethod(httpMethod); client.executeMethod(httpMethod);
} catch (HttpException e1) { } catch (HttpException e1) {
e1.printStackTrace(); e1.printStackTrace();
} catch (IOException e1) { } catch (IOException e1) {
e1.printStackTrace(); e1.printStackTrace();
} }
try
try { {
responseMessage = httpMethod.getResponseBodyAsString(); responseMessage = httpMethod.getResponseBodyAsString();
httpMethod.releaseConnection(); httpMethod.releaseConnection();
} catch (IOException e) { } catch (IOException e) {
...@@ -40,5 +37,4 @@ public class HttpUtil { ...@@ -40,5 +37,4 @@ public class HttpUtil {
} }
return responseMessage; return responseMessage;
} }
} }
\ No newline at end of file
package hls.plugin.weixin.fuwu; package hls.plugin.weixin.fuwu;
import net.sf.json.JSONException;
import net.sf.json.JSONObject;
import hls.plugin.weixin.common.GetPropertiesValue; import hls.plugin.weixin.common.GetPropertiesValue;
import hls.plugin.weixin.common.HttpUtil; import hls.plugin.weixin.common.HttpUtil;
import java.util.Map;
import net.sf.json.JSONException;
import net.sf.json.JSONObject;
public class GetOpenid { public class GetOpenid
{
public String getAccessTokenURL(String code, String appid, public static String getAccessTokenURL(String code, String appid, String secret)
String secret) { {
String mutiurl = "https://api.weixin.qq.com/sns/oauth2/access_token?appid=" String mutiurl = "https://api.weixin.qq.com/sns/oauth2/access_token?appid=" + appid + "&secret=" + secret + "&code=" + code + "&grant_type=authorization_code";
+ appid
+ "&secret="
+ secret
+ "&code="
+ code
+ "&grant_type=authorization_code";
return mutiurl; return mutiurl;
} }
public String run(String code, String appid, String secret) { public String getPenid(String code) {
String openid = ""; String openid = "";
GetPropertiesValue gp = new GetPropertiesValue(); GetPropertiesValue gp = new GetPropertiesValue();
String requestUrl = getAccessTokenURL(code, appid, secret); String requestUrl = getAccessTokenURL(code, (String)gp.GetValue().get("appid"), (String)gp.GetValue().get("secret"));
JSONObject jsonObject = JSONObject.fromObject(HttpUtil.httpRequestUrl( JSONObject jsonObject = JSONObject.fromObject(HttpUtil.httpRequestUrl(
requestUrl, "GET")); // Http GET requestUrl, "GET"));
// ɹ
if (null != jsonObject) { if (jsonObject != null) {
try { try {
openid = jsonObject.getString("openid"); openid = jsonObject.getString("openid");
} catch (JSONException e) { } catch (JSONException e) {
...@@ -35,6 +30,5 @@ public class GetOpenid { ...@@ -35,6 +30,5 @@ public class GetOpenid {
} }
return openid; return openid;
} }
} }
\ No newline at end of file
package hls.plugin.weixin.fuwu; package hls.plugin.weixin.fuwu;
import hls.plugin.weixin.common.HttpUtil; import hls.plugin.weixin.common.HttpUtil;
import java.io.UnsupportedEncodingException; import java.io.UnsupportedEncodingException;
import java.net.URLEncoder; import java.net.URLEncoder;
public class ServiceUtil { public class ServiceUtil
public static String getAccessCodeURL(String appid,String redirect_uri,String state){ {
String mutiurl="https://open.weixin.qq.com/connect/oauth2/authorize?appid="+appid+"&redirect_uri="+redirect_uri+"&response_type=code&scope=snsapi_base&state="+state+"#wechat_redirect"; public static String getAccessCodeURL(String appid, String redirect_uri, String state)
{
String mutiurl = "https://open.weixin.qq.com/connect/oauth2/authorize?appid=" + appid + "&redirect_uri=" + redirect_uri + "&response_type=code&scope=snsapi_base&state=" + state + "#wechat_redirect";
return mutiurl; return mutiurl;
} }
/**
* 手机发起请求 public static void getAccessCodeRuquest(String appid, String redirect_uri, String state)
* @param redirect_uri 回调地址 {
* @param appid 账号 String redirect_urito = "";
* @param state 状态
* @return
*/
public static void getAccessCodeRuquest(String appid,String redirect_uri,String state) {
String redirect_urito="";
try { try {
redirect_urito=URLEncoder.encode(redirect_uri,"utf-8"); redirect_urito = URLEncoder.encode(redirect_uri, "utf-8");
} catch (UnsupportedEncodingException e) { } catch (UnsupportedEncodingException e) {
e.printStackTrace(); e.printStackTrace();
} }
String requestUrl=getAccessCodeURL(appid,redirect_urito,state); String requestUrl = getAccessCodeURL(appid, redirect_urito, state);
HttpUtil.httpRequestUrl(requestUrl, "GET"); // Http GET请求 HttpUtil.httpRequestUrl(requestUrl, "GET");
// 如果请求成功
} }
} }
\ No newline at end of file
package hls.plugin.weixin.fuwu;
import java.io.IOException;
import java.sql.Connection;
import java.sql.Date;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.Statement;
import org.apache.commons.httpclient.HttpClient;
import org.apache.commons.httpclient.HttpException;
import org.apache.commons.httpclient.HttpMethod;
import org.apache.commons.httpclient.methods.GetMethod;
import org.apache.commons.httpclient.methods.PostMethod;
import org.apache.commons.httpclient.methods.RequestEntity;
import org.apache.commons.httpclient.methods.StringRequestEntity;
import hls.plugin.weixin.qiye.DBUtil;
import net.sf.json.JSONObject;
public class sendPostForOpenid {
private String urlTemplate = "https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid={appid}&secret={secret}";
private String msgUrlTemplate = "https://api.weixin.qq.com/cgi-bin/message/custom/send?access_token={accessToken}";
private int MAX_RETRY = 3;
public String httpRequestUrl(String requestUrl, String method) throws IOException {
HttpClient client = new HttpClient();
HttpMethod httpMethod = null;
String openId = "";
if ("GET".equals(method)) {
httpMethod = new GetMethod(requestUrl);
} else {
httpMethod = new PostMethod(requestUrl);
try {
} catch (Exception e) {
e.printStackTrace();
}
}
try {
client.executeMethod(httpMethod);
openId = httpMethod.getResponseHeader("openid").getValue();
httpMethod.releaseConnection();
} catch (HttpException e1) {
e1.printStackTrace();
} catch (IOException e1) {
e1.printStackTrace();
} finally {
if (httpMethod != null) {
httpMethod.releaseConnection();
}
}
return openId;
}
public String getOpenId(String url) {
String openId = null;
String requestUrl = url;
try {
openId = httpRequestUrl(requestUrl, "GET");
} catch (IOException e) {
e.printStackTrace();
}
return openId;
}
public String replyText2OpenId(String appid,String secret,String toOpenId, String msgType, String msg) throws IllegalArgumentException {
String result = "failed";
try{
String accessToken = getAccessToken(appid,secret);
if (isNullOrEmpty(toOpenId) || isNullOrEmpty(msg) || isNullOrEmpty(msgType)) {
StringBuffer errorInfo = new StringBuffer("toOpenId:");
errorInfo.append(String.valueOf(toOpenId));
errorInfo.append("\tmsgType:");
errorInfo.append(String.valueOf(msgType));
errorInfo.append("\tmsg:");
errorInfo.append(String.valueOf(msg));
throw new IllegalArgumentException(errorInfo.toString());
}
String msgUrl = msgUrlTemplate.replace("{accessToken}", accessToken);
String jsonString = "{\"touser\":\""+toOpenId+"\",\"msgtype\":\""+msgType+"\",\"text\":{\"content\":\""+msg+"\"}}";
sendMsg(msgUrl, jsonString);
result = "success";
}catch(Exception e){
e.printStackTrace();
}
return result;
}
public String replyText2OpenIds(String appid,String secret,String[] toOpenId, String msgType) throws IllegalArgumentException {
String result = "failed";
try{
String accessToken = getAccessToken(appid,secret);
String msgUrl = msgUrlTemplate.replace("{accessToken}", accessToken);
for(int i=0; i<toOpenId.length; i++){
JSONObject jsonObject = JSONObject.fromObject(toOpenId[i]);
String openid = jsonObject.get("openid").toString();
String msg = jsonObject.get("msg").toString();
String jsonString = "{\"touser\":\""+openid+"\",\"msgtype\":\""+msgType+"\",\"text\":{\"content\":\""+msg+"\"}}";
sendMsg(msgUrl, jsonString);
}
result = "success";
}catch(Exception e){
e.printStackTrace();
}
return result;
}
private boolean isNullOrEmpty(String s) {
if (s == null || s.length() < 1) {
return true;
}
return false;
}
public String getAccessToken(String appid,String secret) throws IllegalArgumentException, Exception {
String accessToken = null;
HttpClient client = new HttpClient();
// 从数据库获取access_token
Connection connection = DBUtil.getConnection();
String sql = "select access_token from wfl_access_token where expire_date > ?";
PreparedStatement pstmt = connection.prepareStatement(sql);
pstmt.setDate(1, new Date(System.currentTimeMillis()));
ResultSet resultSet = pstmt.executeQuery();
// 如果存在,则使用数据库的access_token
if (resultSet.next()) {
accessToken = resultSet.getString(1);
} else {
// 像服务器请求
if (isNullOrEmpty(appid) || isNullOrEmpty(secret)) {
throw new IllegalArgumentException("cannot get access token");
}
String url = urlTemplate.replace("{appid}", appid).replace("{secret}", secret);
GetMethod get = new GetMethod(url);
int flag = 1;
while (flag > 0) {
int executeMethod = client.executeMethod(get);
byte[] responseBody = get.getResponseBody();
JSONObject jsonObject = JSONObject.fromObject(new String(responseBody));
Object object = jsonObject.get("access_token");
if (object == null) {
System.err.println("get token failed, try again!");
flag++;
if (flag > MAX_RETRY) {
flag = -1;
throw new Exception("get token failed max times. stopped!");
}
} else {
Object expire = jsonObject.get("expires_in");
accessToken = String.valueOf(object);
sql = "insert into wfl_access_token(access_token,expire_date,creation_date,created_by,last_update_date,last_updated_by) values('"
+accessToken
+"',sysdate+"
+String.valueOf(expire)
+"/24/60/60,sysdate,'1',sysdate,'1')";
Statement stmt = connection.createStatement();
// 保存到数据库
stmt.execute(sql);
flag = -1;
}
}
}
pstmt.close();
connection.commit();
connection.close();
return accessToken;
}
private void sendMsg(String url,String msg) throws Exception{
HttpClient client = new HttpClient();
PostMethod postMethod = new PostMethod(url);
RequestEntity requestEntity = new StringRequestEntity(msg,"text/xml","UTF-8");
postMethod.setRequestEntity(requestEntity);
int executeMethod = client.executeMethod(postMethod);
}
public static void main(String[] args) throws Exception{
sendPostForOpenid sendPostForOpenid = new sendPostForOpenid();
/*String accessToken = sendPostForOpenid.getAccessToken("wx114d72be121c0797", "f6490d5f2c58656be86fd522837db943 ");
System.out.println(accessToken);*/
String[] aStrings= new String[]{};
sendPostForOpenid.replyText2OpenIds("wx114d72be121c0797", "f6490d5f2c58656be86fd522837db943", new String[]{"{'openid':'oTZ5RwCyG8mUOgf_1bX4J9nY2L-4','msg':'345'}","{'openid':'12314-4','msg':'abc'}"}, "text");
}
}
...@@ -2,27 +2,23 @@ package hls.plugin.weixin.qiye; ...@@ -2,27 +2,23 @@ package hls.plugin.weixin.qiye;
import java.io.IOException; import java.io.IOException;
import java.io.InputStream; import java.io.InputStream;
import java.io.PrintStream;
import java.sql.Connection; import java.sql.Connection;
import java.sql.DriverManager; import java.sql.DriverManager;
import java.sql.SQLException; import java.sql.SQLException;
import java.util.Properties; import java.util.Properties;
/** public class DBUtil
* @title DBUtil {
* @Description:
* @Company:
* @author jianwen_zheng
* @date 2016-10-9
*/
public class DBUtil {
private static String oracleDriver; private static String oracleDriver;
private static String url; private static String url;
private static String username; private static String username;
private static String password; private static String password;
static { static
try { {
try
{
get(); get();
Class.forName(oracleDriver); Class.forName(oracleDriver);
} catch (ClassNotFoundException e) { } catch (ClassNotFoundException e) {
...@@ -30,14 +26,9 @@ public class DBUtil { ...@@ -30,14 +26,9 @@ public class DBUtil {
} }
} }
/** public InputStream getPathName(String pathName)
* {
*/ return DBUtil.class.getClassLoader().getResourceAsStream(pathName);
public DBUtil() {
}
public InputStream getPathName(String pathName) {
return DBUtil.class.getClassLoader().getResourceAsStream(pathName);// "com/wx/util/data_jdbc.properties"
} }
private static void get() { private static void get() {
...@@ -45,15 +36,24 @@ public class DBUtil { ...@@ -45,15 +36,24 @@ public class DBUtil {
InputStream in = null; InputStream in = null;
try { try {
in = new DBUtil().getPathName("hls/plugin/weixin/qiye/data_jdbc.properties"); in = new DBUtil().getPathName("hls/plugin/weixin/qiye/data_jdbc.properties");
prop.load(in); // /加载属性列表 prop.load(in);
oracleDriver = prop.getProperty("oracleDriver"); oracleDriver = prop.getProperty("oracleDriver");
url = prop.getProperty("url"); url = prop.getProperty("url");
username = prop.getProperty("username"); username = prop.getProperty("username");
password = prop.getProperty("password"); password = prop.getProperty("password");
} catch (Exception e) { } catch (Exception e) {
e.printStackTrace(); e.printStackTrace();
} finally {
if (in != null) { if (in != null)
try {
in.close();
} catch (IOException e1) {
e1.printStackTrace();
}
}
finally
{
if (in != null)
try { try {
in.close(); in.close();
} catch (IOException e) { } catch (IOException e) {
...@@ -61,21 +61,16 @@ public class DBUtil { ...@@ -61,21 +61,16 @@ public class DBUtil {
} }
} }
} }
}
/** public static Connection getConnection()
* 获取数据连接 throws SQLException
* {
* @return
* @throws SQLException
*/
public static Connection getConnection() throws SQLException {
return DriverManager.getConnection(url, username, password); return DriverManager.getConnection(url, username, password);
} }
public static void main(String[] args) { public static void main(String[] args) {
try { try {
// DBUtil.get(); getConnection();
DBUtil.getConnection();
} catch (SQLException e) { } catch (SQLException e) {
e.printStackTrace(); e.printStackTrace();
} }
......
package hls.plugin.weixin.qiye; package hls.plugin.weixin.qiye;
public class Ertrt { import java.io.PrintStream;
/** public class Ertrt
* @param args {
*/ public static void main(String[] args)
public static void main(String[] args) { {
String time = (long)(Math.random() * 10000000.0D)+"";
String time=(long)(Math.random()*10000000)+"";
System.out.println(time); System.out.println(time);
} }
} }
\ No newline at end of file
package hls.plugin.weixin.qiye; package hls.plugin.weixin.qiye;
/** public class FndAtmAttachment
* @title FndAtmAttachment {
* @Description:
* @Company:
* @author jianwen_zheng
* @date 2016-10-12
*/
public class FndAtmAttachment {
private String source_pk_value; private String source_pk_value;
private String file_type_code; private String file_type_code;
private String mime_type; private String mime_type;
...@@ -18,28 +12,12 @@ public class FndAtmAttachment { ...@@ -18,28 +12,12 @@ public class FndAtmAttachment {
private String table_name; private String table_name;
private String table_pk_value; private String table_pk_value;
/** public FndAtmAttachment()
* {
*/ }
public FndAtmAttachment() {
} public FndAtmAttachment(String source_pk_value, String file_type_code, String mime_type, String file_name, int file_size, String file_path, int user_id, String table_name, String table_pk_value)
{
/**
* @param source_pk_value
* @param file_type_code
* @param mime_type
* @param file_name
* @param file_size
* @param file_path
* @param user_id
* @param table_name
* @param table_pk_value
*/
public FndAtmAttachment(String source_pk_value, String file_type_code,
String mime_type, String file_name, int file_size,
String file_path, int user_id, String table_name,
String table_pk_value) {
super();
this.source_pk_value = source_pk_value; this.source_pk_value = source_pk_value;
this.file_type_code = file_type_code; this.file_type_code = file_type_code;
this.mime_type = mime_type; this.mime_type = mime_type;
...@@ -52,7 +30,7 @@ public class FndAtmAttachment { ...@@ -52,7 +30,7 @@ public class FndAtmAttachment {
} }
public String getSource_pk_value() { public String getSource_pk_value() {
return source_pk_value; return this.source_pk_value;
} }
public void setSource_pk_value(String source_pk_value) { public void setSource_pk_value(String source_pk_value) {
...@@ -60,7 +38,7 @@ public class FndAtmAttachment { ...@@ -60,7 +38,7 @@ public class FndAtmAttachment {
} }
public String getFile_type_code() { public String getFile_type_code() {
return file_type_code; return this.file_type_code;
} }
public void setFile_type_code(String file_type_code) { public void setFile_type_code(String file_type_code) {
...@@ -68,7 +46,7 @@ public class FndAtmAttachment { ...@@ -68,7 +46,7 @@ public class FndAtmAttachment {
} }
public String getMime_type() { public String getMime_type() {
return mime_type; return this.mime_type;
} }
public void setMime_type(String mime_type) { public void setMime_type(String mime_type) {
...@@ -76,7 +54,7 @@ public class FndAtmAttachment { ...@@ -76,7 +54,7 @@ public class FndAtmAttachment {
} }
public String getFile_name() { public String getFile_name() {
return file_name; return this.file_name;
} }
public void setFile_name(String file_name) { public void setFile_name(String file_name) {
...@@ -84,7 +62,7 @@ public class FndAtmAttachment { ...@@ -84,7 +62,7 @@ public class FndAtmAttachment {
} }
public int getFile_size() { public int getFile_size() {
return file_size; return this.file_size;
} }
public void setFile_size(int file_size) { public void setFile_size(int file_size) {
...@@ -92,7 +70,7 @@ public class FndAtmAttachment { ...@@ -92,7 +70,7 @@ public class FndAtmAttachment {
} }
public String getFile_path() { public String getFile_path() {
return file_path; return this.file_path;
} }
public void setFile_path(String file_path) { public void setFile_path(String file_path) {
...@@ -100,7 +78,7 @@ public class FndAtmAttachment { ...@@ -100,7 +78,7 @@ public class FndAtmAttachment {
} }
public int getUser_id() { public int getUser_id() {
return user_id; return this.user_id;
} }
public void setUser_id(int user_id) { public void setUser_id(int user_id) {
...@@ -108,7 +86,7 @@ public class FndAtmAttachment { ...@@ -108,7 +86,7 @@ public class FndAtmAttachment {
} }
public String getTable_name() { public String getTable_name() {
return table_name; return this.table_name;
} }
public void setTable_name(String table_name) { public void setTable_name(String table_name) {
...@@ -116,7 +94,7 @@ public class FndAtmAttachment { ...@@ -116,7 +94,7 @@ public class FndAtmAttachment {
} }
public String getTable_pk_value() { public String getTable_pk_value() {
return table_pk_value; return this.table_pk_value;
} }
public void setTable_pk_value(String table_pk_value) { public void setTable_pk_value(String table_pk_value) {
......
package hls.plugin.weixin.qiye; package hls.plugin.weixin.qiye;
public abstract interface IWeChatDao
{
/** public abstract boolean save(FndAtmAttachment paramFndAtmAttachment);
* @title IWeChat
* @Description: ݲҽӿ
* @Company:
* @author jianwen_zheng
* @date 2016-10-9
*/
public interface IWeChatDao {
/**
*
* @return
*/
public boolean save(FndAtmAttachment fnd);
} }
\ No newline at end of file
package hls.plugin.weixin.qiye; package hls.plugin.weixin.qiye;
import hls.plugin.weixin.common.GetPropertiesValue; import hls.plugin.weixin.common.GetPropertiesValue;
import hls.plugin.weixin.common.HttpUtil; import hls.plugin.weixin.common.HttpUtil;
import java.util.Map;
public class RequestToCompany { public class RequestToCompany
public static void sendMassage(String [] mediaId,String table_pk_value,String userId,String tableName,String pck_id) { {
GetPropertiesValue gp=new GetPropertiesValue(); public static void sendMassage(String[] mediaId, String table_pk_value, String userId, String tableName, String pck_id)
{
GetPropertiesValue gp = new GetPropertiesValue();
for (int i = 0; i < mediaId.length; i++) { for (int i = 0; i < mediaId.length; i++) {
String requestUrl=gp.GetValue().get("weixinserviceUrl")+"?mediaId="+mediaId[i]+"&pck_id="+pck_id+"&userId="+userId+"&tableName="+tableName+"&table_pk_value="+table_pk_value; String requestUrl = (String)gp.GetValue().get("weixinserviceUrl") + "?mediaId=" + mediaId[i] + "&pck_id=" + pck_id + "&userId=" + userId + "&tableName=" + tableName + "&table_pk_value=" + table_pk_value;
HttpUtil.httpRequestUrl(requestUrl, "GET"); // Http GET HttpUtil.httpRequestUrl(requestUrl, "GET");
} }
} }
public static void main(String[] args) {
// String a[]={"1qyU7RGN3LHdsMrqCw7VrTc85wY-Q5Z3pEk_VJKcU9E3Nx_ukMH7ik2Vp_43EiMa6VyEjpNwtuEQ2ILqoe7F5cA"}; public static void main(String[] args)
{
} }
} }
\ No newline at end of file
package hls.plugin.weixin.qiye; package hls.plugin.weixin.qiye;
import hls.plugin.weixin.common.HttpUtil;
import hls.plugin.weixin.common.HttpUtil;
import java.io.PrintStream;
import java.util.Map; import java.util.Map;
import net.sf.json.JSONException; import net.sf.json.JSONException;
import net.sf.json.JSONObject; import net.sf.json.JSONObject;
public class WXupAndDown { public class WXupAndDown
/** {
* 获得token public static String getJSSDKAccessToken(String acceToken_urlx)
* @param acceToken_urlx 请求的url {
* @return
*/
public static String getJSSDKAccessToken(String acceToken_urlx) {
String returnString = ""; String returnString = "";
String requestUrl = acceToken_urlx; String requestUrl = acceToken_urlx;
JSONObject jsonObject = JSONObject.fromObject(HttpUtil.httpRequestUrl( JSONObject jsonObject = JSONObject.fromObject(HttpUtil.httpRequestUrl(
requestUrl, "GET")); // Http GET请求 requestUrl, "GET"));
// 如果请求成功
if (null != jsonObject) { if (jsonObject != null) {
try { try {
returnString = jsonObject.getString("access_token"); returnString = jsonObject.getString("access_token");
} catch (JSONException e) { } catch (JSONException e) {
...@@ -26,20 +24,16 @@ public class WXupAndDown { ...@@ -26,20 +24,16 @@ public class WXupAndDown {
} }
return returnString; return returnString;
} }
/**
* 获得ticket public static String getJSSDKTicket(String access_token, String ticket_urlx)
* @param access_token 上面来的token {
* @param ticket_urlx ticket的请求地址
* @return
*/
public static String getJSSDKTicket(String access_token, String ticket_urlx) {
String returnString = ""; String returnString = "";
String requestUrl = ticket_urlx.replace("ACCESS_TOKEN", access_token); String requestUrl = ticket_urlx.replace("ACCESS_TOKEN", access_token);
JSONObject jsonObject = JSONObject.fromObject(HttpUtil.httpRequestUrl( JSONObject jsonObject = JSONObject.fromObject(HttpUtil.httpRequestUrl(
requestUrl, "GET")); requestUrl, "GET"));
// 如果请求成功
if (null != jsonObject) { if (jsonObject != null) {
try { try {
returnString = jsonObject.getString("ticket"); returnString = jsonObject.getString("ticket");
} catch (JSONException e) { } catch (JSONException e) {
...@@ -48,32 +42,26 @@ public class WXupAndDown { ...@@ -48,32 +42,26 @@ public class WXupAndDown {
} }
return returnString; return returnString;
} }
/**
* 获得签名 public static Map<String, String> getSignture(String id, String secrect, String url)
* @param id 账号 {
* @param secrect 密码 String acceToken_urlx = "https://qyapi.weixin.qq.com/cgi-bin/gettoken?corpid=" + id + "&corpsecret=" + secrect;
* @param url 返回地址 String ticket_urlx = "https://qyapi.weixin.qq.com/cgi-bin/get_jsapi_ticket?access_token=ACCESS_TOKEN";
* @return String js_accessToken = getJSSDKAccessToken(acceToken_urlx);
*/ String jsapi_ticket = getJSSDKTicket(js_accessToken, ticket_urlx);
public static Map<String, String> getSignture(String id, String secrect,
String url) { Map map = WxJSsign.sign(jsapi_ticket, url);
String acceToken_urlx="https://qyapi.weixin.qq.com/cgi-bin/gettoken?corpid="+id+"&corpsecret="+secrect;
String ticket_urlx="https://qyapi.weixin.qq.com/cgi-bin/get_jsapi_ticket?access_token=ACCESS_TOKEN";
String js_accessToken = WXupAndDown.getJSSDKAccessToken(acceToken_urlx); // 获取微信jssdk---access_token
String jsapi_ticket = WXupAndDown.getJSSDKTicket(js_accessToken,ticket_urlx); // 获取微信jssdk---ticket
// System.out.println("jsapi_ticket==="+jsapi_ticket);
Map<String, String> map = WxJSsign.sign(jsapi_ticket, url);
return map; return map;
} }
public static void main(String[] args) { public static void main(String[] args) {
String id ="wx4257809fde0f5986"; String id = "wx4257809fde0f5986";
String secrect="iTgSpAaEYejcyPBLlyikzx6kvSVuiMBxotfAkAdWAKo6nF8cefdJSTgLXqivXpZ7"; String secrect = "iTgSpAaEYejcyPBLlyikzx6kvSVuiMBxotfAkAdWAKo6nF8cefdJSTgLXqivXpZ7";
String url="http://cmsplus.com.cn"; String url = "http://cmsplus.com.cn";
Map<String, String> map = getSignture(id,secrect,url); Map map = getSignture(id, secrect, url);
System.out.println("1"+map.get("nonceStr")); System.out.println("1" + (String)map.get("nonceStr"));
System.out.println("2"+map.get("timestamp")); System.out.println("2" + (String)map.get("timestamp"));
System.out.println("3"+map.get("signature")); System.out.println("3" + (String)map.get("signature"));
} }
} }
\ No newline at end of file
package hls.plugin.weixin.qiye; package hls.plugin.weixin.qiye;
import java.io.PrintStream;
import java.sql.CallableStatement; import java.sql.CallableStatement;
import java.sql.Connection; import java.sql.Connection;
import java.sql.SQLException; import java.sql.SQLException;
import java.sql.Types;
/** public class WeCatDaoImpl
* @title WeCatDaoImpl implements IWeChatDao
* @Description: {
* @Company: public static void main(String[] args)
* @author jianwen_zheng {
* @date 2016-10-12 FndAtmAttachment fnd = new FndAtmAttachment("1", "1", "1", "1", 1, "1", 1, "1", "1");
*/ boolean ss = new WeCatDaoImpl().save(fnd);
public class WeCatDaoImpl implements IWeChatDao {
public static void main(String[] args) {
FndAtmAttachment fnd = new FndAtmAttachment("1","1","1","1",1,"1",1,"1","1");
boolean ss =new WeCatDaoImpl().save(fnd);
System.out.println(ss); System.out.println(ss);
} }
...@@ -26,9 +21,9 @@ public class WeCatDaoImpl implements IWeChatDao { ...@@ -26,9 +21,9 @@ public class WeCatDaoImpl implements IWeChatDao {
CallableStatement pst = null; CallableStatement pst = null;
try { try {
conn = DBUtil.getConnection(); conn = DBUtil.getConnection();
pst = conn. pst = conn
prepareCall("{ call fnd_atm_attachment_all_pkg.insert_fnd_atm_attachment(?,?,?,?,?,?,?,?,?,?) }"); .prepareCall("{ call fnd_atm_attachment_all_pkg.insert_fnd_atm_attachment(?,?,?,?,?,?,?,?,?,?) }");
pst.registerOutParameter(1, Types.INTEGER); pst.registerOutParameter(1, 4);
pst.setString(2, fnd.getSource_pk_value()); pst.setString(2, fnd.getSource_pk_value());
pst.setString(3, fnd.getFile_type_code()); pst.setString(3, fnd.getFile_type_code());
pst.setString(4, fnd.getMime_type()); pst.setString(4, fnd.getMime_type());
...@@ -43,11 +38,23 @@ public class WeCatDaoImpl implements IWeChatDao { ...@@ -43,11 +38,23 @@ public class WeCatDaoImpl implements IWeChatDao {
success = true; success = true;
} catch (SQLException e) { } catch (SQLException e) {
e.printStackTrace(); e.printStackTrace();
} finally { try
try { {
if (null != pst) if (pst != null)
pst.close();
if (conn != null)
conn.close();
} catch (SQLException e1) {
e1.printStackTrace();
}
}
finally
{
try
{
if (pst != null)
pst.close(); pst.close();
if (null != conn) if (conn != null)
conn.close(); conn.close();
} catch (SQLException e) { } catch (SQLException e) {
e.printStackTrace(); e.printStackTrace();
......
package hls.plugin.weixin.qiye; package hls.plugin.weixin.qiye;
import hls.plugin.weixin.common.GetPropertiesValue; import hls.plugin.weixin.common.GetPropertiesValue;
import java.io.BufferedInputStream;
import java.io.BufferedOutputStream;
import java.io.ByteArrayOutputStream; import java.io.ByteArrayOutputStream;
import java.io.File; import java.io.File;
import java.io.FileInputStream; import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException; import java.io.IOException;
import java.io.InputStream; import java.io.InputStream;
import java.io.OutputStream; import java.io.OutputStream;
import java.io.PrintStream;
import java.net.HttpURLConnection; import java.net.HttpURLConnection;
import java.net.URL; import java.net.URL;
import java.util.Map;
public class WeiImagePostTo { public class WeiImagePostTo
{
/** public void send(String mediaId, String pck_id, String fileName, String filetype, String fileSize, String userId, String tableName, String table_pk_value)
* 上传到微信服务器 {
*
* @param fileType
* 文件类型
* @param filePath
* 本地上传文件路径
* @param id
* 账号
* @param secret
* 密码
* @return
* @throws Exception
*/
public void send(String mediaId, String pck_id, String fileName,String filetype, String fileSize,String userId,String tableName,String table_pk_value) {
GetPropertiesValue gp = new GetPropertiesValue(); GetPropertiesValue gp = new GetPropertiesValue();
HttpURLConnection con = null; HttpURLConnection con = null;
OutputStream out = null; OutputStream out = null;
...@@ -41,44 +25,89 @@ public class WeiImagePostTo { ...@@ -41,44 +25,89 @@ public class WeiImagePostTo {
ByteArrayOutputStream baos = null; ByteArrayOutputStream baos = null;
int length = 0; int length = 0;
try { try {
File file = new File(gp.GetValue().get("winXinSavePath") + "/" File file = new File((String)gp.GetValue().get("winXinSavePath") + "/" +
+ fileName + "." + filetype); fileName + "." + filetype);
if (!file.exists() || !file.isFile()) { if ((!file.exists()) || (!file.isFile())) {
throw new IOException("ļ"); throw new IOException("ļ");
} }
/**
* 第一部分
*/
String enCodemediaId = mediaId; String enCodemediaId = mediaId;
URL urlObj = new URL(gp.GetValue().get("zuLinserviceUrl") /*URL urlObj = new URL((String)gp.GetValue().get("zuLinserviceUrl") +
+ "?mediaId=" + enCodemediaId + "&pck_id=" + pck_id "?mediaId=" + enCodemediaId + "&pck_id=" + pck_id +
+ "&fileName=" + fileName + "&filetype=" + filetype "&fileName=" + fileName + "&filetype=" + filetype +
+ "&fileSize=" + fileSize+"&userId="+userId+"&tableName="+tableName+"&table_pk_value="+table_pk_value); "&fileSize=" + fileSize + "&userId=" + userId + "&tableName=" + tableName + "&table_pk_value=" + table_pk_value);
*/
int userId2 = Integer.parseInt(userId);
int file_size_int = Integer.parseInt(fileSize);
String mime_type = (String)gp.GetValue().get("file_type_code") + "/" +filetype;
String filepath =
(String)gp.GetValue()
.get("weiXinSavePath") +
"/" + fileName;
FndAtmAttachment fnd = new FndAtmAttachment(table_pk_value, filetype, mime_type, fileName, file_size_int, filepath, userId2, tableName, pck_id);
boolean ss = new WeCatDaoImpl().save(fnd);
System.out.println(ss);
con = (HttpURLConnection) urlObj.openConnection();
// con.setDoInput(true); /* con = (HttpURLConnection)urlObj.openConnection();
con.setDoOutput(true); con.setDoOutput(true);
con.setRequestProperty("Content-Length",fileSize); con.setRequestProperty("Content-Length", fileSize);
con.setRequestProperty("Content-type", "application/image");//这句相当重要,没有回报各种错 con.setRequestProperty("Content-type", "application/image");
con.setRequestMethod("POST"); // 以Post方式提交表单,默认get方式 con.setRequestMethod("POST");
//con.setUseCaches(false); // post方式不能使用缓存
con.connect(); con.connect();
// 获得输出流
out = con.getOutputStream(); out = con.getOutputStream();
in = new FileInputStream(file); in = new FileInputStream(file);
int bytes=-1; int bytes = -1;
byte[] bufferOut = new byte[1024]; byte[] bufferOut = new byte[1024];
while ((bytes = in.read(bufferOut)) != -1) { while ((bytes = in.read(bufferOut)) != -1) {
out.write(bufferOut, 0, bytes); out.write(bufferOut, 0, bytes);
} }
inputStream = con.getInputStream();*/
inputStream = con.getInputStream(); }
// temp.close(); catch (Exception e) {
} catch (Exception e) {
System.out.println("쳣:" + e.getMessage()); System.out.println("쳣:" + e.getMessage());
} finally {
if (in != null) {
try {
in.close();
} catch (IOException e1) {
e1.printStackTrace();
}
}
if (out != null) {
try {
out.flush();
out.close();
} catch (IOException e1) {
e1.printStackTrace();
}
}
if (con != null) {
con.disconnect();
}
if (inputStream != null) {
try {
inputStream.close();
} catch (IOException e1) {
e1.printStackTrace();
}
}
if (baos != null)
try {
baos.close();
} catch (IOException e1) {
e1.printStackTrace();
}
}
finally
{
if (in != null) { if (in != null) {
try { try {
in.close(); in.close();
...@@ -105,15 +134,12 @@ public class WeiImagePostTo { ...@@ -105,15 +134,12 @@ public class WeiImagePostTo {
e.printStackTrace(); e.printStackTrace();
} }
} }
if (baos != null) { if (baos != null)
try { try {
baos.close(); baos.close();
} catch (IOException e) { } catch (IOException e) {
e.printStackTrace(); e.printStackTrace();
}// 再读取一遍
} }
} }
} }
} }
\ No newline at end of file
package hls.plugin.weixin.qiye; package hls.plugin.weixin.qiye;
import hls.plugin.weixin.common.HttpUtil; import hls.plugin.weixin.common.HttpUtil;
import java.io.BufferedReader; import java.io.BufferedReader;
import java.io.DataInputStream; import java.io.DataInputStream;
import java.io.DataOutputStream; import java.io.DataOutputStream;
...@@ -10,64 +9,52 @@ import java.io.FileInputStream; ...@@ -10,64 +9,52 @@ import java.io.FileInputStream;
import java.io.IOException; import java.io.IOException;
import java.io.InputStreamReader; import java.io.InputStreamReader;
import java.io.OutputStream; import java.io.OutputStream;
import java.io.PrintStream;
import java.net.HttpURLConnection; import java.net.HttpURLConnection;
import java.net.URL; import java.net.URL;
import java.util.HashMap; import java.util.HashMap;
import java.util.Map; import java.util.Map;
import net.sf.json.JSONException; import net.sf.json.JSONException;
import net.sf.json.JSONObject; import net.sf.json.JSONObject;
public class WeiImageUpload { public class WeiImageUpload
{
/** public JSONObject send(String fileType, String filePath, String id, String secret)
* 上传到微信服务器 throws Exception
* @param fileType 文件类型 {
* @param filePath 本地上传文件路径
* @param id 账号
* @param secret 密码
* @return
* @throws Exception
*/
public JSONObject send(String fileType, String filePath,String id,String secret) throws Exception {
String result = null; String result = null;
File file = new File(filePath); File file = new File(filePath);
if (!file.exists() || !file.isFile()) { if ((!file.exists()) || (!file.isFile())) {
throw new IOException("文件不存在"); throw new IOException("文件不存在");
} }
String token=getNowToken(id,secret); String token = getNowToken(id, secret);
/**
* 第一部分 URL urlObj = new URL("https://qyapi.weixin.qq.com/cgi-bin/media/upload?access_token=" + token +
*/ "&type=" + fileType);
URL urlObj = new URL("https://qyapi.weixin.qq.com/cgi-bin/media/upload?access_token="+ token HttpURLConnection con = (HttpURLConnection)urlObj.openConnection();
+ "&type="+fileType+""); con.setRequestMethod("POST");
HttpURLConnection con = (HttpURLConnection) urlObj.openConnection();
con.setRequestMethod("POST"); // 以Post方式提交表单,默认get方式
con.setDoInput(true); con.setDoInput(true);
con.setDoOutput(true); con.setDoOutput(true);
con.setUseCaches(false); // post方式不能使用缓存 con.setUseCaches(false);
// 设置请求头信息
con.setRequestProperty("Connection", "Keep-Alive"); con.setRequestProperty("Connection", "Keep-Alive");
con.setRequestProperty("Charset", "UTF-8"); con.setRequestProperty("Charset", "UTF-8");
// 设置边界
String BOUNDARY = "----------" + System.currentTimeMillis(); String BOUNDARY = "----------" + System.currentTimeMillis();
con.setRequestProperty("Content-Type", "multipart/form-data; boundary="+ BOUNDARY); con.setRequestProperty("Content-Type", "multipart/form-data; boundary=" + BOUNDARY);
// 请求正文信息
// 第一部分:
StringBuilder sb = new StringBuilder(); StringBuilder sb = new StringBuilder();
sb.append("--"); // 必须多两道线 sb.append("--");
sb.append(BOUNDARY); sb.append(BOUNDARY);
sb.append("\r\n"); sb.append("\r\n");
sb.append("Content-Disposition: form-data;name=\"media\";filename=\""+ file.getName() + "\"\r\n"); sb.append("Content-Disposition: form-data;name=\"media\";filename=\"" + file.getName() + "\"\r\n");
sb.append("Content-Type:application/octet-stream\r\n\r\n"); sb.append("Content-Type:application/octet-stream\r\n\r\n");
byte[] head = sb.toString().getBytes("utf-8"); byte[] head = sb.toString().getBytes("utf-8");
// 获得输出流
OutputStream out = new DataOutputStream(con.getOutputStream()); OutputStream out = new DataOutputStream(con.getOutputStream());
// 输出表头
out.write(head); out.write(head);
// 文件正文部分
// 把文件已流文件的方式 推入到url中
DataInputStream in = new DataInputStream(new FileInputStream(file)); DataInputStream in = new DataInputStream(new FileInputStream(file));
int bytes = 0; int bytes = 0;
byte[] bufferOut = new byte[1024]; byte[] bufferOut = new byte[1024];
...@@ -75,45 +62,45 @@ public class WeiImageUpload { ...@@ -75,45 +62,45 @@ public class WeiImageUpload {
out.write(bufferOut, 0, bytes); out.write(bufferOut, 0, bytes);
} }
in.close(); in.close();
// 结尾部分
byte[] foot = ("\r\n--" + BOUNDARY + "--\r\n").getBytes("utf-8");// 定义最后数据分隔线 byte[] foot = ("\r\n--" + BOUNDARY + "--\r\n").getBytes("utf-8");
out.write(foot); out.write(foot);
out.flush(); out.flush();
out.close(); out.close();
StringBuffer buffer = new StringBuffer(); StringBuffer buffer = new StringBuffer();
BufferedReader reader = null; BufferedReader reader = null;
try { try
// 定义BufferedReader输入流来读取URL的响应 {
reader = new BufferedReader(new InputStreamReader(con.getInputStream())); reader = new BufferedReader(new InputStreamReader(con.getInputStream()));
String line = null; String line = null;
while ((line = reader.readLine()) != null) { while ((line = reader.readLine()) != null)
//System.out.println(line); {
buffer.append(line); buffer.append(line);
} }
if(result==null){ if (result == null)
result = buffer.toString(); result = buffer.toString();
} }
} catch (IOException e) { catch (IOException e) {
System.out.println("发送POST请求出现异常!" + e); System.out.println("发送POST请求出现异常!" + e);
e.printStackTrace(); e.printStackTrace();
throw new IOException("数据读取异常"); throw new IOException("数据读取异常");
} finally { } finally {
if(reader!=null){ if (reader != null) {
reader.close(); reader.close();
} }
} }
JSONObject jsonObj =JSONObject.fromObject(result); JSONObject jsonObj = JSONObject.fromObject(result);
System.out.println("jsonObj>>>>"+jsonObj); System.out.println("jsonObj>>>>" + jsonObj);
return jsonObj; return jsonObj;
} }
public static String getNowToken(String id,String secret) { public static String getNowToken(String id, String secret) {
String returnString = ""; String returnString = "";
String requestUrl=getNowTokenURL(id,secret); String requestUrl = getNowTokenURL(id, secret);
JSONObject jsonObject = JSONObject.fromObject(HttpUtil.httpRequestUrl( JSONObject jsonObject = JSONObject.fromObject(HttpUtil.httpRequestUrl(
requestUrl, "GET")); // Http GET请求 requestUrl, "GET"));
// 如果请求成功
if (null != jsonObject) { if (jsonObject != null) {
try { try {
returnString = jsonObject.getString("access_token"); returnString = jsonObject.getString("access_token");
} catch (JSONException e) { } catch (JSONException e) {
...@@ -122,36 +109,35 @@ public class WeiImageUpload { ...@@ -122,36 +109,35 @@ public class WeiImageUpload {
} }
return returnString; return returnString;
} }
public static String getNowTokenURL(String id,String secret){ public static String getNowTokenURL(String id, String secret) {
String mutiurl="https://qyapi.weixin.qq.com/cgi-bin/gettoken?corpid="+id+"&corpsecret="+secret; String mutiurl = "https://qyapi.weixin.qq.com/cgi-bin/gettoken?corpid=" + id + "&corpsecret=" + secret;
return mutiurl; return mutiurl;
} }
public static void main(String[] args) { public static void main(String[] args) {
try { try {
JSONObject jsonObj=new WeiImageUpload().send("image","C:/Users/Administrator/Desktop/pak/3.jpg","wx4257809fde0f5986","iTgSpAaEYejcyPBLlyikzx6kvSVuiMBxotfAkAdWAKo6nF8cefdJSTgLXqivXpZ7"); JSONObject jsonObj = new WeiImageUpload().send("image", "C:/Users/Administrator/Desktop/pak/3.jpg", "wx4257809fde0f5986", "iTgSpAaEYejcyPBLlyikzx6kvSVuiMBxotfAkAdWAKo6nF8cefdJSTgLXqivXpZ7");
System.out.println(jsonObj.getString("media_id")); System.out.println(jsonObj.getString("media_id"));
System.out.println(jsonObj.getString("created_at")); System.out.println(jsonObj.getString("created_at"));
}
catch (Exception e)
} catch (Exception e) { {
e.printStackTrace(); e.printStackTrace();
} }
} }
public static Map<String, String> weiUpload(String fileType, String filePath,String id,String secret){ public static Map<String, String> weiUpload(String fileType, String filePath, String id, String secret)
Map<String, String> map=new HashMap<String, String>(); {
Map map = new HashMap();
try { try {
JSONObject jsonObj=new WeiImageUpload().send(fileType,filePath,id,secret); JSONObject jsonObj = new WeiImageUpload().send(fileType, filePath, id, secret);
map.put("media_id", jsonObj.getString("media_id")); map.put("media_id", jsonObj.getString("media_id"));
map.put("created_at", jsonObj.getString("created_at")); map.put("created_at", jsonObj.getString("created_at"));
}
} catch (Exception e) { catch (Exception e) {
e.printStackTrace(); e.printStackTrace();
} }
return map; return map;
} }
} }
\ No newline at end of file
package hls.plugin.weixin.qiye; package hls.plugin.weixin.qiye;
import hls.plugin.weixin.common.HttpUtil; import hls.plugin.weixin.common.HttpUtil;
import java.awt.RadialGradientPaint;
import java.io.BufferedInputStream; import java.io.BufferedInputStream;
import java.io.File; import java.io.File;
import java.io.FileOutputStream; import java.io.FileOutputStream;
...@@ -12,82 +9,76 @@ import java.net.HttpURLConnection; ...@@ -12,82 +9,76 @@ import java.net.HttpURLConnection;
import java.net.URL; import java.net.URL;
import java.util.HashMap; import java.util.HashMap;
import java.util.Map; import java.util.Map;
import java.util.Random;
import net.sf.json.JSONException; import net.sf.json.JSONException;
import net.sf.json.JSONObject; import net.sf.json.JSONObject;
public class WeixinDownload { public class WeixinDownload
{
static WeixinDownload weixinMedia = null; static WeixinDownload weixinMedia = null;
/**
* 下载媒体文件: public static String downloadMedia(String accessToken, String mediaId, String savePath, String imageName)
* 获取媒体文件 {
* @param accessToken 接口访问凭证
* @param media_id 媒体文件id
* @param savePath 文件在服务器上的存储路径
* */
public static String downloadMedia(String accessToken, String mediaId, String savePath,String imageName) {
String filePath = null; String filePath = null;
// 拼接请求地址
String filetype=""; String filetype = "";
HttpURLConnection conn=null; HttpURLConnection conn = null;
BufferedInputStream bis=null; BufferedInputStream bis = null;
FileOutputStream fos=null; FileOutputStream fos = null;
String requestUrl = "https://qyapi.weixin.qq.com/cgi-bin/media/get?access_token=ACCESS_TOKEN&media_id=MEDIA_ID"; String requestUrl = "https://qyapi.weixin.qq.com/cgi-bin/media/get?access_token=ACCESS_TOKEN&media_id=MEDIA_ID";
requestUrl = requestUrl.replace("ACCESS_TOKEN", accessToken).replace("MEDIA_ID", mediaId); requestUrl = requestUrl.replace("ACCESS_TOKEN", accessToken).replace("MEDIA_ID", mediaId);
try { try {
URL url = new URL(requestUrl); URL url = new URL(requestUrl);
conn = (HttpURLConnection) url.openConnection(); conn = (HttpURLConnection)url.openConnection();
conn.setDoInput(true); conn.setDoInput(true);
conn.setRequestMethod("GET"); conn.setRequestMethod("GET");
if (!savePath.endsWith("/")) { if (!savePath.endsWith("/")) {
savePath += "/"; savePath = savePath + "/";
} }
// 根据内容类型获取扩展名
String fileExt = WeixinUtil.getTypeByStream(conn.getHeaderField("Content-Type")); String fileExt = WeixinUtil.getTypeByStream(conn.getHeaderField("Content-Type"));
// 将mediaId作为文件名
filePath = savePath + imageName +"."+fileExt.substring(fileExt.indexOf("/")+1); filePath = savePath + imageName + "." + fileExt.substring(fileExt.indexOf("/") + 1);
filetype=fileExt.substring(fileExt.indexOf("/")+1); filetype = fileExt.substring(fileExt.indexOf("/") + 1);
bis = new BufferedInputStream(conn.getInputStream()); bis = new BufferedInputStream(conn.getInputStream());
fos = new FileOutputStream(new File(filePath)); fos = new FileOutputStream(new File(filePath));
byte[] buf = new byte[8096]; byte[] buf = new byte[1024];
int size = 0; int size = 0;
while ((size = bis.read(buf)) != -1) while ((size = bis.read(buf)) != -1)
fos.write(buf, 0, size); fos.write(buf, 0, size);
}
} catch (Exception e) { catch (Exception e) {
filePath = null; filePath = null;
String error = String.format("下载媒体文件失败:%s", e); String error = String.format("ýļʧ", new Object[] { e });
System.out.println(error); e.printStackTrace();
} finally{ } finally {
if(fos!=null){ if (fos != null) {
try { try {
fos.close(); fos.close();
} catch (IOException e) { } catch (IOException e) {
e.printStackTrace(); e.printStackTrace();
} }
} }
if(bis!=null){ if (bis != null) {
try { try {
bis.close(); bis.close();
} catch (IOException e) { } catch (IOException e) {
e.printStackTrace(); e.printStackTrace();
} }
} }
if(conn!=null){ if (conn != null) {
conn.disconnect(); conn.disconnect();
} }
} }
return filetype; return filetype;
} }
public static String getNowToken(String id,String secret) { public static String getNowToken(String id, String secret) {
String returnString = ""; String returnString = "";
String requestUrl=getNowTokenURL(id,secret); String requestUrl = getNowTokenURL(id, secret);
JSONObject jsonObject = JSONObject.fromObject(HttpUtil.httpRequestUrl( JSONObject jsonObject = JSONObject.fromObject(HttpUtil.httpRequestUrl(
requestUrl, "GET")); // Http GET请求 requestUrl, "GET"));
// 如果请求成功
if (null != jsonObject) { if (jsonObject != null) {
try { try {
returnString = jsonObject.getString("access_token"); returnString = jsonObject.getString("access_token");
} catch (JSONException e) { } catch (JSONException e) {
...@@ -97,33 +88,34 @@ public class WeixinDownload { ...@@ -97,33 +88,34 @@ public class WeixinDownload {
return returnString; return returnString;
} }
public static String getNowTokenURL(String id,String secret){ public static String getNowTokenURL(String id, String secret) {
String mutiurl="https://qyapi.weixin.qq.com/cgi-bin/gettoken?corpid="+id+"&corpsecret="+secret; String mutiurl = "https://qyapi.weixin.qq.com/cgi-bin/gettoken?corpid=" + id + "&corpsecret=" + secret;
return mutiurl; return mutiurl;
} }
public static void main(String[] args) { public static void main(String[] args) {
weiDownload("wx4257809fde0f5986","iTgSpAaEYejcyPBLlyikzx6kvSVuiMBxotfAkAdWAKo6nF8cefdJSTgLXqivXpZ7","1qyU7RGN3LHdsMrqCw7VrTc85wY-Q5Z3pEk_VJKcU9E3Nx_ukMH7ik2Vp_43EiMa6VyEjpNwtuEQ2ILqoe7F5cA","G:/pad/"); weiDownload("wx4257809fde0f5986", "iTgSpAaEYejcyPBLlyikzx6kvSVuiMBxotfAkAdWAKo6nF8cefdJSTgLXqivXpZ7", "1qyU7RGN3LHdsMrqCw7VrTc85wY-Q5Z3pEk_VJKcU9E3Nx_ukMH7ik2Vp_43EiMa6VyEjpNwtuEQ2ILqoe7F5cA", "G:/pad/");
} }
private static String createImageName() { private static String createImageName() {
return (long)(Math.random()*10000000)+""; return (long)(Math.random()*10000000)+"";
// return Long.toString(System.currentTimeMillis() / 1000); // return Long.toString(System.currentTimeMillis() / 1000);
} }
public static Map<String, String> weiDownload(String id,String secret, String mediaId, String savePath){
Map<String, String> map=new HashMap<String, String>(); public static Map<String, String> weiDownload(String id, String secret, String mediaId, String savePath) {
String accessToken=getNowToken(id,secret); Map map = new HashMap();
String imageName=createImageName(); String accessToken = getNowToken(id, secret);
String filetype=downloadMedia(accessToken,mediaId,savePath,imageName); String imageName = createImageName();
String filetype = downloadMedia(accessToken, mediaId, savePath, imageName);
String fileSize=getFileSize(savePath,imageName,filetype)+""; String fileSize=getFileSize(savePath,imageName,filetype)+"";
map.put("fileName", imageName); map.put("fileName", imageName);
map.put("filetype", filetype); map.put("filetype", filetype);
map.put("fileSize", fileSize); map.put("fileSize", fileSize);
return map; return map;
} }
public static long getFileSize(String savePath,String imageName,String filetype){ public static long getFileSize(String savePath, String imageName, String filetype) {
long fileSize=0; long fileSize = 0L;
File file=new File(savePath+"/"+imageName+"."+filetype); File file = new File(savePath + "/" + imageName + "." + filetype);
if (file.exists() && file.isFile()){ if ((file.exists()) && (file.isFile())) {
fileSize=file.length()/1024; fileSize = file.length() / 1024L;
} }
return fileSize; return fileSize;
} }
......
package hls.plugin.weixin.qiye; package hls.plugin.weixin.qiye;
import hls.plugin.weixin.common.GetPropertiesValue; import hls.plugin.weixin.common.GetPropertiesValue;
import java.io.IOException; import java.io.IOException;
import java.io.PrintStream;
import java.io.PrintWriter; import java.io.PrintWriter;
import java.util.Map; import java.util.Map;
import javax.servlet.ServletException; import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse; import javax.servlet.http.HttpServletResponse;
@SuppressWarnings("serial") public class WeixinServlet extends HttpServlet
public class WeixinServlet extends HttpServlet { {
@SuppressWarnings("static-access") protected void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException
/** {
* 获得mediaId进行下载到自己微信服务器, GetPropertiesValue gp = new GetPropertiesValue();
*/ System.out.println("11111");
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { String mediaId = request.getParameter("mediaId");
GetPropertiesValue gp=new GetPropertiesValue(); String pck_id = request.getParameter("pck_id");
String mediaId=request.getParameter("mediaId"); String id = (String)gp.GetValue().get("appid");
String pck_id=request.getParameter("pck_id"); String secret = (String)gp.GetValue().get("secret");
String id=gp.GetValue().get("appid"); String winXinSavePath = (String)gp.GetValue().get("winXinSavePath");
String secret=gp.GetValue().get("secret"); String userId = request.getParameter("userId");
String winXinSavePath=gp.GetValue().get("winXinSavePath"); String tableName = request.getParameter("tableName");
String userId=request.getParameter("userId"); String table_pk_value = request.getParameter("table_pk_value");
String tableName=request.getParameter("tableName");
String table_pk_value=request.getParameter("table_pk_value"); new WeixinDownload(); Map map = WeixinDownload.weiDownload(id, secret, mediaId, winXinSavePath);
String fileName = (String)map.get("fileName");
String filetype = (String)map.get("filetype");
//下载 String fileSize = (String)map.get("fileSize");
Map<String,String> map=new WeixinDownload().weiDownload(id,secret,mediaId,winXinSavePath);
String fileName=map.get("fileName");
String filetype=map.get("filetype");
String fileSize=map.get("fileSize");
try { try {
new WeiImagePostTo().send(mediaId, pck_id, fileName, filetype, fileSize,userId,tableName,table_pk_value); new WeiImagePostTo().send(mediaId, pck_id, fileName, filetype, fileSize, userId, tableName, table_pk_value);
} catch (Exception e) { } catch (Exception e) {
e.printStackTrace(); e.printStackTrace();
} }
//回执
PrintWriter pw = response.getWriter(); PrintWriter pw = response.getWriter();
pw.println("OK!!"); pw.println("OK!!");
pw.flush(); pw.flush();
pw.close(); pw.close();
} }
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
doGet(request, response); doGet(request, response);
} }
} }
\ No newline at end of file
package hls.plugin.weixin.qiye; package hls.plugin.weixin.qiye;
public class WeixinUtil
{
public class WeixinUtil { public static String getTypeByStream(String cot)
{
public static String getTypeByStream(String cot){
String type = cot.toUpperCase(); String type = cot.toUpperCase();
if(type.contains("FFD8FF")){ if (type.contains("FFD8FF"))
return "jpg"; return "jpg";
}else if(type.contains("89504E47")){ if (type.contains("89504E47"))
return "png"; return "png";
}else if(type.contains("47494638")){ if (type.contains("47494638"))
return "gif"; return "gif";
}else if(type.contains("49492A00")){ if (type.contains("49492A00"))
return "tif"; return "tif";
}else if(type.contains("424D")){ if (type.contains("424D")) {
return "bmp"; return "bmp";
} }
return type.toLowerCase(); return type.toLowerCase();
......
...@@ -8,16 +8,17 @@ import java.util.HashMap; ...@@ -8,16 +8,17 @@ import java.util.HashMap;
import java.util.Map; import java.util.Map;
import java.util.UUID; import java.util.UUID;
public class WxJSsign { public class WxJSsign
{
public static Map<String, String> sign(String jsapi_ticket,String url){ public static Map<String, String> sign(String jsapi_ticket, String url)
Map<String, String> ret = new HashMap<String, String>(); {
Map ret = new HashMap();
String nonce_str = create_nonce_str(); String nonce_str = create_nonce_str();
String timestamp = create_timestamp(); String timestamp = create_timestamp();
String string1;
String signature = ""; String signature = "";
// 注意这里参数名必须全部小写,且必须有序
string1 = "jsapi_ticket=" + jsapi_ticket + "&noncestr=" + nonce_str + "&timestamp=" + timestamp + "&url=" + url; String string1 = "jsapi_ticket=" + jsapi_ticket + "&noncestr=" + nonce_str + "&timestamp=" + timestamp + "&url=" + url;
try { try {
MessageDigest crypt = MessageDigest.getInstance("SHA-1"); MessageDigest crypt = MessageDigest.getInstance("SHA-1");
crypt.reset(); crypt.reset();
...@@ -34,24 +35,22 @@ public static Map<String, String> sign(String jsapi_ticket,String url){ ...@@ -34,24 +35,22 @@ public static Map<String, String> sign(String jsapi_ticket,String url){
ret.put("timestamp", timestamp); ret.put("timestamp", timestamp);
ret.put("signature", signature); ret.put("signature", signature);
return ret; return ret;
} }
private static String create_nonce_str() { private static String create_nonce_str() {
return UUID.randomUUID().toString(); return UUID.randomUUID().toString();
} }
private static String create_timestamp() { private static String create_timestamp() {
return Long.toString(System.currentTimeMillis() / 1000); return Long.toString(System.currentTimeMillis() / 1000L);
} }
private static String byteToHex(final byte[] hash) { private static String byteToHex(byte[] hash) {
Formatter formatter = new Formatter(); Formatter formatter = new Formatter();
for (byte b : hash) { byte[] arrayOfByte = hash; int j = hash.length; for (int i = 0; i < j; i++) { byte b = arrayOfByte[i];
formatter.format("%02x", b); formatter.format("%02x", new Object[] { Byte.valueOf(b) });
} }
String result = formatter.toString(); String result = formatter.toString();
formatter.close(); formatter.close();
return result; return result;
} }
} }
\ No newline at end of file
package hls.plugin.weixin.qiye; package hls.plugin.weixin.qiye;
import hls.plugin.weixin.common.GetPropertiesValue; import hls.plugin.weixin.common.GetPropertiesValue;
import java.io.FileOutputStream; import java.io.FileOutputStream;
import java.io.IOException; import java.io.IOException;
import java.io.InputStream; import java.io.InputStream;
import java.io.ObjectInputStream;
import java.io.OutputStream; import java.io.OutputStream;
import java.io.PrintWriter; import java.io.PrintStream;
import java.util.Map;
import javax.servlet.ServletException; import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse; import javax.servlet.http.HttpServletResponse;
@SuppressWarnings("serial") public class ZuLinServlet extends HttpServlet
public class ZuLinServlet extends HttpServlet { {
@SuppressWarnings("static-access") protected void doGet(HttpServletRequest request, HttpServletResponse response)
/** throws ServletException, IOException
* 获得mediaId进行下载,并且保存参数到数据库 {
*/
protected void doGet(HttpServletRequest request,
HttpServletResponse response) throws ServletException, IOException {
doPost(request, response); doPost(request, response);
} }
protected void doPost(HttpServletRequest request,
HttpServletResponse response) throws ServletException, IOException { protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException
//request.setCharacterEncoding("utf-8"); {
InputStream in=null; InputStream in = null;
OutputStream out=null; OutputStream out = null;
GetPropertiesValue gp = new GetPropertiesValue(); GetPropertiesValue gp = new GetPropertiesValue();
//String mediaId = request.getParameter("mediaId");
String pck_id = request.getParameter("pck_id"); String pck_id = request.getParameter("pck_id");
String file_name = request.getParameter("fileName"); String file_name = request.getParameter("fileName") + "." + request.getParameter("filetype");
String mime_type = request.getParameter("filetype");
String file_size = request.getParameter("fileSize"); String file_size = request.getParameter("fileSize");
String userId = request.getParameter("userId"); String userId = request.getParameter("userId");
int userId2 = Integer.parseInt(userId); int userId2 = Integer.parseInt(userId);
String tableName = request.getParameter("tableName"); String tableName = request.getParameter("tableName");
String table_pk_value = request.getParameter("table_pk_value"); String table_pk_value = request.getParameter("table_pk_value");
int file_size_int = Integer.parseInt(file_size); int file_size_int = Integer.parseInt(file_size);
String file_type_code =gp.GetValue().get("file_type_code"); String file_type_code = request.getParameter("filetype");
System.out.println("file_type_code>>"+file_type_code); String mime_type = (String)gp.GetValue().get("file_type_code") + "/" + request.getParameter("filetype");
System.out.println("file_size_int>>"+file_size_int);
System.out.println("table_pk_value>>"+table_pk_value);
System.out.println("tableName>>"+tableName);
System.out.println("file_size>>"+file_size);
String filepath =
System.out.println("mime_type>>"+mime_type); (String)gp.GetValue()
System.out.println("file_name>>"+file_name); .get("zuLinsavePath") +
String filepath = gp.GetValue().get( "/" + file_name;
"zuLinsavePath") System.out.println("filepath>>>" + filepath);
+ "/" + file_name+"."+mime_type;
System.out.println("filepath>>>"+filepath);
try { try {
in =request.getInputStream(); in = request.getInputStream();
out = new FileOutputStream(filepath); out = new FileOutputStream(filepath);
int bytes = -1; int bytes = -1;
byte[] bufferOut = new byte[1024]; byte[] bufferOut = new byte[1024];
while ((bytes = in.read(bufferOut)) != -1) { while ((bytes = in.read(bufferOut)) != -1)
out.write(bufferOut, 0, bytes); out.write(bufferOut, 0, bytes);
} }
} catch (Exception e) { catch (Exception e) {
e.printStackTrace(); e.printStackTrace();
}finally{ } finally {
if(in!=null){ if (in != null) {
in.close(); in.close();
} }
if(out!=null){ if (out != null) {
out.flush(); out.flush();
out.close(); out.close();
} }
} }
// 保存数据到数据库 FndAtmAttachment fnd = new FndAtmAttachment(table_pk_value, file_type_code, mime_type, file_name, file_size_int, filepath, userId2, tableName, pck_id);
FndAtmAttachment fnd = new FndAtmAttachment(table_pk_value,file_type_code,mime_type,file_name,file_size_int,filepath,userId2,tableName,pck_id); boolean ss = new WeCatDaoImpl().save(fnd);
boolean ss =new WeCatDaoImpl().save(fnd);
System.out.println(ss); System.out.println(ss);
} }
} }
\ No newline at end of file
\u8D26\u53F7
appid=wx4257809fde0f5986
\u5BC6\u7801
secret=lyJAj3vUqDg2BJp4Yc2ZLq9qwCX1rOXKV8OHSTD7JqY
\u5FAE\u4FE1\u670D\u52A1\u5668\u4FDD\u5B58\u5730\u5740
weiXinSavePath=/u01/web/JUNCHUANG_WX/attachment
\u79DF\u8D41\u4FDD\u5B58\u5730\u5740
zuLinsavePath=/u01/web/JUNCHUANG_WX/attachment
\u5FAE\u4FE1\u670D\u52A1\u5668\u8BF7\u6C42\u5730\u5740
weixinserviceUrl=http://172.20.0.115:5371/junchuang_wx/WeixinServlet
file_type_code=image
\u79DF\u8D41\u8BF7\u6C42\u5730\u5740
zuLinserviceUrl=http://172.20.0.115:5371/junchuang_wx/ZuLinServlet
\ No newline at end of file
oracleDriver=oracle.jdbc.driver.OracleDriver oracleDriver=oracle.jdbc.driver.OracleDriver
url=jdbc:oracle:thin:@10.0.36.97:1521:hls url=jdbc:oracle:thin:@172.20.0.115:1521:hls
# url=jdbc:oracle:thin:@172.20.0.115:1521:hls username=jc_hls
username=hls_standard password=jc_hls
password=hls_standard \ No newline at end of file
\ No newline at end of file
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment