EasyPay(易支付)
Introduction(介紹)
This is a library for Developers easily to use Alipay,WechatPay and UnionPay in Android project.
EasyPay(易支付)集成并高度封裝了Android平臺的微信支付,支付寶支付以銀聯(lián)支付咒循。使用此庫据途,開發(fā)者可以使用簡單輕松方便的api實現(xiàn)支付功能,大量節(jié)省集成配置時間叙甸。
易支付編碼實現(xiàn)遵循設(shè)計模式六大原則颖医,并且使用了單例以及策略模式來實現(xiàn)整個庫,擴展性良好,可以輕松擴展其他支付方式如百度,美團等裆蒸。支付方式類繼承IPayStrategy接口熔萧,支付信息類實現(xiàn)IPayInfo接口,再分別傳入場景類EasyPay中即可。具體請參照代碼中支付寶或者微信或者銀聯(lián)支付方式封裝佛致。
##項目結(jié)構(gòu)
├── activity
│ ├── UnionPayAssistActivity.java //銀聯(lián)輔助Activity贮缕,負責(zé)調(diào)起銀聯(lián)支付接口以及接收回調(diào)“秤埽客戶端無需關(guān)心感昼。
│ └── WXPayEntryBaseActivity.java //微信支付回調(diào)Activity封裝」藜梗客戶端需繼承該Activity并實現(xiàn)getAppId()方法定嗓。
├── alipay
│ ├── AliPay.java //支付寶支付api封裝,實現(xiàn)了IPayStrategy接口
│ ├── AlipayInfoImpli.java
│ └── AliPayResult.java
├── base
│ ├── IPayInfo.java //易支付支付信息基類接口
│ └── IPayStrategy.java //易支付支付策略基類接口
├── callback
│ └── IPayCallback.java //易支付統(tǒng)一回調(diào)接口
├── EasyPay.java //易支付場景類萍桌,客戶端調(diào)用者
├── unionpay
│ ├── Mode.java
│ ├── UnionPay.java //銀聯(lián)支付api封裝宵溅,,實現(xiàn)了IPayStrategy接口
│ └── UnionPayInfoImpli.java
└── wxpay
├── WXPay.java //微信支付api封裝上炎,實現(xiàn)了IPayStrategy接口
└── WXPayInfoImpli.java
Screenshot(截屏)
screenshot.gif
Usage(使用)
step 1
在build.gradle直接引用 :
compile 'com.xgr.easypay:EasyPay:1.0.2'
下載庫后作為module導(dǎo)入:
compile project(':easypay')
Or Maven :
<dependency>
<groupId>com.xgr.easypay</groupId>
<artifactId>EasyPay</artifactId>
<version>1.0.2</version>
<type>pom</type>
</dependency>
step 2
銀聯(lián)支付:
配置:無需配置
編碼:
private void unionpay(){
//實例化銀聯(lián)支付策略
UnionPay unionPay = new UnionPay();
//構(gòu)造銀聯(lián)訂單實體恃逻。一般都是由服務(wù)端直接返回。測試時可以用Mode.TEST,發(fā)布時用Mode.RELEASE反症。
UnionPayInfoImpli unionPayInfoImpli = new UnionPayInfoImpli();
unionPayInfoImpli.setTn("814144587819703061900");
unionPayInfoImpli.setMode(Mode.TEST);
//策略場景類調(diào)起支付方法開始支付辛块,以及接收回調(diào)。
EasyPay.pay(unionPay, this, unionPayInfoImpli, new IPayCallback() {
@Override
public void success() {
toast("支付成功");
}
@Override
public void failed() {
toast("支付失敗");
}
@Override
public void cancel() {
toast("支付取消");
}
});
}
微信支付:
配置:(具體可參考demo項目)
- 在你的項目包名(applicationId:com.xxx.xxx)目錄下建立.wxapi(如com.xxx.xxx.wxapi)目 錄铅碍。在目錄下新建WXPayEntryActivity.java,繼承WXPayEntryBaseActivity.java,實現(xiàn)getWXAppId()方法。
public class WXPayEntryActivity extends WXPayEntryBaseActivity {
@Override
public String getWXAppId() {
return "appid";
}
}
- 在AndroidManifest.xml中注冊上述Activity.
<activity
android:name=".wxapi.WXPayEntryActivity"
android:exported="true"
android:launchMode="singleTop"
android:theme="@android:style/Theme.Translucent.NoTitleBar"/>
編碼:
private void wxpay(){
//實例化微信支付策略
String wxAppId = "";
WXPay wxPay = WXPay.getInstance(this,wxAppId);
//構(gòu)造微信訂單實體线椰。一般都是由服務(wù)端直接返回胞谈。
WXPayInfoImpli wxPayInfoImpli = new WXPayInfoImpli();
wxPayInfoImpli.setTimestamp("");
wxPayInfoImpli.setSign("");
wxPayInfoImpli.setPrepayId("");
wxPayInfoImpli.setPartnerid("");
wxPayInfoImpli.setAppid("");
wxPayInfoImpli.setNonceStr("");
wxPayInfoImpli.setPackageValue("");
//策略場景類調(diào)起支付方法開始支付,以及接收回調(diào)憨愉。
EasyPay.pay(wxPay, this, wxPayInfoImpli, new IPayCallback() {
@Override
public void success() {
toast("支付成功");
}
@Override
public void failed() {
toast("支付失敗");
}
@Override
public void cancel() {
toast("支付取消");
}
});
}
支付寶支付:
配置:無需配置烦绳。
編碼:
private void alipay(){
//實例化支付寶支付策略
AliPay aliPay = new AliPay();
//構(gòu)造支付寶訂單實體。一般都是由服務(wù)端直接返回配紫。
AlipayInfoImpli alipayInfoImpli = new AlipayInfoImpli();
alipayInfoImpli.setOrderInfo("");
//策略場景類調(diào)起支付方法開始支付径密,以及接收回調(diào)。
EasyPay.pay(aliPay, this, alipayInfoImpli, new IPayCallback() {
@Override
public void success() {
toast("支付成功");
}
@Override
public void failed() {
toast("支付失敗");
}
@Override
public void cancel() {
toast("支付取消");
}
});
}
沒錯躺孝,就是這樣享扔,這就搞定了。
由于水平有限植袍,難免會有錯誤惧眠。請大家多多指教。
有任何問題請在issues里面留言交流于个。Issues.
Contact Me(聯(lián)系我)
- Email : kingofglory@yeah.net
- Weibo : @King的沉積時代
License
MIT License
Copyright (c) 2017 kingofglory
Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files (the "Software"), to deal
in the Software without restriction, including without limitation the rights
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
copies of the Software, and to permit persons to whom the Software is
furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in all
copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
SOFTWARE.