本文目錄一覽:
- 1、怎麼用java調用微信支付接口
- 2、用Java怎麼實現微信支付?
- 3、如何用java開發微信
- 4、如何實現java程序與微信公眾平台之間實現消息推送
- 5、java設計微信賬號類,微信號,手機號,昵稱怎麼寫
- 6、微信支付Java如何判斷回調
怎麼用java調用微信支付接口
java調用微信支付接口方法:\x0d\x0aRequestHandlerrequestHandler=newRequestHandler(super.getRequest(),super.getResponse());\x0d\x0a\x0d\x0a//獲取token//兩小時內有效,兩小時後重新獲取\x0d\x0a\x0d\x0aToken=requestHandler.GetToken();\x0d\x0a\x0d\x0a//更新token到應用中\x0d\x0a\x0d\x0arequestHandler.getTokenReal();\x0d\x0a\x0d\x0aSystem.out.println(“微信支付獲取token=======================:”+Token);\x0d\x0a\x0d\x0a\x0d\x0a\x0d\x0a//requestHandler初始化\x0d\x0a\x0d\x0arequestHandler.init();\x0d\x0a\x0d\x0arequestHandler.init(appid,appsecret,appkey,partnerkey,key);\x0d\x0a\x0d\x0a\x0d\x0a\x0d\x0a//——————————–本地系統生成訂單————————————-\x0d\x0a\x0d\x0a//設置package訂單參數\x0d\x0a\x0d\x0aSortedMappackageParams=newTreeMap();\x0d\x0a\x0d\x0apackageParams.put(“bank_type”,”WX”);//支付類型\x0d\x0a\x0d\x0apackageParams.put(“body”,”xxxx”);//商品描述\x0d\x0a\x0d\x0apackageParams.put(“fee_type”,”1″);//銀行幣種\x0d\x0a\x0d\x0apackageParams.put(“input_charset”,”UTF-8″);//字符集\x0d\x0a\x0d\x0apackageParams.put(“notify_url”,””);//通知地址這裡的通知地址使用外網地址測試,注意80端口是否打開。\x0d\x0a\x0d\x0apackageParams.put(“out_trade_no”,no);//商戶訂單號\x0d\x0a\x0d\x0apackageParams.put(“partner”,partenerid);//設置商戶號\x0d\x0a\x0d\x0apackageParams.put(“spbill_create_ip”,super.getRequest().getRemoteHost());//訂單生成的機器IP,指用戶瀏覽器端IP\x0d\x0a\x0d\x0apackageParams.put(“total_fee”,String.valueOf(rstotal));//商品總金額,以分為單位\x0d\x0a\x0d\x0a\x0d\x0a\x0d\x0a//設置支付參數\x0d\x0a\x0d\x0aSortedMapsignParams=newTreeMap();\x0d\x0a\x0d\x0asignParams.put(“appid”,appid);\x0d\x0a\x0d\x0asignParams.put(“noncestr”,noncestr);\x0d\x0a\x0d\x0asignParams.put(“traceid”,PropertiesUtils.getOrderNO());\x0d\x0a\x0d\x0asignParams.put(“timestamp”,timestamp);\x0d\x0a\x0d\x0asignParams.put(“package”,packageValue);\x0d\x0a\x0d\x0asignParams.put(“appkey”,this.appkey);\x0d\x0a\x0d\x0a\x0d\x0a\x0d\x0a//生成支付簽名,要採用URLENCODER的原始值進行SHA1算法!\x0d\x0a\x0d\x0aStringsign=””;\x0d\x0a\x0d\x0atry{\x0d\x0a\x0d\x0asign=Sha1Util.createSHA1Sign(signParams);\x0d\x0a\x0d\x0a}catch(Exceptione){\x0d\x0a\x0d\x0ae.printStackTrace();\x0d\x0a\x0d\x0a}\x0d\x0a\x0d\x0a\x0d\x0a\x0d\x0a//增加非參與簽名的額外參數\x0d\x0a\x0d\x0asignParams.put(“sign_method”,”sha1″);\x0d\x0a\x0d\x0asignParams.put(“app_signature”,sign);\x0d\x0a\x0d\x0a\x0d\x0a\x0d\x0a\x0d\x0a\x0d\x0a//api支付拼包結束————————————\x0d\x0a\x0d\x0a\x0d\x0a\x0d\x0a//獲取prepayid\x0d\x0a\x0d\x0aStringprepayid=requestHandler.sendPrepay(signParams);\x0d\x0a\x0d\x0aSystem.out.println(“prepayid:”+prepayid);\x0d\x0a\x0d\x0a\x0d\x0a\x0d\x0a\x0d\x0a\x0d\x0a\x0d\x0a\x0d\x0a//——————————–生成完成———————————————\x0d\x0a\x0d\x0a\x0d\x0a\x0d\x0a//生成預付快訂單完成,返回給android,ios掉起微信所需要的參數。\x0d\x0a\x0d\x0aSortedMappayParams=newTreeMap();\x0d\x0a\x0d\x0apayParams.put(“appid”,appid);\x0d\x0a\x0d\x0apayParams.put(“noncestr”,noncestr);\x0d\x0a\x0d\x0apayParams.put(“package”,”Sign=WXPay”);\x0d\x0a\x0d\x0apayParams.put(“partnerid”,partenerid);\x0d\x0a\x0d\x0apayParams.put(“prepayid”,prepayid);\x0d\x0a\x0d\x0apayParams.put(“appkey”,this.appkey);\x0d\x0a\x0d\x0a//這裡除1000是因為參數長度限制。\x0d\x0a\x0d\x0ainttime=(int)(System.currentTimeMillis()/1000);\x0d\x0a\x0d\x0apayParams.put(“timestamp”,String.valueOf(time));\x0d\x0a\x0d\x0a\x0d\x0a\x0d\x0aSystem.out.println(“timestamp:”+time);\x0d\x0a\x0d\x0a\x0d\x0a\x0d\x0a//簽名\x0d\x0a\x0d\x0aStringpaysign=””;\x0d\x0a\x0d\x0atry{\x0d\x0a\x0d\x0apaysign=Sha1Util.createSHA1Sign(payParams);\x0d\x0a\x0d\x0a}catch(Exceptione){\x0d\x0a\x0d\x0ae.printStackTrace();\x0d\x0a\x0d\x0a}\x0d\x0a\x0d\x0apayParams.put(“sign”,paysign);\x0d\x0a\x0d\x0a\x0d\x0a\x0d\x0a//拼json數據返回給客戶端\x0d\x0a\x0d\x0aBasicDBObjectbackObject=newBasicDBObject();\x0d\x0a\x0d\x0abackObject.put(“appid”,appid);\x0d\x0a\x0d\x0abackObject.put(“noncestr”,payParams.get(“noncestr”));\x0d\x0a\x0d\x0abackObject.put(“package”,”Sign=WXPay”);\x0d\x0a\x0d\x0abackObject.put(“partnerid”,payParams.get(“partnerid”));\x0d\x0a\x0d\x0abackObject.put(“prepayid”,payParams.get(“prepayid”));\x0d\x0a\x0d\x0abackObject.put(“appkey”,this.appkey);\x0d\x0a\x0d\x0abackObject.put(“timestamp”,payParams.get(“timestamp”));\x0d\x0a\x0d\x0abackObject.put(“sign”,payParams.get(“sign”));\x0d\x0a\x0d\x0a\x0d\x0a\x0d\x0aStringbackstr=dataObject.toString();\x0d\x0a\x0d\x0aSystem.out.println(“backstr:”+backstr);\x0d\x0a\x0d\x0a\x0d\x0a\x0d\x0areturnbackstr;\x0d\x0a\x0d\x0a\x0d\x0a\x0d\x0a====================到此為止,預付款訂單已生成,並且已返回客戶端====================\x0d\x0a\x0d\x0a\x0d\x0a\x0d\x0a//坐等微信服務器通知,通知的地址就是生成預付款訂單的notify_url\x0d\x0a\x0d\x0a\x0d\x0a\x0d\x0aResponseHandlerresHandler=newResponseHandler(request,response);\x0d\x0a\x0d\x0aresHandler.setKey(partnerkey);\x0d\x0a\x0d\x0a//創建請求對象\x0d\x0a\x0d\x0a//RequestHandlerqueryReq=newRequestHandler(request,response);\x0d\x0a\x0d\x0a//queryReq.init();\x0d\x0a\x0d\x0aif(resHandler.isTenpaySign()==true){\x0d\x0a\x0d\x0a//商戶訂單號\x0d\x0a\x0d\x0aStringout_trade_no=resHandler.getParameter(“out_trade_no”);\x0d\x0a\x0d\x0aSystem.out.println(“out_trade_no:”+out_trade_no);\x0d\x0a\x0d\x0a//財付通訂單號\x0d\x0a\x0d\x0aStringtransaction_id=resHandler.getParameter(“transaction_id”);\x0d\x0a\x0d\x0aSystem.out.println(“transaction_id:”+transaction_id);\x0d\x0a\x0d\x0a//金額,以分為單位\x0d\x0a\x0d\x0aStringtotal_fee=resHandler.getParameter(“total_fee”);\x0d\x0a\x0d\x0a//如果有使用折扣券,discount有值,total_fee+discount=原請求的total_fee\x0d\x0a\x0d\x0aStringdiscount=resHandler.getParameter(“discount”);\x0d\x0a\x0d\x0a//支付結果\x0d\x0a\x0d\x0aStringtrade_state=resHandler.getParameter(“trade_state”);\x0d\x0a\x0d\x0a\x0d\x0a\x0d\x0a//判斷簽名及結果\x0d\x0a\x0d\x0aif(“0”.equals(trade_state)){\x0d\x0a\x0d\x0a//——————————\x0d\x0a\x0d\x0a//即時到賬處理業務開始\x0d\x0a\x0d\x0a//——————————\x0d\x0a\x0d\x0a\x0d\x0a\x0d\x0aSystem.out.println(“—————-業務邏輯執行—————–“);\x0d\x0a\x0d\x0a\x0d\x0a\x0d\x0a//——請根據您的業務邏輯來編寫程序(以上代碼僅作參考)——\x0d\x0a\x0d\x0aSystem.out.println(“—————-業務邏輯執行完畢—————–“);\x0d\x0a\x0d\x0aSystem.out.println(“success”);//請不要修改或刪除\x0d\x0a\x0d\x0a\x0d\x0a\x0d\x0aSystem.out.println(“即時到賬支付成功”);\x0d\x0a\x0d\x0a//給財付通系統發送成功信息,財付通系統收到此結果後不再進行後續通知\x0d\x0a\x0d\x0aresHandler.sendToCFT(“success”);\x0d\x0a\x0d\x0a\x0d\x0a\x0d\x0a//給微信服務器返回success否則30分鐘通知8次\x0d\x0a\x0d\x0areturn”success”;\x0d\x0a\x0d\x0a}else{\x0d\x0a\x0d\x0aSystem.out.println(“通知簽名驗證失敗”);\x0d\x0a\x0d\x0aresHandler.sendToCFT(“fail”);\x0d\x0a\x0d\x0aresponse.setCharacterEncoding(“utf-8”);\x0d\x0a\x0d\x0a}\x0d\x0a\x0d\x0a}else{\x0d\x0a\x0d\x0aSystem.out.println(“fail-Md5failed”);
用Java怎麼實現微信支付?
具體方法步驟:
一、準備階段:已認證微信號,且通過微信支付認證,這個可以看微信文檔,很詳細,這裡就不再重複。
二、配置授權目錄,官方推薦使用https類型的url,不知道http能不能行,個人也推薦使用https的保證不會錯。
配置授權域名
三、微信支付二次開發所需要的參數:
APP_ID,APP_KEY,PARTNER,PARTNER_KEY(AppSecret)
APP_ID和PARTNER_KEY(AppSecret)
PARTNER
APP_KEY(自行設置32位字符)
四、具體編程
1、通過頁面跳轉到確認支付頁面,其中的redirect_uri必須是配置授權目錄下的。
2、獲取到openid,再經服務器向微信請求獲取prepay_id,封裝字段並進行簽名後通過jsapi調起微信支付
3、測試結果
如何用java開發微信
說明:
本次的教程主要是對微信公眾平台開發者模式的講解,網絡上很多類似文章,但很多都讓初學微信開發的人一頭霧水,所以總結自己的微信開發經驗,將微信開發的整個過程系統的列出,並對主要代碼進行講解分析,讓初學者儘快上手。
在閱讀本文之前,應對微信公眾平台的官方開發文檔有所了解,知道接收和發送的都是xml格式的數據。另外,在做內容回復時用到了圖靈機器人的api接口,這是一個自然語言解析的開放平台,可以幫我們解決整個微信開發過程中最困難的問題,此處不多講,下面會有其詳細的調用方式。
1.1 在登錄微信官方平台之後,開啟開發者模式,此時需要我們填寫url和token,所謂url就是我們自己服務器的接口,用WechatServlet.java來實現,相關解釋已經在注釋中說明,代碼如下:
[java] view plain copy
package demo.servlet;
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.OutputStream;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import demo.process.WechatProcess;
/**
* 微信服務端收發消息接口
*
* @author pamchen-1
*
*/
public class WechatServlet extends HttpServlet {
/**
* The doGet method of the servlet. br
*
* This method is called when a form has its tag value method equals to get.
*
* @param request
* the request send by the client to the server
* @param response
* the response send by the server to the client
* @throws ServletException
* if an error occurred
* @throws IOException
* if an error occurred
*/
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
request.setCharacterEncoding(“UTF-8”);
response.setCharacterEncoding(“UTF-8”);
/** 讀取接收到的xml消息 */
StringBuffer sb = new StringBuffer();
InputStream is = request.getInputStream();
InputStreamReader isr = new InputStreamReader(is, “UTF-8”);
BufferedReader br = new BufferedReader(isr);
String s = “”;
while ((s = br.readLine()) != null) {
sb.append(s);
}
String xml = sb.toString(); //次即為接收到微信端發送過來的xml數據
String result = “”;
/** 判斷是否是微信接入激活驗證,只有首次接入驗證時才會收到echostr參數,此時需要把它直接返回 */
String echostr = request.getParameter(“echostr”);
if (echostr != null echostr.length() 1) {
result = echostr;
} else {
//正常的微信處理流程
result = new WechatProcess().processWechatMag(xml);
}
try {
OutputStream os = response.getOutputStream();
os.write(result.getBytes(“UTF-8”));
os.flush();
os.close();
} catch (Exception e) {
e.printStackTrace();
}
}
/**
* The doPost method of the servlet. br
*
* This method is called when a form has its tag value method equals to
* post.
*
* @param request
* the request send by the client to the server
* @param response
* the response send by the server to the client
* @throws ServletException
* if an error occurred
* @throws IOException
* if an error occurred
*/
public void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
doGet(request, response);
}
}
1.2 相應的web.xml配置信息如下,在生成WechatServlet.java的同時,可自動生成web.xml中的配置。前面所提到的url處可以填寫例如:http;//服務器地址/項目名/wechat.do
[html] view plain copy
?xml version=”1.0″ encoding=”UTF-8″?
web-app version=”2.5″
xmlns=””
xmlns:xsi=””
xsi:schemaLocation=”
“
servlet
descriptionThis is the description of my J2EE component/description
display-nameThis is the display name of my J2EE component/display-name
servlet-nameWechatServlet/servlet-name
servlet-classdemo.servlet.WechatServlet/servlet-class
/servlet
servlet-mapping
servlet-nameWechatServlet/servlet-name
url-pattern/wechat.do/url-pattern
/servlet-mapping
welcome-file-list
welcome-fileindex.jsp/welcome-file
/welcome-file-list
/web-app
1.3 通過以上代碼,我們已經實現了微信公眾平台開發的框架,即開通開發者模式並成功接入、接收消息和發送消息這三個步驟。
下面就講解其核心部分——解析接收到的xml數據,並以文本類消息為例,通過圖靈機器人api接口實現智能回復。
2.1 首先看一下整體流程處理代碼,包括:xml數據處理、調用圖靈api、封裝返回的xml數據。
[java] view plain copy
package demo.process;
import java.util.Date;
import demo.entity.ReceiveXmlEntity;
/**
* 微信xml消息處理流程邏輯類
* @author pamchen-1
*
*/
public class WechatProcess {
/**
* 解析處理xml、獲取智能回復結果(通過圖靈機器人api接口)
* @param xml 接收到的微信數據
* @return 最終的解析結果(xml格式數據)
*/
public String processWechatMag(String xml){
/** 解析xml數據 */
ReceiveXmlEntity xmlEntity = new ReceiveXmlProcess().getMsgEntity(xml);
/** 以文本消息為例,調用圖靈機器人api接口,獲取回復內容 */
String result = “”;
if(“text”.endsWith(xmlEntity.getMsgType())){
result = new TulingApiProcess().getTulingResult(xmlEntity.getContent());
}
/** 此時,如果用戶輸入的是“你好”,在經過上面的過程之後,result為“你也好”類似的內容
* 因為最終回復給微信的也是xml格式的數據,所有需要將其封裝為文本類型返回消息
* */
result = new FormatXmlProcess().formatXmlAnswer(xmlEntity.getFromUserName(), xmlEntity.getToUserName(), result);
return result;
}
}
2.2 解析接收到的xml數據,此處有兩個類,ReceiveXmlEntity.java和ReceiveXmlProcess.java,通過反射的機制動態調用實體類中的set方法,可以避免很多重複的判斷,提高代碼效率,代碼如下:
[java] view plain copy
package demo.entity;
/**
* 接收到的微信xml實體類
* @author pamchen-1
*
*/
public class ReceiveXmlEntity {
private String ToUserName=””;
private String FromUserName=””;
private String CreateTime=””;
private String MsgType=””;
private String MsgId=””;
private String Event=””;
private String EventKey=””;
private String Ticket=””;
private String Latitude=””;
private String Longitude=””;
private String Precision=””;
private String PicUrl=””;
private String MediaId=””;
private String Title=””;
private String Description=””;
private String Url=””;
private String Location_X=””;
private String Location_Y=””;
private String Scale=””;
private String Label=””;
private String Content=””;
private String Format=””;
private String Recognition=””;
public String getRecognition() {
return Recognition;
}
public void setRecognition(String recognition) {
Recognition = recognition;
}
public String getFormat() {
return Format;
}
public void setFormat(String format) {
Format = format;
}
public String getContent() {
return Content;
}
public void setContent(String content) {
Content = content;
}
public String getLocation_X() {
return Location_X;
}
public void setLocation_X(String locationX) {
Location_X = locationX;
}
public String getLocation_Y() {
return Location_Y;
}
public void setLocation_Y(String locationY) {
Location_Y = locationY;
}
public String getScale() {
return Scale;
}
public void setScale(String scale) {
Scale = scale;
}
public String getLabel() {
return Label;
}
public void setLabel(String label) {
Label = label;
}
public String getTitle() {
return Title;
}
public void setTitle(String title) {
Title = title;
}
public String getDescription() {
return Description;
}
public void setDescription(String description) {
Description = description;
}
public String getUrl() {
return Url;
}
public void setUrl(String url) {
Url = url;
}
public String getPicUrl() {
return PicUrl;
}
public void setPicUrl(String picUrl) {
PicUrl = picUrl;
}
public String getMediaId() {
return MediaId;
}
public void setMediaId(String mediaId) {
MediaId = mediaId;
}
public String getEventKey() {
return EventKey;
}
public void setEventKey(String eventKey) {
EventKey = eventKey;
}
public String getTicket() {
return Ticket;
}
public void setTicket(String ticket) {
Ticket = ticket;
}
public String getLatitude() {
return Latitude;
}
public void setLatitude(String latitude) {
Latitude = latitude;
}
public String getLongitude() {
return Longitude;
}
public void setLongitude(String longitude) {
Longitude = longitude;
}
public String getPrecision() {
return Precision;
}
public void setPrecision(String precision) {
Precision = precision;
}
public String getEvent() {
return Event;
}
public void setEvent(String event) {
Event = event;
}
public String getMsgId() {
return MsgId;
}
public void setMsgId(String msgId) {
MsgId = msgId;
}
public String getToUserName() {
return ToUserName;
}
public void setToUserName(String toUserName) {
如何實現java程序與微信公眾平台之間實現消息推送
java程序與微信公眾平台之間實現消息推送方法:
1、本地數據庫中存放着小程序用戶表和微信公眾號的表,下面就是向某一個小程序用戶推送微信公眾號信息
2、在小程序用戶表中任意取一個用戶A信息,用戶A的openId和unionId,通過unionId到公眾號表裡去檢索對應的A用戶微信公眾號的openId
3、在微信公眾號上選擇一個模板消息,編輯完要發送的的內容後,再請求發送模板消息的接口
關於微信公眾號不能推送的,或者推送報錯的,推送的miniprogram下的appid對應的小程序必須是已審核並發布的才可以推送。
推送軟件用極光推送,實現多種消息類型,開發者可以輕鬆地通過極光發送各個移動平台的系統通知,還可以在控制台編輯多種富文本展示模板; 極光還提供自定義消息的透傳,客戶端接到消息內容後根據自己的邏輯自由處理。
java設計微信賬號類,微信號,手機號,昵稱怎麼寫
1、首先打開《java》這款軟件。
2、其次輸入個人賬號密碼點擊登錄。
3、最後在軟件中輸入微信賬號類,微信號。手機號。昵稱點擊編寫即可。
微信支付Java如何判斷回調
微信支付Java判斷回調方法:
微信支付完成支付調用的時候,在傳入的參數中有一個是執行支付完成之後結果回調的參數,這個回調函數就是微信調用這個接口來將支付成功的結果。
原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/302842.html