A. 現在開發微信公眾號好還是app好兩個有什麼區別
背景如下:
記得有位高中同學,他進了培訓班學了IOS開發,學完之後工作一段時間,因為項目完工沒項目了被辭退了,後來找工作找了許久都沒找著,另外我的另一個同事做IOS開發出身,也是找了許久也沒找到,這是前年的事,微信推出小程序,企業不會花大價錢去做APP了,因為APP要養很多人很長時間才能做出來,而微信小程序兩個人就夠,還有一點原因就是微信用戶量龐大,特別是在一線城市使用二維碼支付的時候,會看到微信公眾號的影子。
從這兩年來看,企業微信公眾號越來越盛行了,它的研發成本低昂,只要遵守它的規則,立馬就能出效果,而且還可以根據大數據分析進行相對的推送。所以要學會微信公眾號開發,但是要用那種語言開發最好呢?
個人覺得用python開發最好,理由如下:
1:微信公眾號官網入門指引案例就是用python寫的;雖然支持C,C#,java,php,python,但為什麼要用python呢,好好想想;
2:python現在很火,爬蟲,數據分析,web應用開發,網站,機器學習,人工智慧都可以用它,符合當今技術潮流;
希望能幫上你
B. android微信支付demo怎麼開通零錢支付
准備:
1,導入微信的libs包libammsdk.jar;
2,測試時使用weixinDemo中的debug_keystore;
3,需要注意應用要通過審核,並且幾個Key值正確,一下為微信支付Demo中的值:
?
1
2
3
4
5
6
7
8
9
10
//微信公眾平台id;
private
String app_wx_appid=WxConstants.app_wx_appid;
//微信開放平台和商戶約定的密鑰
private
String app_wx_secret_key="";
//微信公眾平台商戶模塊和商戶約定的密鑰
private
String app_wx_parent_key="";
//微信公眾平台商戶模塊和商戶約定的支付密鑰
private
String app_wx_pay_key="";
//
商家向財付通申請的商家id */
private
String app_tx_parent_key = "1900000109";
==========================================
根據微信支付Demo,微信支付分為三步:
第一步,獲取accessToken,accessToken值第二步要用;
?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
private
class
GetAccessTokenTask extends
AsyncTask<void,
void,=""
wxgetaccesstokenresult="">
{
@Override
protected
WxGetAccessTokenResult doInBackground(Void... params) {
WxGetAccessTokenResult
result = getAccessToken();
return
result;
}
@Override
protected
void
onPostExecute(WxGetAccessTokenResult result) {
if
(result.localRetCode == WxLocalRetCode.ERR_OK) {
GetPrepayIdTask
getPrepayId = new
GetPrepayIdTask();
getPrepayId.execute(result);
}
}}</void,>
解析伺服器響應
?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
private
WxGetAccessTokenResult getAccessToken() {
WxGetAccessTokenResult
result = new
WxGetAccessTokenResult();
String
url = String.format(api_get_access_token,
"client_credential",
app_wx_appid,
app_wx_secret_key);
byte[]
buf = WeixinUtil.httpGet(url);
if
(buf == null
|| buf.length == 0)
{
result.localRetCode
= WxLocalRetCode.ERR_HTTP;
return
result;
}
String
content = new
String(buf);
result.parseFrom(content);
return
result;
}
第二步,根據第一步的accesstoken值,將 組裝的商品參數Post給微信伺服器
?
1
2
3
4
5
6
7
8
9
10
11
12
13
private
class
GetPrepayIdTask extends
AsyncTask<wxgetaccesstokenresult, void,=""
wxgetprepayidresult="">
{
@Override
protected
WxGetPrepayIdResult doInBackground(WxGetAccessTokenResult... params) {
WxGetPrepayIdResult
result = getPrepayId(params[0]);
return
result;
}
@Override
protected
void
onPostExecute(WxGetPrepayIdResult result) {
if
(result.localRetCode == WxLocalRetCode.ERR_OK) {
sendPayReq(result);
}
}
}</wxgetaccesstokenresult,>
組裝參數
?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
private
WxGetPrepayIdResult getPrepayId(WxGetAccessTokenResult accessTokenResult) {
String
url = String.format(api_get_preorder_id,accessTokenResult.accessToken);
String
entity = appSign.getWxPrepayAppSign();WxGetPrepayIdResult
result = new
WxGetPrepayIdResult();byte[]
buf = WeixinUtil.httpPost(url, entity);
if
(buf == null
|| buf.length == 0)
{
result.localRetCode
= WxLocalRetCode.ERR_HTTP;
return
result;
}String
content = new
String(buf);
result.parseFrom(content);
return
result;
}
Post給伺服器
?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
<span
style="white-space:pre">
</span>private
void
sendPayReq(WxGetPrepayIdResult result) {PayReq
req = new
PayReq();
req.appId
= app_wx_appid;
req.partnerId
= app_tx_parent_key;
req.prepayId
= result.prepayId;
req.nonceStr
= appSign.getNoncestr();
req.timeStamp
= appSign.getTimestamp();
req.packageValue
= "Sign="
+ appSign.getPackageSign();List<namevaluepair>
signParams = new
LinkedList<namevaluepair>();
signParams.add(new
BasicNameValuePair("appid",
req.appId));
signParams.add(new
BasicNameValuePair("appkey",
app_wx_pay_key));
signParams.add(new
BasicNameValuePair("noncestr",
req.nonceStr));
signParams.add(new
BasicNameValuePair("package",
req.packageValue));
signParams.add(new
BasicNameValuePair("partnerid",
req.partnerId));
signParams.add(new
BasicNameValuePair("prepayid",
req.prepayId));
signParams.add(new
BasicNameValuePair("timestamp",
req.timeStamp));
req.sign
= WeixinUtil.genSign(signParams);wxRequest.sendReq(req);
}</namevaluepair></namevaluepair>
?
1
?
1
第三步:在項目下新建一個包wxapi,建立一個類名為WXPayEntryActivity作為接受微信的支付結果,不過最終結果以伺服器的返回為准notify_url:
?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
package
net.sourceforge.simcpux.wxapi;
public
class
WXPayEntryActivity extends
Activity implements
IWXAPIEventHandler{<pre name="code"
class="java"><span
style="white-space:pre">
</span>@Override
public
void
onResp(BaseResp resp) {
Log.d(TAG,
"onPayFinish,
errCode = "
+ resp.errCode);if
(resp.getType() == ConstantsAPI.COMMAND_PAY_BY_WX) {
AlertDialog.Builder
builder = new
AlertDialog.Builder(this);
builder.setTitle("支付結果");
builder.setMessage("支付結果"+String.valueOf(resp.errCode));
builder.show();
}
}</pre>}
<p></p>
<pre
class="brush:java;"></pre>
==========================================
<p></p>
<p>暫時沒想到其他想說的,先看個效果</p>
<p>1,包結構,需要注意的就是接收微信返回結果的那個類名;</p>
<p><img
src="http://www.2cto.com/uploadfile/Collfiles/20140901/201409010901522.png"
alt="\"
style="display:
inline; width: 239px; height: 238px;"></p>
<p>2,組裝數據,規則在文檔中有說明<喎�"http://www.2cto.com/kf/ware/vc/"
target="_blank"
class="keylink">vcD4KPHByZSBjbGFzcz0="brush:java;">//package_
欄位生成方法
//package生成方法:
//A)對所有傳入參數按照欄位名的ASCII
碼從小到大排序(字典序)後,使用URL 鍵值對的格式(即key1=value1&key2=value2…)拼接成字元串string1;
//B)
在string1 最後拼接上key=partnerKey 得到stringSignTemp 字元串, 並對 stringSignTemp進行md5 運算,再將得到的字元串所有字元轉換為大寫,得到sign值signValue。
//C)對string1
中的所有鍵值對中的value 進行urlencode 轉碼,按照a 步驟重新拼接成字元串,得到string2。對於js 前端程序,一定要使用函數encodeURIComponent 進行urlencode編碼(注意!進行urlencode時要將空格轉化為%20而不是+)。
//D)將sign=signValue
拼接到string1 後面得到最終的package 字元串。//app_signature生成方法:
//A)參與簽名的欄位包括:appid、appkey、noncestr、package、timestamp以及
traceid
//B)對所有待簽名參數按照欄位名的ASCII
碼從小到大排序(字典序)後,使用URL 鍵值對的格式(即key1=value1&key2=value2…)拼接成字元串string1。 注意:所有參數名均為小寫字元
//C)對string1
作簽名演算法,欄位名和欄位值都採用原始值,不進行URL 轉義。具體簽名演算法為SHA1</p>
\